win7系统做目标检测时,需要用到摄像头,但是无法调用摄像头,并报如下错误
问题分析
没有思路,直接问下chatgpt
它说:
还是没有解决的思路。
百度博客,看有用的信息
- 读python中使用opencv无法打开usb摄像头的问题
自己摸索
打开自己项目中的datasets.py
datasets.py 是一个 Python3 数据集工具库(Datasets),旨在提供一种标准化的、易于使用的对数据集进行处理、分析和访问的方式。该库提供了各种数据集的 API,可以帮助用户快速加载和预处理各种数据集,包括文本、语音、图像等多种类型。
找到关于的信息
cap = cv2.VideoCapture(0)
关于VideoCapture参数问题,(1)中的博客中已经做了详细介绍
class LoadImages:
.......
def new_video(self, path):
self.frame = 0
self.cap = cv2.VideoCapture(path)
self.frames = int(self.cap.get(cv2.CAP_PROP_FRAME_COUNT))
添加图片内容的识别模式
class LoadImages:
.......
def new_video(self, path):
self.frame = 0
self.cap = cv2.VideoCapture(path,cv2.CAP_DSHOW) #这个调用了cv2.CAP_DSHOW参数的接口
self.frames = int(self.cap.get(cv2.CAP_PROP_FRAME_COUNT))
更改摄像头参数,调用笔记本自带的摄像头
原代码
class LoadWebcam: # for inference
# YOLOv5 local webcam dataloader, i.e. `python detect.py --source 0`
.......
def __init__(self, pipe='0', img_size=640, stride=32):
self.img_size = img_size
self.stride = stride
self.pipe = eval(pipe) if pipe.isnumeric() else pipe
self.cap = cv2.VideoCapture(self.pipe) # video capture object
self.cap.set(cv2.CAP_PROP_BUFFERSIZE, 3) # set buffer size
更改后代码
class LoadWebcam: # for inference
# YOLOv5 local webcam dataloader, i.e. `python detect.py --source 0`
.......
def __init__(self, pipe='0', img_size=640, stride=32):
self.img_size = img_size
self.stride = stride
self.pipe = eval(pipe) if pipe.isnumeric() else pipe
self.cap = cv2.VideoCapture(self.pipe,cv2.CAP_DSHOW) # 这里也需要调用cv2.CAP_DSHOW 参数
self.cap.set(cv2.CAP_PROP_BUFFERSIZE, 3)
注意事项:
我这里添加cv2.CAP_DSHOW,运行程序后,我的摄像头是可以正常开启的。
因为我还要进行上传视频进行识别,发现此时的视频识别是不可用的
我的解决方法是,将更改后的代码改回原样。 问题能够神奇的解决
我分析原因是:
- 添加参数成功的唤醒了,摄像头。
- 此时摄像头,已经被唤醒了。
- 现在更改回参数,摄像头还是可以正常运行。