如何在OpenCV中裁剪检测到的人脸,并在OpenCV Python中将ROI另存为图像



我在python中使用opencv,这是我检测人脸和保存人脸的代码。但它没有保存ROI(检测到的人脸),我一直在执行此操作时遇到问题。请帮助我如何解决此问题。

   TRAINSET = "data/lbpcascades/lbpcascade_frontalface.xml"
   DOWNSCALE = 4
   cam = cv2.VideoCapture(0) #capture a video
   cv2.namedWindow("preview")
   classifier = cv2.CascadeClassifier(TRAINSET) 
   Compare_images=[]
   for file in os.listdir("images"):
       if file.endswith(".jpg"):
          Compare_images.append(file)
while True: # try to get the first frame
    _, frame = cam.read() 
key = cv2.waitKey(20)
if(key==32):
    print "Name of Image:"
    n= raw_input()
    value=len(Compare_images)
    cv2.imwrite('images/image'+str(n)+'.jpg', frame)
    saved_image=cv2.imread("images/image"+str(n)+".jpg")
    minisize = (saved_image.shape[1]/DOWNSCALE,saved_image.shape[0]/DOWNSCALE)
    miniframe = cv2.resize(saved_image, minisize)
    faces = classifier.detectMultiScale(miniframe)
    for f in faces:
        x, y, w, h = [ v*DOWNSCALE for v in f ]     
        print x 
        print y,w,h      
        x0,y0=int(x),int(y)
        x1,y1=int(x+w),int(y+h)
        print x0,y0,y1,y0
        image = cv2.rectangle(saved_image, (x0,y0), (x1,y1), (0,0,255),2)
        roi=saved_image[y0:y1,x1:x0]#crop 
        cv2.imwrite('roi.jpg',roi)
        cv2.imshow("adsa", saved_image) 

cv2.putText(frame, "Press ESC to close.", (5, 25),
            cv2.FONT_HERSHEY_SIMPLEX, 1.0, (255,255,255))
cv2.imshow("preview", frame)

你的意思是?

.
.
.
print x0,y0,x1,y1
.
.
.
roi=saved_image[y0:y1,x0:x1]

while语句上方和下方的缩进似乎不正确。

三引号只能暂时用于块报价,因为它们可能会导致问题。

也许改用#

#x0,y0=x,y
#x1,y1=x+w,y+h

除非这是该函数的帮助应该读取的方式。

在您的问题中包含错误也会有所帮助。

相关内容

  • 没有找到相关文章

最新更新