Python3 OpenCV调用摄像头进行实时人脸识别

超、凢脫俗 2022-12-21 02:26 284阅读 0赞

写在最前

在Python与计算机视觉这个方向上,我只算个初学者,不会用一些复杂语法,所以代码写得比较简单。代码如有问题或有待进一步优化,请各位同学不吝指出。

项目使用了官方的Haar分类器haarcascade_frontalface_alt.xml进行人脸识别。

项目代码

  1. import cv2
  2. import matplotlib.pyplot as plt
  3. import numpy as np
  4. import time
  5. # 图像显示
  6. def show(image):
  7. plt.imshow(image)
  8. plt.axis('off')
  9. plt.show()
  10. # 图像读取
  11. def imread(path):
  12. image=cv2.imread(path)
  13. image=cv2.cvtColor(image, cv2.COLOR_BGR2RGB)
  14. return image
  15. # 人脸识别与绘制矩形框
  16. def facedetect(image):
  17. dector=cv2.CascadeClassifier('haarcascade_frontalface_alt.xml')
  18. rects=dector.detectMultiScale(image, scaleFactor=1.1, minNeighbors=20, minSize=(10,10), flags=cv2.CASCADE_SCALE_IMAGE)
  19. for (x,y,w,h) in rects:
  20. cv2.rectangle(image, (x,y), (x+w,y+h), (0,255,0), 2)
  21. return image
  22. # 调用摄像头进行人脸识别
  23. def videoRecognition(count=10):
  24. cap=cv2.VideoCapture(0)
  25. while True:
  26. while not cap.isOpened(): # 处理摄像头未正常读取的情况
  27. time.sleep(1) # 延时1s后再次尝试
  28. cap.open()
  29. count=count-1
  30. if count<=0:
  31. return False
  32. ret,frame=cap.read()
  33. image=facedetect(frame)
  34. cv2.imshow('where_is_my_face',image)
  35. if cv2.waitKey(1) & 0xff == ord('q'):
  36. break
  37. cap.release
  38. cv2.destroyAllWindows()
  39. return True

使用时,直接调用videoRecognition即可:

  1. videoRecognition()

项目演示

在这里插入图片描述
按下Q键退出。

发表评论

表情:
评论列表 (有 0 条评论,284人围观)

还没有评论,来说两句吧...

相关阅读