【计算机视觉(2)】

基于Python的OpenCV基础入门------视频的处理

视频

视频是由一系列连续的图像帧组成的。每一帧都是视频中的一张静止图像,它们以非常快的速度连续播放,给人一种连续运动的感觉。视频的帧率指的是每秒钟播放的帧数,常见的帧率有24帧/秒、30帧/秒和60帧/秒等。帧率越高,视频播放越流畅。视频的处理就是通过循环将视频流中的所有的帧进行处理

OpenCV视频处理操作:

创建视频对象

cap = cv2.VideoCapture(value)

参数:

设备索引或者一个视频文件名。摄像头读取则是设备索引,0为默认摄像头;视频文件读取则为filename

判断视频是否成功初始化

ret = cap.isOpened()

返回值:

ret :bool类型,成功则为True,否则为False。

读取视频帧

ret, frame = video.read()

返回值:

ret:bool类型,判断是否读取到帧,成功为True,否则为False。

frame:读取到的帧

获取视频特征

cap.get(propId)

参数:

propId : 0 到 18 之间的整数。每一个数代表视频的一个属性,在这里仅举几个常用的参数:

int 属性 propld
0 视频文件的当前位置(毫秒) CV_CAP_PROP_POS_FRAMES
1 下一步要解码/捕获的帧的基于0的索引 CV_CAP_PROP_POS_AVI_RATIO
3 视频流中帧的宽度 CV_CAP_PROP_FRAME_HEIGHT
4 视频流中帧的高度 CV_CAP_PROP_FPS
5 帧率 CV_CAP_PROP_FOURCC

设置视频参数

cap.set(propId, value)

参数:

propId : 0 到 18 之间的整数

value:设置的新值

声明编码器

fourcc = cv2.VideoWriter_fourcc('M', 'P', '4', 'V' ) , FourCC 是用于指定视频解码器的 4 字节代码。

参数 说明
'M', 'P', '4', 'V' MPEG-4编码类型,文件扩展名为 .mp4
'X','2','6','4' MPEG-4编码类型,文件扩展名为.mp4
'P','I','M','I' MPEG-1编码类型,文件扩展名为.avi
'X', 'V', 'I', 'D' MPEG-4编码类型,文件扩展名为.avi
'I', '4', '2', '0' YUV编码类型,文件扩展名为avi

保存视频

out = cv2.VideoWriter(filename,fourcc, fps, frameSize)

参数:

filename:视频保存的位置

fourcc:指定视频编解码器的4字节代码

fps:帧率

frameSize:帧大小

释放视频对象

capture.release(),释放视频对象是必要的清理操作

视频处理基本操作的代码实现:

import cv2

cap = cv2.VideoCapture('img/1.mp4')

while(cap.isOpened()):
    ret, frame = cap.read()
    if ret == True:
        cv2.imshow('frame', frame)
        if cv2.waitKey(1) & 0xFF == ord('q'):
            break
    else:
        break

实现效果如下图:

相关推荐
Elastic 中国社区官方博客11 分钟前
使用 Vertex AI Gemini 模型和 Elasticsearch Playground 快速创建 RAG 应用程序
大数据·人工智能·elasticsearch·搜索引擎·全文检索
电饭叔23 分钟前
《python语言程序设计》2018版第8章19题几何Rectangle2D类(下)-头疼的几何和数学
开发语言·python
说私域36 分钟前
地理定位营销与开源AI智能名片O2O商城小程序的融合与发展
人工智能·小程序
alfiy44 分钟前
Elasticsearch学习笔记(四) Elasticsearch集群安全配置一
笔记·学习·elasticsearch
向上的车轮1 小时前
Django学习笔记十一:部署程序
笔记·学习·django
Q_w77421 小时前
计算机视觉小目标检测模型
人工智能·目标检测·计算机视觉
程序猿小D1 小时前
第二百六十七节 JPA教程 - JPA查询AND条件示例
java·开发语言·前端·数据库·windows·python·jpa
创意锦囊1 小时前
ChatGPT推出Canvas功能
人工智能·chatgpt
知来者逆1 小时前
V3D——从单一图像生成 3D 物体
人工智能·计算机视觉·3d·图像生成
alfiy2 小时前
Elasticsearch学习笔记(五)Elastic stack安全配置二
笔记·学习·elasticsearch