目标
• 学会读取视频文件,显示视频,保存视频文件
• 学会从摄像头获取并显示视频
• 你将会学习到这些函数:cv2.VideoCapture(),cv2.VideoWrite()
5.1 用摄像头捕获视频
我们经常需要使用摄像头捕获实时图像。OpenCV 为这中应用提供了一个
非常简单的接口。让我们使用摄像头来捕获一段视频,并把它转换成灰度视频
显示出来。从这个简单的任务开始吧。
为了获取视频,你应该创建一个VideoCapture 对象。他的参数可以是
设备的索引号,或者是一个视频文件。设备索引号就是在指定要使用的摄像头。
一般的笔记本电脑都有内置摄像头。所以参数就是0。你可以通过设置成1 或
者其他的来选择别的摄像头。之后,你就可以一帧一帧的捕获视频了。但是最
后,别忘了停止捕获视频。
1 # -*- coding: utf-8 -*-
2 """
3 Created on Fri Jan 3 21:06:22 2014
4
5 @author: duan
6 """
7
8 import numpy as np
9 import cv2
10
11 cap = cv2.VideoCapture(0)
12
13 while(True):
14 # Capture frame-by-frame
15 ret, frame = cap.read()
16
17 # Our operations on the frame come here
18 gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
19
20 # Display the resulting frame
21 cv2.imshow('frame',gray)
22 if cv2.waitKey(1) & 0xFF == ord('q'):
23 break
24
25 # When everything done, release the capture
26 cap.release()
27 cv2.destroyAllWindows()
cap.read() 返回一个布尔值(True/False)。如果帧读取的是正确的,
就是True。所以最后你可以通过检查他的返回值来查看视频文件是否已经到
了结尾。
有时cap 可能不能成功的初始化摄像头设备。这种情况下上面的代码会报
错。你可以使用cap.isOpened(),来检查是否成功初始化了。如果返回值是
True,那就没有问题。否则就要使用函数cap.open()。
你可以使用函数cap.get(propId) 来获得视频的一些参数信息。这里
propId 可以是0 到18 之间的任何整数。每一个数代表视频的一个属性,见
下表
其中的一些值可以使用cap.set(propId,value) 来修改,value 就是
你想要设置成的新值。
例如,我可以使用cap.get(3) 和cap.get(4) 来查看每一帧的宽和高。
默认情况下得到的值是640X480。但是我可以使用ret=cap.set(3,320)
和ret=cap.set(4,240) 来把宽和高改成320X240。
注意:当你的程序报错时,你首先应该检查的是你的摄像头是否能够在其他程
序中正常工作(比如linux 下的Cheese)。
从文件中播放视频
与从摄像头中捕获一样,你只需要把设备索引号改成视频文件的名字。在
播放每一帧时,使用cv2.waiKey() 设置适当的持续时间。如果设置的太低视
频就会播放的非常快,如果设置的太高就会播放的很慢(你可以使用这种方法
控制视频的播放速度)。通常情况下25 毫秒就可以了。
1 # -*- coding: utf-8 -*-
2 """
3 Created on Fri Jan 3 21:06:22 2014
4
5 @author: duan
6 """
7
8 import numpy as np
9 import cv2
10
11 cap = cv2.VideoCapture(0)
12
13 # Define the codec and create VideoWriter object
14 fourcc = cv2.VideoWriter_fourcc(*'XVID')
15 out = cv2.VideoWriter('output.avi',fourcc, 20.0, (640,480))
16
17 while(cap.isOpened()):
18 ret, frame = cap.read()
19 if ret==True:
20 frame = cv2.flip(frame,0)
21
22 # write the flipped frame
23 out.write(frame)
24
25 cv2.imshow('frame',frame)
26 if cv2.waitKey(1) & 0xFF == ord('q'):
27 break
28 else:
29 break
30
31 # Release everything if job is finished
32 cap.release()
33 out.release()
34 cv2.destroyAllWindows()
注意:你应该确保你已经装了合适版本的ffmpeg 或者gstreamer。如果你装
错了那就比较头疼了
保存视频
在我们捕获视频,并对每一帧都进行加工之后我们想要保存这个视频。对
于图片来时很简单只需要使用cv2.imwrite()。但对于视频来说就要多做点工
作。
这次我们要创建一个VideoWriter 的对象。我们应该确定一个输出文件
的名字。接下来指定FourCC 编码(下面会介绍)。播放频率和帧的大小也都
需要确定。最后一个是isColor 标签。如果是True,每一帧就是彩色图,否
则就是灰度图。
FourCC 就是一个4 字节码,用来确定视频的编码格式。可用的编码列表
可以从fourcc.org查到。这是平台依赖的。下面这些编码器对我来说是有用个。
• In Fedora: DIVX, XVID, MJPG, X264, WMV1, WMV2. (XVID is
more preferable. MJPG results in high size video. X264 gives
very small size video)
• In Windows: DIVX (More to be tested and added)
• In OSX : (I don’t have access to OSX. Can some one fill this?)
FourCC 码以下面的格式传给程序,以MJPG 为例:
cv2.cv.FOURCC('M','J','P','G') 或者cv2.cv.FOURCC(*'MJPG')。
下面的代码是从摄像头中捕获视频,沿水平方向旋转每一帧并保存它。
1 # -*- coding: utf-8 -*-
2 """
3 Created on Fri Jan 3 21:06:22 2014
4
5 @author: duan
6 """
7
8 import numpy as np
9 import cv2
10
11 cap = cv2.VideoCapture(0)
12
13 # Define the codec and create VideoWriter object
14 fourcc = cv2.cv.FOURCC(*'XVID')
15 out = cv2.VideoWriter('output.avi',fourcc, 20.0, (640,480))
16
17 while(cap.isOpened()):
18 ret, frame = cap.read()
19 if ret==True:
20 frame = cv2.flip(frame,0)
21
22 # write the flipped frame
23 out.write(frame)
24
25 cv2.imshow('frame',frame)
26 if cv2.waitKey(1) & 0xFF == ord('q'):
27 break
28 else:
29 break
30
31 # Release everything if job is finished
32 cap.release()
33 out.release()
34 cv2.destroyAllWindows()