第一章 2 用opencv调用摄像头
-
opencv提供非常简单的接口 VideoCapture()函数,它的参数可以是设备的索引号‘例如0,1,2’,也可以是一个视频文件‘视频地址’。
-
import numpy as np import cv2 cap=VideoCapture(0) while(True) ret,flame=cap.read() gray=cv2.cvtColar(flame,cv2.COLOR_BGR2GRAY) cv2.imshow('flame',gray) if cv2.waitKey(1)&0xFF==ord('q'): break cap.release() cv2.destroyAllWindows()
-
-
cap.read() 返回一个布尔值(True/False)。如果帧读取的是正确的,就是 True。所以最后你可以通过检查他的返回值来查看视频文件是否已经到了结尾。
-
有时 cap 可能不能成功的初始化摄像头设备。这种情况下上面的代码会报错。你可以使用 cap.isOpened(),来检查是否成功初始化了。如果返回值是True,那就没有问题。否则就要使用函数 cap.open()。
-
你可以使用函数 cap.get(propId) 来获得视频的一些参数信息。这里propId 可以是 0 到 18 之间的任何整数。每一个数代表视频的一个属性,见下表其中的一些值可以使用 cap.set(propId,value) 来修改, value 就是你想要设置成的新值。例如,我可以使用 cap.get(3) 和 cap.get(4) 来查看每一帧的宽和高。默认情况下得到的值是 640X480。但是我可以使用 ret=cap.set(3,320)和 ret=cap.set(4,240) 来把宽和高改成 320X240。
从文件播放视频
-
cv2.VidoeCapture(‘路径’)
# -*- coding:utf-8 -*- import numpy as np import cv2 cap=cv2.VideoCapture('retime.mov') while(True): ret,frame=cap.read() cv2.imshow('retime.mov',frame) if cv2.waitKey(30)&0xFF==ord('q'): break cap.release() cv2.destroyAllWindows()
从摄像头捕获视频
- 只需设置cv2.waitKey()的时间。一般设置为30就可以了。
- 捕获视频后保存不能继续简单的用cv2.imwritw()了,这里我们需要创建一个VideoWrite对象,然后指定FourCC编码(用来确定视频格式),最后需要一个颜色标签,如果是True,每一帧是彩图,否则就是灰度图。
VideoWrite(const string& filename, // 输入文件名
int fourcc, // 编码形式,使用 CV_FOURCC()宏
double fps, // 输出视频帧率
Size frame_size, // 单帧图片的大小
bool is_color = true // 如果是false,可传入灰度图像 )
-
代码如下
# -*- coding:utf-8 -*- import numpy as np import cv2 #初始化摄像头 cap=cv2.VideoCapture(0) #定义标签并且创建输出对象 fourcc=cv2.VideoWriter_fourcc(*'XVID')#定义编码格式MJPG编码 out=cv2.VideoWriter('out.avi',fourcc,30.0,(640,480)) while(cap.isOpened()): ret,flame=cap.read() if ret==True: flame=cv2.flip(flame,0)#flip()图像翻转 out.write(flame) cv2.imshow('flame',flame) if cv2.waitKey(1)&0xFF==ord('q'): break else: break cap.release() out.release() cv2.destroyAllWindows()