目录
代码示例
#########################从摄像头读取视频帧##########################
import cv2
# 创建窗口
cv2.namedWindow('camera',cv2.WINDOW_AUTOSIZE)
# 获取视频设备,选择默认摄像头
camera = cv2.VideoCapture(0)
# 判断摄像头调用是否成功,调用失败退出程序
if not camera.isOpened():
exit()
# 读取视频
while True:
# 读取视频帧
retval, image = camera.read()
# 窗口显示视频帧
cv2.imshow('camera', image)
# 等待键盘按键q,停止读取视频
if cv2.waitKey(1) & 0xFF == ord('q'):
break
#释放资源
camera.release()
cv2.destroyAllWindows()
#########################从多媒体文件读取视频帧##########################
import cv2
# 创建窗口
cv2.namedWindow('camera',cv2.WINDOW_AUTOSIZE)
# 获取多媒体资源,该视频为24帧,每帧应停留1000/24=41.7ms
camera = cv2.VideoCapture('D:\深度学习\计算机视觉学习资源\特征检测的基本概念.mp4')
# 判断多媒体文件调用是否成功,调用失败退出程序
if not camera.isOpened():
exit()
# 读取视频
while True:
# 读取视频帧
retval, image = camera.read()
# 窗口显示视频帧
cv2.imshow('camera', image)
# 等待键盘按键q,停止读取视频
if cv2.waitKey(42) & 0xFF == ord('q'):
break
#释放资源
camera.release()
cv2.destroyAllWindows()
VideoCapture构造函数
VideoCapture()
VideoCapture(filename)
VideoCapture(index)
功能:创建一个VideoCapture类的实例,如果传入对应的参数,可以直接打开视频文件或者要调用的摄像头。
filename:打开的视频文件名。
index:打开的视频捕获设备id ,如果只有一个摄像头可以填0,表示打开默认的摄像头,如果系统中有多个摄像机,那么只要将其向上增加即可。
VideoCapture.isOpened()
功能:判断视频读取或者摄像头调用是否成功,成功则返回True。
VideoCapture.release()
功能:关闭视频文件或者摄像头。
VideoCapture.grab()
功能:从视频文件或捕获设备中抓取下一个帧,假如调用成功返回True。
VideoCapture.retrieve()
功能:解码并且返回刚刚抓取的视频帧,假如没有视频帧被捕获(相机没有连接或者视频文件中没有更多的帧)将返回False。
VideoCapture.read()
retval, image = cv2.VideoCapture.read()
该函数结合VideoCapture.grab()和VideoCapture.retrieve(),用于捕获、解码和返回下一个视频帧这是一个最方便的函数对于读取视频文件或者捕获数据从解码和返回刚刚捕获的帧,假如没有视频帧被捕获(相机没有连接或者视频文件中没有更多的帧)将返回False。
- image:是返回的捕获到的帧,如果没有帧被捕获到,则该值为空。
- retval:表示帧捕获是否成功,如果成功,retval为True,失败为False。
VideoCapture.get()
功能:一个视频有很多属性,比如:帧率、总帧数、尺寸、格式等,VideoCapture的get方法可以获取这些属性。
如果查询的视频属性是VideoCapture类不支持的,将会返回0
参数 | 对应宏 | 说明 |
VideoCapture.get(0) | CV_CAP_PROP_POS_MSEC | 视频文件的当前位置(播放)以毫秒为单位 |
VideoCapture.get(1) | CV_CAP_PROP_POS_FRAMES | 基于以0开始的被捕获或解码的帧索引 |
VideoCapture.get(2) | CV_CAP_PROP_POS_AVI_RATIO | 视频文件的相对位置(播放):0=电影开始,1=影片的结尾 |
VideoCapture.get(3) | CV_CAP_PROP_FRAME_WIDTH | 在视频流的帧的宽度 |
VideoCapture.get(4) | CV_CAP_PROP_FRAME_HEIGHT | 在视频流的帧的高度 |
VideoCapture.get(5) | CV_CAP_PROP_FPS | 帧速率/帧数/fps |
VideoCapture.get(6) | CV_CAP_PROP_FOURCC | 编解码的4字-字符代码 |
VideoCapture.get(7) | CV_CAP_PROP_FRAME_COUNT | 视频文件中的帧数 |
VideoCapture.get(8) | CV_CAP_PROP_FORMAT | 返回对象的格式 |
VideoCapture.get(9) | CV_CAP_PROP_MODE | 返回后端特定的值,该值指示当前捕获模式 |
VideoCapture.get(10) | CV_CAP_PROP_BRIGHTNESS | 图像的亮度(仅适用于照相机) |
VideoCapture.get(11) | CV_CAP_PROP_CONTRAST | 图像的对比度(仅适用于照相机) |
VideoCapture.get(12) | CV_CAP_PROP_SATURATION | 图像的饱和度(仅适用于照相机) |
VideoCapture.get(13) | CV_CAP_PROP_HUE | 色调图像(仅适用于照相机) |
VideoCapture.get(14) | CV_CAP_PROP_GAIN | 图像增益(仅适用于照相机)(Gain在摄影中表示白平衡提升) |
VideoCapture.get(15) | CV_CAP_PROP_EXPOSURE | 曝光(仅适用于照相机) |
VideoCapture.get(16) | CV_CAP_PROP_CONVERT_RGB | 指示是否应将图像转换为RGB布尔标志 |
VideoCapture.get(17) | CV_CAP_PROP_WHITE_BALANCE | × 暂时不支持 |
VideoCapture.get(18) | CV_CAP_PROP_RECTIFICATION | 立体摄像机的矫正标注(目前只有DC1394 v.2.x后端支持这个功能) |
VideoCapture.set()
VideoCapture.set(propertyId,value)
功能:设置VideoCapture类的属性,设置成功返回Ture,失败返回False。
参数:第一个是属性ID,第二个是该属性要设置的值。
example | 作用 |
---|---|
VideoCapture.set(CV_CAP_PROP_FRAME_WIDTH, 1080) | 宽度 |
VideoCapture.set(CV_CAP_PROP_FRAME_HEIGHT, 960) | 高度 |
VideoCapture.set(CV_CAP_PROP_FPS, 30) | 帧率 帧/秒 |
VideoCapture.set(CV_CAP_PROP_BRIGHTNESS, 1) | 亮度 |
VideoCapture.set(CV_CAP_PROP_CONTRAST,40) | 对比度 40 |
VideoCapture.set(CV_CAP_PROP_SATURATION, 50) | 饱和度 50 |
VideoCapture.set(CV_CAP_PROP_HUE, 50) | 色调 50 |
VideoCapture.set(CV_CAP_PROP_EXPOSURE, 50) | 曝光 50 获取摄像头参数 |
参考:
VideoCapture详解_white_156的博客-CSDN博客
opencv视频操作基础---VideoCapture类_洪流之源的博客-CSDN博客
3-6 如何利用OpenCV从摄像头采集视频_哔哩哔哩_bilibili
opencv学习---VideoCapture 类基础知识_hairuiJY的博客-CSDN博客