计算机视觉cv2入门之视频处理

        在我们进行计算机视觉任务时,经常会对视频中的图像进行操作,这里我来给大家分享一下,cv2对视频文件的操作方法。这里我们主要介绍cv2.VideoCapture函数的基本使用方法。

cv2.VideoCapture函数

当我们在使用cv2.VideoCapture函数时,我们通常使用轮询的方式,即:

while True:if condition1:do somethingif condition2:break...

更一般化的是 

import cv2
#这里是获取实时视频源,如果是读取已有视频文件cap=cv2.VideoCapture(filename='')
cap=cv2.VideoCapture(index=0)
if cap.isOpened():while True:ret,frame=cap.read()#...#... 针对视频中的每一帧图像的其他操作#....if not ret:breakcv2.imshow('test',frame)key=cv2.waitKey(1)if key==27:#置顶一个按键来结束循环,这里使用esc健的ASCII码breakcap.release()cv2.destroyAllWindows()
else:print('摄像头未打开')

初始化

        视频文件

        如果你需要处理的是已有的视频文件,而不是打开摄像头捕获的实时视频流,那么只需要传入filename即可。apiPerference是可选参数主要用来指定视频捕获的后端,即使用哪种顶层API来读取视频流或摄像头,默认值是cv2.CAP_ANY由opencv自动选择

import cv2
'''
filename:视频文件路径 .mp4
apiPerference:指定视频捕获的后端(即使用哪种底层API来读取视频流或摄像头)apiPerference参数常用flag:
cv2.CAP_ANY:	自动选择默认后端(OpenCV自行决定)跨平台
cv2.CAP_ANDROID:  使用Android的Camera2 API
cv2.CAP_DSHOW:	使用DirectShow(Windows专用)
cv2.CAP_MSMF:    使用Microsoft Media Foundation(Windows 10+)
cv2.CAP_V4L2:    使用Video4Linux2(Linux专用)Linux
cv2.CAP_FFMPEG:	 使用FFmpeg解码视频文件跨平台(需安装 FFmpeg)
cv2.CAP_GSTREAMER:	使用 GStreamer(Linux常用)
cv2.CAP_OPENNI:	用于深度摄像头(如Kinect)特定设备
'''
cap=cv2.VideoCapture(r'test.mp4')

实时视频流 

        如果你处理的是实时视频流,那么需要设置index参数,不使用外接设备时index一般都设置为apiPerference是可选参数主要用来指定视频捕获的后端,即使用哪种顶层API来读取视频流或摄像头,默认值是cv2.CAP_ANY由opencv自动选择

import cv2
'''
index:0或1,0是电脑内置摄像头,1是外接摄像头,没有外接摄像头仍然设置Index=1的话不会报错,只是代码不运行
apiPerference:指定视频捕获的后端(即使用哪种底层API来读取视频流或摄像头)apiPerference参数常用flag:
cv2.CAP_ANY:	自动选择默认后端(OpenCV自行决定)跨平台
cv2.CAP_ANDROID:  使用Android的Camera2 API
cv2.CAP_DSHOW:	使用DirectShow(Windows专用)
cv2.CAP_MSMF:    使用Microsoft Media Foundation(Windows 10+)
cv2.CAP_V4L2:    使用Video4Linux2(Linux专用)Linux
cv2.CAP_FFMPEG:	 使用FFmpeg解码视频文件跨平台(需安装 FFmpeg)
cv2.CAP_GSTREAMER:	使用 GStreamer(Linux常用)
cv2.CAP_OPENNI:	用于深度摄像头(如Kinect)特定设备
'''
cap=cv2.VideoCapture(index=1,apiPreference=cv2.CAP_ANY)

 常用属性

cap.isOpened()

检查视频源是否打开,返回值为True 或False

import cv2
cap=cv2.VideoCapture(index=0,apiPreference=cv2.CAP_MSMF)
if cap.isOpened():print('摄像头已打开')while True:ret,frame=cap.read()cv2.imshow('test',frame)key=cv2.waitKey(1)if key==27:#按下esc健退出breakcap.release()cv2.destroyAllWindows()
else:print('摄像头未打开')

cap.read() 

        用来读取视频中的下一帧,返回值为(ret,frame) ret为是否成功,frame为图像数据

        cap.read()是我们处理视频文件中最关键的函数,如果没有这一步,那么根本无法处理视频文件中的图像。

import cv2
cap=cv2.VideoCapture(index=0,apiPreference=cv2.CAP_MSMF)
if cap.isOpened():print('摄像头已打开')while True:ret,frame=cap.read()if not ret:breakcv2.imshow('test',frame)key=cv2.waitKey(1)if key==27:#按下esc健退出breakcap.release()cv2.destroyAllWindows()
else:print('摄像头未打开')

cap.release() 

        用来释放视频源,出现在cv2.destroyAllWindows()前。

import cv2
#这里是获取实时视频源,如果是读取已有视频文件cap=cv2.VideoCapture(filename='')
cap=cv2.VideoCapture(index=0)
if cap.isOpened():while True:ret,frame=cap.read()#...#...#....cv2.imshow('test',frame)key=cv2.waitKey(1)if key==27:#设定一个按键来结束循环,这里使用esc健的ASCII码breakcap.release()cv2.destroyAllWindows()
else:print('摄像头未打开')

视频属性控制 

 cap.get(propId)

         用来获取当前视频的属性值,比如帧宽,高,FPS等。

        这里我们以获取当前帧率并标记在窗口内为例:

fps=cv2.get(cv2.CAP_PROP_FPS)

        fps的类型为Float

import cv2
#这里是获取实时视频源,如果是读取已有视频文件cap=cv2.VideoCapture(filename='')
cap=cv2.VideoCapture(index=0)
if cap.isOpened():while True:ret,frame=cap.read()fps=cap.get(cv2.CAP_PROP_FPS)#...#...#....cv2.putText(img=frame,text=f'fps:{fps}',org=(50,50),fontFace=1,fontScale=3,color=(255,0,0))cv2.imshow('test',frame)key=cv2.waitKey(1)if key==27:#设定一个按键来结束循环关闭摄像头,这里使用esc健的ASCII码breakcap.release()cv2.destroyAllWindows()
else:print('摄像头未打开')

最后,我将所有的本文所有的要点都总结在了下方这个表格里。

参数/方法​​说明​
​初始化​
cap=cv2.VideoCapture()创建视频捕获对象,参数可以是设备索引(摄像头)或视频文件路径。
​常用属性​
cap.isOpened()检查视频源是否成功打开,返回 True/False
cap.read()读取下一帧,返回 (ret, frame)ret 为是否成功,frame 为图像数据。
cap.release()释放视频源。
​视频属性控制​
cap.get(propId)获取视频属性值(如帧宽、高、FPS 等),propId 为属性标识。
cap.set(propId, value)设置视频属性值(部分属性可修改)。
​常用属性标识(propId)​
cv2.CAP_PROP_FRAME_WIDTH帧的宽度(像素)。
cv2.CAP_PROP_FRAME_HEIGHT帧的高度(像素)。
cv2.CAP_PROP_FPS视频的帧率(Frames Per Second)。
cv2.CAP_PROP_FRAME_COUNT视频的总帧数(仅对文件有效)。
cv2.CAP_PROP_POS_MSEC当前帧的时间戳(毫秒,仅对文件有效)。
cv2.CAP_PROP_POS_FRAMES当前帧的索引(从 0 开始)。
​其他方法​
cap.grab()快速抓取下一帧(不解码),通常与 cap.retrieve() 配合使用。
cap.retrieve()解码并返回由 grab() 抓取的帧。
cap.getBackendName()返回当前使用的后端名称(如 FFMPEGDSHOW)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/902563.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux之彻底掌握防火墙-----安全管理详解

—— 小 峰 编 程 目录: 一、防火墙作用 二、防火墙分类 1、逻辑上划分:大体分为 主机防火墙 和 网络防火墙 2、物理上划分: 硬件防火墙 和 软件防火墙 三、硬件防火墙 四、软件防火墙 五、iptables 1、iptables的介绍 2、netfilter/…

python项目实战-后端个人博客系统

本文分享一个基于 Flask 框架开发的个人博客系统后端项目,涵盖用户注册登录、文章发布、分类管理、评论功能等核心模块。适合初学者学习和中小型博客系统开发。 一、项目结构 blog │ app.py │ forms.py │ models.py │ ├───instance │ blog.d…

Unity 接入阿里的全模态大模型Qwen2.5-Omni

1 参考 根据B站up主阴沉的怪咖 开源的项目的基础上修改接入 AI二次元老婆开源项目地址(unity-AI-Chat-Toolkit): Github地址:https://github.com/zhangliwei7758/unity-AI-Chat-Toolkit Gitee地址:https://gitee.com/DammonSpace/unity-ai-chat-too…

第十五届蓝桥杯 2024 C/C++组 合法密码

目录 题目: 题目描述: 题目链接: 思路: substr函数: 思路详解: 代码: 代码详解; 题目: 题目描述: 题目链接: P10906 [蓝桥杯 2024 国 B] 合法密码 -…

NoSQL 简单讲解

目录 1. NoSQL 的背景与意义 1.1 数据库的演变 1.2 NoSQL 的兴起 2. NoSQL 数据库的分类 2.1 键值存储(Key-Value Stores) 2.2 文档数据库(Document Stores) 2.3 列族存储(Column-Family Stores) 2.…

122.在 Vue3 中使用 OpenLayers 实现图层层级控制(zIndex)显示与设置详解

📅 作者:彭麒 📫 邮箱:1062470959@qq.com 📌 声明:本文源码归吉檀迦俐所有,欢迎学习借鉴,如用于商业项目请注明出处 🙌 🔧 技术栈:Vue 3 + Composition API + OpenLayers 6+ + Element Plus + Tailwind CSS 🧠 一、什么是 zIndex(图层层级)? 在地图开发中…

车载测试用例开发-如何平衡用例覆盖度和测试效率的方法论

1 摘要 在进行车载测试用例编写时,会遇到多个条件导致用例排列组合爆炸的情况,但是为了产品测试质量,我们又不得不保证用例设计的需求覆盖度,这样又会使得测试周期非常长。我们如何平衡效率和测试质量?本文进行了一些…

AI——神经网络以及TensorFlow使用

文章目录 一、TensorFlow安装二、张量、变量及其操作1、张量Tensor2、变量 三、tf.keras介绍1、使用tf.keras构建我们的模型2、激活函数1、sigmoid/logistics函数2、tanh函数3、RELU函数4、LeakReLu5、SoftMax6、如何选择激活函数 3、参数初始化1、bias偏置初始化2、weight权重…

Kubernetes (k8s) 日常运维命令总结

一、资源查看 查看所有命名空间的 Pod kubectl get pod --all-namespaces查看指定命名空间的 Pod kubectl get pod --namespace <命名空间>查看所有部署&#xff08;Deployments&#xff09; kubectl get deployments.apps --all-namespaces查看所有守护进程集&#xff0…

【PostgreSQL教程】PostgreSQL 特别篇之 语言接口连接Perl

博主介绍:✌全网粉丝22W+,CSDN博客专家、Java领域优质创作者,掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域✌ 技术范围:SpringBoot、SpringCloud、Vue、SSM、HTML、Nodejs、Python、MySQL、PostgreSQL、大数据、物联网、机器学习等设计与开发。 感兴趣的可…

07-IDEA企业开发工具-开发入门程序

1. IDEA创建Java项目的代码结构 项目结构: IDEA中的Java项目包含四种主要结构&#xff1a;工程(Project)、模块(Module)、包(Package)、类(Class)。 工程(Project): 代表整个项目&#xff0c;通常是一个磁盘目录或文件夹。模块(Module): 工程下的子单元&#xff0c;用于划分项…

深度解析云计算:概念、优势与分类全览

以下是对云计算概念、优点和分类更详细的介绍&#xff1a; 一、云计算的概念 云计算是一种通过互联网提供计算服务的模式&#xff0c;它基于虚拟化、分布式计算、网络存储等一系列先进技术&#xff0c;将计算资源进行整合和管理&#xff0c;形成一个庞大的资源池。这些资源包…

高并发系统的通用设计方法是什么?

背景 高并发系统的通用设计方法是解决系统在面对大量用户访问时的性能瓶颈问题。当系统遇到性能瓶颈时&#xff0c;通常是因为某个单点资源&#xff08;如数据库、后端云服务器、网络带宽等&#xff09;达到了极限。 为了提升整个系统的容量&#xff0c;需要找到这个瓶颈资源…

【手机】vivo手机应用声音分离方案

文章目录 前言方案 前言 尝试分离vivo手机音乐与其他应用的声音 方案 最佳方案&#xff1a;网易云音乐设置内关闭音量均衡 上传不同的白噪音&#xff0c;成功 goodlock&#xff0c;主要适用于三星手机&#xff0c;vivo不一定适用 app volume control &#xff0c;可行

一个报错说函数为私有函数

你遇到的警告信息&#xff1a; warning: declaration of struct Zero2TenVDrv will not be visible outside of this function [-Wvisibility]这是编译器提示你在某个函数内部声明了一个结构体 struct Zero2TenVDrv&#xff0c;但这个结构体的声明作用域仅限于该函数内部&…

3.2 Agent核心能力:感知、规划、决策与执行

智能代理&#xff08;Agent&#xff09;是一种能够在复杂环境中自主运作的计算实体&#xff0c;其智能行为依赖于四大核心能力&#xff1a;感知&#xff08;Perception&#xff09;、规划&#xff08;Planning&#xff09;、决策&#xff08;Decision-making&#xff09;和执行…

图解Mysql原理:深入理解事务的特性以及它的实现机制

前言 大家好&#xff0c;我是程序蛇玩编程。 Mysql中事务大家不陌生吧&#xff0c;事务就是要保证一组数据库操作&#xff0c;要么全部成功&#xff0c;要么全部失败。那它具有哪些特性&#xff0c;如何实现的呢?接着往下看。 正文 事务的特性: 事务的基本特性主要为四种…

进行网页开发时,怎样把function()中变量值在控制台输出,查看?

在网页开发过程中&#xff0c;为了及时了解JavaScript中的function函数中的变量值&#xff0c;可以用控制台命令console.log()把变量的值在控制台输出&#xff0c;方便调试时对函数变量值进行了解。 看下面的一段示例&#xff1a; <!DOCTYPE html> <html> &l…

linux内核进程管理(1)——创建,退出

linux源码阅读——进程管理&#xff08;1&#xff09; 1. 进程的基本介绍1.1 linux中进程和线程的区别1.2 task_struct中的基本内容1.3 命名空间ns(namespace)命名空间结构图Linux 中的命名空间类型 1.4 进程标识符 2. 创建一个进程的流程2.1 CLONE宏2.2 创建进程系统调用1. do…

人像面部关键点检测

此工作为本人近期做人脸情绪识别&#xff0c;CBAM模块前是否能加人脸关键点检测而做的尝试。由于创新点不是在于检测点的标注&#xff0c;而是CBAM的改进&#xff0c;因此&#xff0c;只是借用了现成库Dilb与cv2进行。 首先&#xff0c;下载人脸关键点预测模型:Index of /file…