如何在OpenCV中获取最近的图像

时间:2018-03-07 09:01:18

标签: python opencv image-processing

我使用了以下代码。但是,我可以控制网络摄像头中的面部。但是,如何将最近的图像提取到相机。有人可以帮忙吗?

import cv2
import numpy as np
import time

face_cascade = cv2.CascadeClassifier('C:\\Users\\Admin\\Desktop\\opencv\\opencv\\data\\haarcascades\\haarcascade_frontalface_default.xml')

eye_cascade = cv2.CascadeClassifier('C:\\Users\\Admin\\Desktop\\opencv\\opencv\\data\\haarcascades\\haarcascade_eye.xml')

cap = cv2.VideoCapture(0)

while True:
    ret,img = cap.read()
    gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
    faces = face_cascade.detectMultiScale(gray, 1.3,5)
    print len(faces)
    for(x,y,w,h) in faces:
    crop_img = img[y: y + h, x: x + w] #Crop from x, y, w, h->100, 200, 300, 400
        ts = time.time()
        'cv2.imwrite("C:\\Users\\Admin\\Desktop\\opencv\\detectedfaces\\"+str(ts)+".jpg", crop_img)'
        cv2.rectangle(img, (x,y), (x+w,y+h), (255,0,0), 2)
        roi_gray = gray[y:y+h,x:x+h]
        roi_color = img[y:y+h,x:x+h]
        eyes = eye_cascade.detectMultiScale(roi_gray)
        for(ex,ey,ew,eh) in eyes:
                 cv2.rectangle(roi_color, (ex,ey), (ex+ew,ey+eh), (0,255,0), 2)
    cv2.imshow('img',img)
    time.sleep(5)
    k = cv2.waitKey(1) & 0xFF == ord('q')
    if k == 27:
        break;

cap.release()
cv2.destroAllWindows()

1 个答案:

答案 0 :(得分:0)

由于你有眼睛位置,我只使用IOD(眼间距离)。基本上是两眼ROI中心之间的距离。该指标可用于推断与相机的距离。

这样的事情可以胜任:

if len(eyes) >= 2:
  IOD = abs((eyes[0][0] + eyes[0][1] / 2.0) - (eyes[1][0] + eyes[1][1] / 2.0))
  cv2.putText(img,'%d'%IOD, (30,30), cv2.FONT_HERSHEY_SIMPLEX, 1, (0,255,0), 1)

如果两个人距离相机的距离大致相同,那将是非常准确的,但我不会想太多。您还可以关联面部宽度和IOD以补偿具有不同大小头部的人。