我的帧差分(前景检测)工作得很好。现在,我想给它添加一个额外的功能,那就是斑点检测。基本上,我的想法是在检测到的物体的运动上形成斑点圆。
这是我的代码:
import cv2
cap = cv2.VideoCapture('14.mp4')
ret, current_frame = cap.read()
previous_frame = current_frame
# Setup SimpleBlobDetector parameters.
params = cv2.SimpleBlobDetector_Params()
# Change blob detection thresholds
params.minThreshold = 200
params.maxThreshold = 255
params.minDistBetweenBlobs = 100
# Filter by Area.
params.filterByArea = True
params.minArea = 1200
params.maxArea = 40000
# Filter by Circularity
params.filterByCircularity = False
params.minCircularity = 0.1
# Filter by Convexity
params.filterByConvexity = False
params.minConvexity = 0.87
# Filter by Inertia
params.filterByInertia = True
params.minInertiaRatio = 0.02
# Create a detector with the parameters
detector = cv2.SimpleBlobDetector_create(params)
#Detect blobs
keypoints = detector.detect(current_frame)
while(cap.isOpened()):
current_frame_gray = cv2.cvtColor(current_frame, cv2.COLOR_BGR2GRAY)
previous_frame_gray = cv2.cvtColor(previous_frame, cv2.COLOR_BGR2GRAY)
frame_diff = cv2.absdiff(current_frame_gray,previous_frame_gray)
im_with_keypoints = cv2.drawKeypoints(frame_diff, keypoints, np.array([]), (0,0,255), cv2.DRAW_MATCHES_FLAGS_DRAW_RICH_KEYPOINTS)
cv2.imshow('frame diff ',im_with_keypoints )
if cv2.waitKey(1) & 0xFF == ord('q'):
break
previous_frame = current_frame.copy()
ret, current_frame = cap.read()
keypoints = detector.detect(current_frame)
cap.release()
cv2.destroyAllWindows()
我的错误是"image不是数字数组,也不是标量“
发布于 2016-07-09 16:21:52
您正在将cap
变量传递给函数detector.detect
,但是cap
来自cv2.VideoCapture
,它返回一个CvCapture对象,而不是一个Numpy数组。
相反,您应该使用.read()
返回的current_frame
。
keypoints = detector.detect(current_frame)
发布于 2017-05-22 21:49:25
你应该导入库"numpy“
您可以在cmd(win+R,cmd,enter)上安装它: pip install numpy
并在您的代码中编写:将numpy导入为np
发布于 2019-06-13 07:36:07
这个问题是由阈值参数引起的,主要是params.minThreshold = 100
和params.maxThreshold = 255
。为什么要设置这些特定值?试着推送它们,直到你得到好的结果。
顺便说一句,你似乎没有得到这个错误,但当我在我的一个.avi视频上运行你的代码时,我得到了一个cv2.error。我通过将while(cap.isOpened()):
更改为while(ret)
修复了它。
https://stackoverflow.com/questions/38279741
复制相似问题