作者:安澈澈^
案列:© Fu Xianjun. All Rights Reserved.
目标检测
可提取视频中自己所感兴趣的部分
import cv2
import numpy as np
OPENCV_OBJECT_TRACKERS = {
"csrt": cv2.TrackerCSRT_create,
"kcf": cv2.TrackerKCF_create,
"boosting": cv2.TrackerBoosting_create,
"mil": cv2.TrackerMIL_create,
"tld": cv2.TrackerTLD_create,
"medianflow": cv2.TrackerMedianFlow_create,
"mosse": cv2.TrackerMOSSE_create
}
#2.实例化追踪器对象
trackers = cv2.MultiTracker_create()
#3.视频基本处理方法
vs = cv2.VideoCapture("name.mp4")
while True:
frame = vs.read()
frame = frame[1]
if frame is None:
break
(h,w) = frame.shape[:2]
width=600
r = width/float(w)
dim = (width,int(h*r))
frame = cv2.resize(frame,dim,interpolation = cv2.INTER_AREA)
#4.追踪结果与区域绘制
(success,boxes) = trackers.update(frame)
for box in boxes:
(x,y,w,h)= [int(v) for v in box]
cv2.rectangle(frame,(x,y),(x+w,y+h),(0,255,0),2)
cv2.imshow("Frame",frame)
#5.选择目标ROI
key = cv2.waitKey(100)& 0xFF
if key==ord("s"):
box = cv2.selectROI("Frame",frame,fromCenter=False,
showCrosshair=True)
tracker = OPENCV_OBJECT_TRACKERS["csrt"]()
trackers.add(tracker,frame,box)
elif key ==27:
break
#6.关闭视频
vs.release()
cv2.destroyAllWindows()