python - 从视频中裁剪人脸并另存为图像
问题描述
每次出现在视频中时,我都试图裁剪一张脸,但它似乎没有创建图像文件。
我已经包含了一条 imshow 线,以查看是否有从边界框创建的图像以及是否有一张被裁剪的脸。任何帮助,将不胜感激。
代码:
import numpy as np
import cv2
import os
detector= cv2.CascadeClassifier("haarcascade_frontalface_default.xml")
cap = cv2.VideoCapture("smallvid.mp4")
while(True):
ret, img = cap.read()
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
faces = detector.detectMultiScale(gray, 1.3, 5)
count = 1
for (x,y,w,h) in faces:
cropped = img[ y : y+h, x : x+w ]
cv2.imwrite("cropped_face" + str(id) + ".png", cropped)
count=count+1
cv2.imshow(out_dir+str(count), cropped); # show an image of each face
cv2.rectangle(img,(x,y),(x+w,y+h),(255,0,0),2) # create bounding box around face
cv2.imshow('frame',img)
if cv2.waitKey(1) & 0xFF == ord('q'):
break
cap.release()
cv2.destroyAllWindows()
enter code here
解决方案
你可以像这样裁剪。
img[y:y+w, x:x+w]
推荐阅读
- node.js - 每次运行重定向操作时都创建新文件
- python - 根据条件以有序方式填充NA值
- android - 当 setNotificationVisibility 为隐藏时,下载管理器不工作
- r - 如果每个列分别满足条件,则将值设置为零
- r - 如何使用 column_spec() 或替代方法来指定表格的最后一列相对于 pdf 页面大小应该在哪里结束?
- python - 尝试登录网站并下载 zipfile
- reactjs - useReducer 状态更新不会在具有依赖关系的另一个组件中重新渲染 useEffect
- amazon-dynamodb - DataDog DynamoDB 指标
- http - Nginx 缓存 301 响应
- python - 文件和文件夹树的数据结构?