OpenCV入门学习笔记图片与视频基本操作

Posted min_count

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了OpenCV入门学习笔记图片与视频基本操作相关的知识,希望对你有一定的参考价值。

  • namedWindow(winname,flags)

cv2.nameWindow(winname,flags) ##为窗口命名

解释:第一个参数为新建窗口的名字,第二个参数为flag值,flag可取值如下,

WINDOW_AUTOSIZE :窗口会自动适应图片大小
WINDOW_NORMAL :用户可以改变窗口大小
WINDOW_OPENGL

注:flag默认为 WINDOW_AUTOSIZE

  • resizeWindow(window_name, width, height)

cv2.resizeWindow(window_name, width, height)##设置窗口大小

解释:第一个参数为新建窗口的名字,第二个参数为窗口宽度,第三个参数为窗口高度。

  • imshow(winname, mat)

cv2.imshow(winname, mat)##显示图片

解释:第一个参数为新建窗口的名字,第二个参数为要显示的图像。

注:使用imshow要使用waitKey函数,不然会一闪而过。

  • waitKey()

key = cv2.waitKey (delay)##等待键盘输入

解释:其参数为延时值,若为0则等待任意键盘输入才会返回,若值大于0则为延时值。

注:默认为0

  • destoryAllWindows()

cv2.destoryAllWindows()##关闭所有窗口

  • imread

cv2.imread( filename, flags )##读取图片

解释:第一个参数为读取文件的名字,第二个参数为flag值,flag可取值如下,

flags = -1:imread按解码得到的方式读入图像
flags = 0:imread按单通道的方式读入图像,即灰白图像
flags = 1:imread按三通道方式读入图像,即彩色图像

  • imwrite

cv2.imwrite(path,img)##保存图片

解释:第一个参数为保存的路径,第二个参数为保存的图片。

  • VideoCapture

cap = cv2.VideoCapture(device) ##读取摄像头设备的视频,或读取某路径的视频

解释:其参数为设备号或为视频路径

  • read()

ret,frame = cap.read()##读取一帧数据

解释:返回的第一个参数为ret,若为ture则读到数据,反之则未读到数据。第二个参数为frame,是这一帧数据。

  • release()

cap.release()##释放资源

  • isOpened()

cap.isOpened()##判断摄像头是否打开

  • VideoWriter_fourcc()

fourcc = cv2.VideoWriter_fourcc(*‘mp4v’)##设置保存视频的格式为mp4

  • VideoWriter

vw = cv2.VideoWriter(‘output.mp4’,fourcc,20,(1280,720))

解释:第一个参数为存储的路径,第二个参数为编码器,第三个参数为要保存视屏的帧率,第四个参数为要保存文件的画面尺寸。

注:若画面尺寸不对,会导致保存的文件损坏,macos为(1280,720)

  • write(frame)

vw.write(frame)##将某一帧写入要保存的文件中

解释:frame为前面cap.read()返回的一帧的数据。

  • release()

vw.release()##释放资源

OpenCV | 图片与视频的相互转换(C++&Python)

七月 上海| 高性能计算之GPU CUDA培训

7月27-29日
三天密集式学习  快速带你入门
>


正文共1338个字,预计阅读时间6分钟。


前言


在学习opencv的过程中,终会遇到需要把视频转换成图片处理,或者把处理后的图片保存为视频格式的时候。这篇文章中就来看一下如何进行图片和视频之间的相互转换。


视频转图片


对于这种情况大家应该很熟悉了。因为学习opencv的时候肯定打开过摄像头,比如打开摄像头检测个人脸或者笑脸之类的。在这个过程中,实际就是把摄像头拍摄到的视频转换为一帧一帧的图片连续地进行处理。


我们知道,对于打开视频和摄像头,opencv提供了VideoCapture类,可以方便地通过流操作符>>与Mat类进行交互。这种情况比较常见,我们直接看例子。

 1#include<opencv2\opencv.hpp>
2using namespace cv;
3int main()
4
{
5//打开默认摄像头
6VideoCapture cap(0)
7if (!cap.isOpened())
8{
9return -1;
10}
11Mat frame;
12// 按Q键退出时,键盘需要调为英文模式
13while(waitKey(30) != 'q')
14{
15// 通过流操作符把视频转化为一帧帧图片
16cap >> frame;
17// Do something here !
18imshow("video", frame);
19}
20return 0;
21}


如果是要打开视频文件而不是摄像头,只需要像下面这样:


1VideoCapture cap("E:\\我的视频\\视频.mp4");


而视频转成图片也就是那么简单的一句cap >> frame;


图片转视频


视频转图片只需要流操作符简单的一句代码就能实现,那么图片转视频呢?是不是也是这么简单?


答案是肯定的。也是只需要用一句这么简单的代码,而且只需要把流操作符的方向反过来就行了。这时候用到的就是opencv提供的VideoWriter类。VideoCapture和VideoWriter,顾名思义,他俩一个是抓取视频的,一个是写入视频的。


VideoWriter构造函数如下所示:

VideoWriter(const string& filename, int fourcc, double fps, Size frameSize, bool isColor=true)


各参数含义如下:


  • filename: 输出视频文件的名称

  • fourcc:4-character code of codec的缩写,四个字符用来表示压缩帧的编解码。

  • fps:帧率,我猜是frame per second的缩写。

  • frameSize:每帧图片的大小

  • isColor: 如果非零,编码器将希望得到彩色帧并进行编码;否则,是灰度帧(只有在Windows下支持这个标志)


第二个参数,OpenCV提供的格式是未经过压缩的,目前支持的格式如下:


CV_FOURCC('P', 'I', 'M', '1') = MPEG-1 codec

CV_FOURCC('M', 'J', 'P', 'G') = motion-jpeg codec

CV_FOURCC('M', 'P', '4', '2') = MPEG-4.2 codec

CV_FOURCC('D', 'I', 'V', '3') = MPEG-4.3 codec

CV_FOURCC('D', 'I', 'V', 'X') = MPEG-4 codec

CV_FOURCC('U', '2', '6', '3') = H263 codec

CV_FOURCC('I', '2', '6', '3') = H263I codec

CV_FOURCC('F', 'L', 'V', '1') = FLV1 codec


还是用一个例子来看:


 1#include<opencv2\opencv.hpp>
2#include<iostream>
3using namespace std;
4using namespace cv;
5int main()
6
{
7// 构造一个VideoWriter
8VideoWriter video("test.avi", CV_FOURCC('M''J''P''G'), 25.0, Size(640480));
9// 从一个文件夹下读取多张jpg图片
10String pattern = "G:\\temp_picture\\*.jpg";
11vector<String> fn;
12glob(pattern, fn, false);
13size_t count = fn.size();
14for (size_t i = 0; i < count; i++)
15{
16Mat image = imread(fn[i]);
17// 这个大小与VideoWriter构造函数中的大小一致。
18resize(image, image, Size(640480));
19// 流操作符,把图片传入视频
20video << image;
21}
22cout << "处理完毕!" << endl;
23// 处理完之后会在得到一个名为test.avi的视频文件。
24}


Python代码


最后还是给出Python版本的示例代码:


视频转图片


1import cv2
2import numpy 
3cap = cv2.VideoCapture(0)
4while cv2.waitKey(30)!=ord('q'):
5retval, image = cap.read()
6cv2.imshow("video",image)
7cap.release()
图片转视频
1# encoding: UTF-8
2import glob as gb
3import cv2
4img_path = gb.glob("G:\\temp_picture\\*.jpg"
5videoWriter = cv2.VideoWriter('test.mp4',cv2.VideoWriter_fourcc(*'MJPG'), 25, (640,480))
6for path in img_path:
7img  = cv2.imread(path) 
8img = cv2.resize(img,(640,480))
9videoWriter.write(img)


额,虽然Python代码没加注释,但是好像还是理解了什么叫人生苦短,我用Python。


原文链接:https://www.jianshu.com/p/65aa6516baa6


查阅更为简洁方便的分类文章以及最新的课程、产品信息,请移步至全新呈现的“LeadAI学院官网”:

www.leadai.org


大家都在看



以上是关于OpenCV入门学习笔记图片与视频基本操作的主要内容,如果未能解决你的问题,请参考以下文章

OpenCv初学者学习笔记:图像视频的加载与显示

基础学习笔记之opencv:实现将图片生成视频

OpenCV | 图片与视频的相互转换(C++&Python)

opencv 入门 学习笔记

计算机视觉入门

OpenCV3学习笔记整理(一期)