我是靠谱客的博主 谦让抽屉,这篇文章主要介绍opencv的视频处理(源码及详细注释),现在分享给大家,希望可以做个参考。

opencv视频操作基础

  • 使用的是opencv中的VideoCapture类,作用是从视频文件或从摄像头捕捉视频并显示出来

1.2-1读取或播放视频

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
 #include<opencv2/opencv.hpp>  using namespace cv;  int main()  {   //读入视频   VideoCapture capture("1.mp4");  //实例化&初始化   //循环显示每一帧   while (1)   {   Mat frame; //定义一个Mat变量,用于储存每一帧的图像   capture >> frame;//读取当前帧   imshow("读取视频", frame);//显示当前帧   waitKey(30);//延时30毫秒   }   return 0;  }
  • 第6行也可以先实例化再初始化,即VideoCapture capture; capture.open("1.mp4");

1.2-2调用摄像头采集图像

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
​  #include<opencv2/opencv.hpp>  using namespace cv;  int main()  {   //读入视频                               ***********************   VideoCapture capture(0); //实例化&初始化 **其实就是这里改成0了**   //循环显示每一帧                           ***********************   while (1)   {   Mat frame; //定义一个Mat变量,用于储存每一帧的图像   capture >> frame;//读取当前帧   imshow("读取视频", frame);//显示当前帧   waitKey(30);//延时30毫秒   }   return 0;  } ​

1.2-3摄像头配合边缘检测

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
 #include<opencv2/opencv.hpp>  using namespace cv;  int main()  {   //读入视频   VideoCapture capture(0);  //实例化&初始化   Mat frame2;   //循环显示每一帧   while (1)   {   Mat frame; //定义一个Mat变量,用于储存每一帧的图像   capture >> frame;//读取当前帧   cvtColor(frame, frame2, COLOR_BGR2GRAY);//将原图像转为灰度图像  ​   blur(frame2, frame2, Size(7, 7));  //使用3*3来降噪(2*3+1 = 7[这句我没懂...])  ​   Canny(frame2, frame2, 0, 30, 3); //运行Canny算子  ​   imshow("边缘检测后的读取视频", frame2);//显示当前帧   if(waitKey(30)>=30)break;//延时30毫秒   }   return 0;  }

纯手敲,整理不易,留个赞再走叭

最后

以上就是谦让抽屉最近收集整理的关于opencv的视频处理(源码及详细注释)的全部内容,更多相关opencv内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(96)

评论列表共有 0 条评论

立即
投稿
返回
顶部