日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

python實現圖像外邊界跟蹤操作

瀏覽:163日期:2022-07-17 15:54:55

share一些python實現的code

#!/usr/bin/env python#coding=utf-8 import cv2 img = cv2.imread('trace_border2.bmp')[img_h, img_w, img_channel] = img.shape trace = []start_x = 0start_y = 0 gray = img[:,:,1]for h in range(img_h): for w in range(img_w): if (gray[h,w] > 128): gray[h,w] = 255 else: gray[h,w] = 0 #python 跳出多重循環#https://www.cnblogs.com/xiaojiayu/p/5195316.htmlclass getoutofloop(Exception): passtry: for h in range(img_h - 2): for w in range(img_w - 2): if gray[h,w] == 0:start_x = wstart_y = hraise getoutofloopexcept getoutofloop: pass print('Start Point (%d %d)'%(start_x, start_y))trace.append([start_x, start_y]) # 8鄰域 順時針方向搜索neighbor = [[-1,-1],[0,-1],[1,-1],[1,0],[1,1],[0,1],[-1,1],[-1,0]]neighbor_len = len(neighbor) #先從當前點的左上方開始,# 如果左上方也是黑點(邊界點):# 搜索方向逆時針旋轉90 i-=2# 否則:# 搜索方向順時針旋轉45 i+=1i = 0cur_x = start_x + neighbor[i][0]cur_y = start_y + neighbor[i][1] is_contour_point = 0 try: while not ((cur_x == start_x) and (cur_y == start_y)): is_contour_point = 0 while is_contour_point == 0: #neighbor_x = cur_x + if gray[cur_y, cur_x] == 0:is_contour_point = 1trace.append([cur_x, cur_y])i -= 2if i < 0: i += neighbor_len else:i += 1if i >= neighbor_len: i -= neighbor_len #print(i) cur_x = cur_x + neighbor[i][0] cur_y = cur_y + neighbor[i][1]except: print('throw error') for i in range(len(trace)-1): cv2.line(img,(trace[i][0],trace[i][1]), (trace[i+1][0], trace[i+1][1]),(0,0,255),3) cv2.imshow('img', img) cv2.waitKey(10) cv2.rectangle(img,(start_x, start_y),(start_x + 20, start_y + 20),(255,0,0),2)cv2.imshow('img', img)cv2.waitKey(0)cv2.destroyWindow('img')

搜索過程,紅色標記線如下:

python實現圖像外邊界跟蹤操作

補充知識:python實現目標跟蹤(opencv)

1.單目標跟蹤

import cv2import sys (major_ver, minor_ver, subminor_ver) = (cv2.__version__).split(’.’)print(major_ver, minor_ver, subminor_ver) if __name__ == ’__main__’: # 創建跟蹤器 tracker_type = ’MIL’ tracker = cv2.TrackerMIL_create() # 讀入視頻 video = cv2.VideoCapture('./data/1.mp4') # 讀入第一幀 ok, frame = video.read() if not ok: print(’Cannot read video file’) sys.exit() # 定義一個bounding box bbox = (287, 23, 86, 320) bbox = cv2.selectROI(frame, False) # 用第一幀初始化 ok = tracker.init(frame, bbox) while True: ok, frame = video.read() if not ok: break # Start timer timer = cv2.getTickCount() # Update tracker ok, bbox = tracker.update(frame) # Cakculate FPS fps = cv2.getTickFrequency() / (cv2.getTickCount() - timer) # Draw bonding box if ok: p1 = (int(bbox[0]), int(bbox[1])) p2 = (int(bbox[0] + bbox[2]), int(bbox[1] + bbox[3])) cv2.rectangle(frame, p1, p2, (255,0,0), 2, 1) else: cv2.putText(frame, 'Tracking failed detected', (100, 80), cv2.FONT_HERSHEY_SIMPLEX, 0.75, (0, 0, 255), 2) # 展示tracker類型 cv2.putText(frame, tracker_type+'Tracker', (100, 20), cv2.FONT_HERSHEY_SIMPLEX, 0.75, (50, 170, 50), 2) # 展示FPS cv2.putText(frame, 'FPS:'+str(fps), (100, 50), cv2.FONT_HERSHEY_SIMPLEX, 0.75, (50, 170, 50), 2) # Result cv2.imshow('Tracking', frame) # Exit k = cv2.waitKey(1) & 0xff if k ==27 : break

2.多目標跟蹤

使用GOTURN作為跟蹤器時,須將goturn.caffemodel和goturn.prototxt放到工作目錄才能運行,解決問題鏈接https://stackoverflow.com/questions/48802603/getting-deep-learning-tracker-goturn-to-run-opencv-python

import cv2import sys (major_ver, minor_ver, subminor_ver) = (cv2.__version__).split(’.’)print(major_ver, minor_ver, subminor_ver) if __name__ == ’__main__’: # 創建跟蹤器 # ’BOOSTING’, ’MIL’,’KCF’, ’TLD’, ’MEDIANFLOW’, ’GOTURN’, ’MOSSE’ tracker_type = ’MIL’ tracker = cv2.MultiTracker_create() # 創建窗口 cv2.namedWindow('Tracking') # 讀入視頻 video = cv2.VideoCapture('./data/1.mp4') # 讀入第一幀 ok, frame = video.read() if not ok: print(’Cannot read video file’) sys.exit() # 定義一個bounding box box1 = cv2.selectROI('Tracking', frame) box2 = cv2.selectROI('Tracking', frame) box3 = cv2.selectROI('Tracking', frame) # 用第一幀初始化 ok = tracker.add(cv2.TrackerMIL_create(), frame, box1) ok1 = tracker.add(cv2.TrackerMIL_create(), frame, box2) ok2 = tracker.add(cv2.TrackerMIL_create(), frame, box3) while True: ok, frame = video.read() if not ok: break # Start timer timer = cv2.getTickCount() # Update tracker ok, boxes = tracker.update(frame) print(ok, boxes) # Cakculate FPS fps = cv2.getTickFrequency() / (cv2.getTickCount() - timer) for box in boxes: # Draw bonding box if ok:p1 = (int(box[0]), int(box[1]))p2 = (int(box[0] + box[2]), int(box[1] + box[3]))cv2.rectangle(frame, p1, p2, (255, 0, 0), 2, 1) else:cv2.putText(frame, 'Tracking failed detected', (100, 80), cv2.FONT_HERSHEY_SIMPLEX, 0.75, (0, 0, 255),2) # 展示tracker類型 cv2.putText(frame, tracker_type+'Tracker', (100, 20), cv2.FONT_HERSHEY_SIMPLEX, 0.75, (50, 170, 50), 2) # 展示FPS cv2.putText(frame, 'FPS:'+str(fps), (100, 50), cv2.FONT_HERSHEY_SIMPLEX, 0.75, (50, 170, 50), 2) # Result cv2.imshow('Tracking', frame) # Exit k = cv2.waitKey(1) & 0xff if k ==27 : break

以上這篇python實現圖像外邊界跟蹤操作就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Python 編程
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
久久精品亚洲| 欧美日韩尤物久久| 日韩欧美中文字幕在线视频| 国产极品久久久久久久久波多结野 | 欧美日韩激情在线一区二区三区| 亚洲丝袜美腿一区| 97精品中文字幕| 九色精品91| 国产成人精品免费视| 四虎成人精品一区二区免费网站| 日韩黄色大片网站| 中文字幕一区二区精品区| 青青久久av| 91精品国产自产观看在线| 精品日本视频| 国产欧美日韩亚洲一区二区三区| 亚洲国产日韩欧美在线| av资源亚洲| 国产精品久久久久久模特| 一区二区三区网站| 在线看片日韩| 先锋影音久久久| 亚洲爱爱视频| 激情婷婷久久| 欧美日韩一区二区三区视频播放| 欧美日本久久| 美女视频黄免费的久久| 国产精品一区二区美女视频免费看| 蜜臀国产一区二区三区在线播放| 麻豆久久精品| 亚洲精品乱码| 欧美在线观看天堂一区二区三区| 日本h片久久| 国产精品久久免费视频| 久久精品午夜| 日韩精品欧美激情一区二区| 久久久成人网| 国产一区二区三区日韩精品| 精品国产亚洲一区二区三区大结局| 免费日韩一区二区三区| 97视频热人人精品免费| 国产一区二区中文| 午夜性色一区二区三区免费视频| 69堂免费精品视频在线播放| 国产一区一一区高清不卡| 欧美日韩一二三四| 亚洲v天堂v手机在线| 久久中文字幕一区二区三区| 国产精品欧美在线观看| 九九99久久精品在免费线bt| 九九在线精品| 精品一区视频| 欧美成人午夜| 国产免费av国片精品草莓男男| 国产成人调教视频在线观看| 国产视频亚洲| 国产精品久久久久久久免费观看 | 亚洲国产一区二区在线观看 | 国产在线不卡一区二区三区| 日韩精品影视| 国产精品毛片久久久| 人人精品亚洲| 麻豆中文一区二区| 亚洲人www| 不卡av一区二区| 国产精品视频一区二区三区| 国产网站在线| 岛国精品一区| 欧美精品成人| 欧美亚洲综合视频| 中文字幕中文字幕精品| 欧美日韩国产综合网| 狠狠久久伊人| 国产欧美啪啪| 国产精品嫩模av在线| 亚洲精品综合| 亚洲女同中文字幕| 亚洲在线国产日韩欧美| 国产一区二区三区成人欧美日韩在线观看 | 欧美激情五月| 国产精选久久| 日韩精品免费一区二区夜夜嗨| av不卡在线| 视频一区中文字幕| 麻豆久久精品| 日韩精品1区2区3区| 亚洲国产一区二区在线观看| 久久中文字幕av| 韩国精品主播一区二区在线观看| 免费在线欧美黄色| 国产真实久久| 丝袜亚洲精品中文字幕一区| 另类av一区二区| 欧美亚洲网站| 欧洲一区二区三区精品| 亚洲一级黄色| 日韩中文av| 国产一区二区三区四区| 久久精品av| 亚洲精品伦理| 麻豆精品在线| 国产精品网址| 久久精品国产精品亚洲毛片| 97精品国产| 国产精品普通话对白| 日韩精品视频在线看| 日韩精品麻豆| 国产亚洲第一伦理第一区| 91精品xxx在线观看| 午夜天堂精品久久久久| а√天堂8资源在线| 三级在线观看一区二区| 国产日韩1区| 夜夜嗨一区二区三区| 国产精品成人3p一区二区三区| 欧美日韩一区二区三区四区在线观看 | 激情综合亚洲| 国产精品a级| 亚洲性视频在线| 国产精品久久久久av电视剧| 奇米亚洲欧美| 久久先锋影音| 成人看片网站| 国产精品99视频| 国产午夜精品一区在线观看| 国产精品普通话对白| 日韩精品影视| 麻豆国产欧美一区二区三区 | 亚洲免费中文| 婷婷成人综合| 久久精品导航| 亚洲成av人片一区二区密柚| 久久精品国产久精国产爱| 日本欧美大码aⅴ在线播放| 免费精品国产| 欧美在线资源| 在线视频精品| 午夜亚洲精品| 亚洲18在线| 自由日本语亚洲人高潮| 午夜国产一区二区| 女主播福利一区| 久久婷婷av| 一区二区自拍| 中文字幕一区二区三区四区久久| 国产精品88久久久久久| 蜜臀久久99精品久久一区二区| 91精品福利| 亚洲精品欧洲| 国产欧美丝祙| 999国产精品视频| 久久久精品午夜少妇| 久久福利毛片| 亚洲二区精品| 国产色综合网| 日韩国产成人精品| 国内在线观看一区二区三区| 国产精品分类| 亚洲国产影院| 国产调教精品| 亚洲香蕉网站| 欧美精品三级在线| 日韩大片免费观看| 久久亚洲二区| 精品久久99| 亚洲免费成人av在线| 麻豆中文一区二区| 在线精品视频在线观看高清| 视频一区二区三区在线| 欧美日韩1区2区3区| 中文一区一区三区高中清不卡免费| 日韩成人综合| 欧美日韩免费观看一区=区三区| 国产日韩欧美一区二区三区 | 国产精品一站二站| 日韩中文在线电影| 蜜桃久久精品一区二区| 精品一区电影| 91成人小视频| 首页欧美精品中文字幕| 亚洲a级精品| 久久国产影院| 久久精品国产999大香线蕉| 视频一区二区三区在线| 国产伦精品一区二区三区视频| 91精品精品| 韩国久久久久久| 久久精品人人| 国产精品一站二站| 日韩精品久久理论片| 免费人成精品欧美精品| 黄色亚洲精品| 欧美~级网站不卡| 日本欧美不卡| 人人精品亚洲| 91国内精品| 久久国产精品99国产| 国产综合精品一区| 99国产精品| 国产麻豆久久|