opencv实现视频的读取并且一帧一帧的显示出来

在进行视频的读取的时候视频的额来源可以是现有的视频文件,还可以是直接在设备上进行读取文件
当让cap=cv2.VideoCapture(0),的时候就是默认使用电脑上自带的设备即笔记本的摄像头

**#-*- coding utf-8 -*-
import cv2
import numpy as np
import matplotlib.pyplot as plt


cap=cv2.VideoCapture('rm.rmvb')
while(True):
    ret,frame=cap.read()
    gray=cv2.cvtColor(frame,cv2.COLOR_BGR2GRAY)
    cv2.imshow('frame',gray)
    if cv2.waitKey(1)&0xFF==ord('q'):
        break

cap.release()
cv2.destroyAllWidows()
**

**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。**

你可能感兴趣的:(python)