我想在Python上用OpenCV检测手。
我工作的这个阈值的图像上:
这就是轮廓drawed状态:
我想检测的手,但轮廓太大,它抓住了我的全身。
我需要这样的:
OpenCV分割轮廓
我的代码:
import cv2
orImage = cv2.imread("f.png")
image = cv2.cvtColor(orImage,cv2.COLOR_BGR2GRAY)
image = cv2.blur(image,(15,15))
(_,img_th) = cv2.threshold(image,96,255,1)
(contours,_) = cv2.findContours(img_th, cv2.RETR_TREE, cv2.CHAIN_APPROX_SIMPLE)
for c in contours:
if cv2.contourArea(c) > 15:
x,y,w,h = cv2.boundingRect(c)
cv2.rectangle(image,(x-20,y-20),(x+w+20,y+h+20),(0,255,0),2)
cv2.drawContours(image,contours,-1,(255,0,0),2)
cv2.imwrite("hi.jpg",image)
谢谢!
要从身体的其余部分分离手轮廓,您需要使用阈值算法。你有实际的输入图像吗? –
或者,也许你可以检测实际图像中的边缘,然后将其与轮廓图像重叠。 –
是的,我愿意。 http://i.imgur.com/YOFXf9u.jpg但我想我需要像“最大面积” –