如何使用opencv仅检测视频中的左眼?

时间:2018-02-06 00:38:22

标签: python windows opencv haar-classifier

我想在视频流中只检测左眼,但我不能。当我运行此代码时,它会检测到两只眼睛(右侧和左侧),有时它还会像嘴巴一样检测到嘴巴或鼻子。

请遵循以下代码:

import cv2
import numpy as np

faceCascade = cv2.CascadeClassifier('haarcascade_frontalface_default.xml')
#eye_cascade = cv2.CascadeClassifier('haarcascade_eye.xml')
eye_cascade = cv2.CascadeClassifier('haarcascade_lefteye_2splits.xml')

video_capture = cv2.VideoCapture(0)

while True:
    ret, img = video_capture.read()
    gray_img = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)

    faces = faceCascade.detectMultiScale(
        gray_img,
        scaleFactor=1.98,
        minNeighbors=8,
        minSize=(80, 80),
        flags=cv2.cv.CV_HAAR_SCALE_IMAGE    
    )    

    #print 'faces: ', faces
    for (p,q,r,s) in faces:
        #cv2.rectangle(img,(p,q),(p+r,q+s),(255,0,0),3)
        face_gray = gray_img[q:q+s, p:p+r]
        face_color = img[q:q+s, p:p+r]
        eyes = eye_cascade.detectMultiScale(face_gray)
        for (ep,eq,er,es) in eyes:
            cv2.rectangle(face_color,(ep,eq),(ep+er,eq+es), (0,255,0),3)

    rimg = cv2.flip(img, 1) # invert the object img
    cv2.imshow("Video", rimg)

    if cv2.waitKey(1) & 0xFF == ord('q'):
        break

video_capture.release()
cv2.destroyAllWindows()

那么我该如何才能只检测左眼?

PS:我在这个程序中使用的是Python 2.7.13,NumPy 1.10.0和OpenCV 2.4.13.3。

1 个答案:

答案 0 :(得分:1)

您可以使用简单的for循环遍历级联返回的眼睛,并找到具有最小x坐标的眼睛索引。这将为您提供最左眼的索引。

def getleftmosteye(eyes):
 leftmost=9999999
 leftmostindex=-1
  for i in range(0,2):
   if eyes[i][0]<leftmost:
    leftmost=eyes[i][0]
    leftmostindex=i
  return eyes[leftmostindex]

现在,一旦获得左眼的索引,便可以获取左眼的坐标。