2

我是 python 和 opencv 的新手,我正在尝试用树莓派构建一个人脸检测项目。我收到此错误,这是我的代码

回溯(最近一次通话最后):

 File "/home/pi/Desktop/picamera-code/FaceDetection1.0", line 19, in <module>
for frame in 
    camera.capture_continuous(rawCapture, format="bgr", use_video_port=True):

代码:

import numpy as np
import cv2
from picamera.array import PiRGBArray
from picamera import PiCamera
import time


camera = PiCamera()
camera.resolution = (640, 480)
camera.framerate = 32
rawCapture = PiRGBArray(camera, size=(640, 480))

time.sleep(0.1)



face_cascade =  cv2.CascadeClassifier('/home/pi/Downloads/haarcascade_frontalface_default.xml')

for frame in camera.capture_continuous(rawCapture, format="bgr",  use_video_port=True):

    img=np.asarray(frame.array)
    gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)

    faces = face_cascade.detectMultiScale(gray, 1.3, 5)
    for (x,y,w,h) in faces:
        img = cv2.Rectangle(img,(x,y),(x+w,y+h),(255,0,0),2)
        roi_gray = gray[y:y+h, x:x+w]
        roi_color = img[y:y+h, x:x+w]


cv2.imshow('img',img)
cv2.waitKey(0)
cv2.destroyAllWindows()
4

3 回答 3

5

问题出在你的camera.capture_continuos. 第一个值,输出,不能只是一个数组,因为它像文档所说的那样以无限迭代记录。取而代之的是,您应该放置一个输出文件。如果您想要一个流来捕获它,您也可以使用 io.Bytes 。

在此链接中,它向您解释了有关如何使用框架以及应将输出重定向到何处的示例。

您可以执行 API 文档中建议的操作。获取流并截断它以获取您当前正在获取的图像:

import io
import time
import picamera
with picamera.PiCamera() as camera:
    stream = io.BytesIO()
    for foo in camera.capture_continuous(stream, format='jpeg'):
    # YOURS:  for frame in camera.capture_continuous(stream, format="bgr",  use_video_port=True):
        # Truncate the stream to the current position (in case
        # prior iterations output a longer image)
        stream.truncate()
        stream.seek(0)
        if process(stream):
            break
于 2015-04-29T09:56:51.510 回答
3

正确答案是您需要在循环结束时截断流。添加

rawCapture.truncate(0) 

在第一个 for 循环结束时。

于 2017-02-20T23:42:58.363 回答
0

如果您将第 11 640、420 ​​行中的部分更改为 160、120,它应该可以工作

于 2017-01-27T01:16:17.633 回答