opencv-python 视频读取: VideoCapture.get()参数详解

视频读取demo

python 复制代码
import cv2
from tqdm import tqdm


videoCapture = cv2.VideoCapture(video_path)
if not videoCapture.isOpened():  # 若视频文件读取失败,读取下一段视频
    print('视频打开失败!!!')
    print(video_path)
    return False
total_frames = int(videoCapture.get(cv2.CAP_PROP_FRAME_COUNT))  # 获取视频总帧数
# fourcc = int(videoCapture.get(cv2.CAP_PROP_FOURCC))  # 原生不支持h264编码
fps = videoCapture.get(cv2.CAP_PROP_FPS)  # 获取视频帧率
w = int(videoCapture.get(cv2.CAP_PROP_FRAME_WIDTH))  # 获取图像宽度
h = int(videoCapture.get(cv2.CAP_PROP_FRAME_HEIGHT))  # 获取图像高度

pbar = tqdm(total=total_frames)  # 进度条显示
while total_frames:
    success, curr = videoCapture.read()
    if success:
        cv2.imshow('frame', curr)
        # cv2.waitKey(0)=='q'

VideoCapture.get()参数

整理了get()函数各个参数的参数值和说明,方便查阅。

参数 对应宏 说明
VideoCapture.get(0) cv2.CAP_PROP_POS_MSEC 视频文件的当前位置(播放)以毫秒为单位
VideoCapture.get(1) cv2.CAP_PROP_POS_FRAMES 基于以0开始的被捕获或解码的帧索引
VideoCapture.get(2) cv2.CAP_PROP_POS_AVI_RATIO 视频文件的相对位置(播放):0=电影开始,1=影片的结尾
VideoCapture.get(3) cv2.CAP_PROP_FRAME_WIDTH 在视频流的帧的宽度
VideoCapture.get(4) CV_CAP_PROP_FRAME_HEIGHT 在视频流的帧的高度
VideoCapture.get(5) cv2.CAP_PROP_FPS 帧速率/帧数/fps
VideoCapture.get(6) cv2.CAP_PROP_FOURCC 编解码的4字-字符代码
VideoCapture.get(7) cv2.CAP_PROP_FRAME_COUNT 视频文件中的帧数
VideoCapture.get(8) cv2.CAP_PROP_FORMAT 返回对象的格式
VideoCapture.get(9) cv2.CAP_PROP_MODE 返回后端特定的值,该值指示当前捕获模式
VideoCapture.get(10) cv2.CAP_PROP_BRIGHTNESS 图像的亮度(仅适用于照相机)
VideoCapture.get(11) cv2.CAP_PROP_CONTRAST 图像的对比度(仅适用于照相机)
VideoCapture.get(12) cv2.CAP_PROP_SATURATION 图像的饱和度(仅适用于照相机)
VideoCapture.get(13) cv2.CAP_PROP_HUE 色调图像(仅适用于照相机)
VideoCapture.get(14) cv2.CAP_PROP_GAIN 图像增益(仅适用于照相机)(Gain在摄影中表示白平衡提升)
VideoCapture.get(15) cv2.CAP_PROP_EXPOSURE 曝光(仅适用于照相机)
VideoCapture.get(16) cv2.CAP_PROP_CONVERT_RGB 指示是否应将图像转换为RGB布尔标志
VideoCapture.get(17) cv2.CAP_PROP_WHITE_BALANCE × 暂时不支持
VideoCapture.get(18) cv2.CAP_PROP_RECTIFICATION 立体摄像机的矫正标注(目前只有DC1394 v.2.x后端支持这个功能)
相关推荐
珂朵莉MM27 分钟前
2024 睿抗机器人开发者大赛CAIP-编程技能赛-专科组(国赛)解题报告 | 珂学家
开发语言·人工智能·算法·leetcode·职场和发展·深度优先·图论
ㄣ知冷煖★42 分钟前
【论文阅读】A Survey on Multimodal Large Language Models
人工智能·语言模型·自然语言处理
视觉语言导航1 小时前
兼顾长、短视频任务的无人机具身理解!AirVista-II:面向动态场景语义理解的无人机具身智能体系统
人工智能·无人机·具身智能
墨绿色的摆渡人2 小时前
pytorch小记(二十二):全面解读 PyTorch 的 `torch.cumprod`——累积乘积详解与实战示例
人工智能·pytorch·python
moonsims2 小时前
低空态势感知:基于AI的DAA技术是低空飞行的重要安全保障-机载端&地面端
人工智能·安全
若叶时代2 小时前
数据分析_Python
人工智能·python·数据分析
虾球xz2 小时前
游戏引擎学习第286天:开始解耦实体行为
c++·人工智能·学习·游戏引擎
武子康2 小时前
大语言模型 11 - 从0开始训练GPT 0.25B参数量 MiniMind2 准备数据与训练模型 DPO直接偏好优化
人工智能·gpt·ai·语言模型·自然语言处理
羽凌寒3 小时前
图像对比度调整(局域拉普拉斯滤波)
人工智能·计算机视觉
大模型铲屎官3 小时前
【Python-Day 14】玩转Python字典(上篇):从零开始学习创建、访问与操作
开发语言·人工智能·pytorch·python·深度学习·大模型·字典