我是使用 OpenCV 人脸检测器的新手。面部检测工作正常,但我正在尝试使用生成的矩形围绕面部制作框架并将其剪切以将面部保存在新存档中。我一直在使用 getSubRect 和“haarcascade_frontalface_default”(左、上、宽、高)返回的值。假设 GetSubRect 的参数是(图像,(左,上,右,下)但它不起作用,因为生成的图像没有使脸部居中。我的错误是什么?
代码如下:
import sys
import cv
imcolor = cv.LoadImage('C:\\Temp\\camera_test2.jpg') # input image
# loading the classifier
haarFace = cv.Load('c:\opencv\data\haarcascades\haarcascade_frontalface_default.xml')
# running the classifier
storage = cv.CreateMemStorage()
detectedFace = cv.HaarDetectObjects(imcolor, haarFace, storage, 1.1)
if detectedFace:
arg1 = detectedFace[0][0][0]
arg2 = detectedFace[0][0][1]
arg3 = detectedFace[0][0][2]
arg4 = detectedFace[0][0][3]
Izq = arg1 - arg3/10
Sup = arg2 - arg4/6
Der = arg1 + arg3 #+ (arg3/10)
Inf = arg2 + arg4 +(arg4/6)
print detectedFace
print Izq
print Sup
print Der
print Inf
imcolor2 = cv.GetSubRect(imcolor,(Izq, Sup, Der, Inf))
cv.SaveImage('C:\\temp\\test_1.JPG', imcolor2)
cv.WaitKey()