所以我决定开始一起学习 Open CV 和 Python!
我的第一个项目是在相对静止的背景上检测移动物体,然后检测它们的平均颜色以对它们进行排序。至少有 10 个物体需要检测,我正在处理彩色视频。
到目前为止,我设法去除背景,识别轮廓(可选地获取每个轮廓的中心),但现在我正在努力获得每个轮廓内部的平均或平均颜色。有一些关于此类问题的主题,但其中大部分是用 C 编写的。显然我可以使用,cv.mean()但我无法获得一个工作掩码来提供此功能。我想这不是那么困难,但我被困在那里......干杯!
import numpy as np
import cv2
video_path = 'test.h264'
cap = cv2.VideoCapture(video_path)
fgbg = cv2.createBackgroundSubtractorMOG2()
while (cap.isOpened):
ret, frame = cap.read()
if ret==True:
fgmask = fgbg.apply(frame)
(contours, hierarchy) = cv2.findContours(fgmask, cv2.RETR_TREE,cv2.CHAIN_APPROX_NONE)
for c in contours:
if cv2.contourArea(c) > 2000:
cv2.drawContours(frame, c, -1, (255,0,0), 3)
cv2.imshow('foreground and background',fgmask)
cv2.imshow('rgb',frame)
key = cv2.waitKey(1) & 0xFF
if key == ord("q"):
break
cap.release()
cv2.destroyAllWindows()
Run Code Online (Sandbox Code Playgroud)