读取视频文件

OpenCV提供了VideoCapture类来支持视频读/写。VideoCapture类通过read()函数来获取每一帧,即一个RGB图像。

本文用到的视频traffic.flv,来源于原作者Github,地址为:
https://github.com/techfort/pycv/tree/master/chapter8/surveillance_demo

——————————————–

OpenCV读取视频并显示

# -*- coding:utf-8 -*-

import cv2

cap = cv2.VideoCapture('video/traffic.flv')

while True:
    ret, frame = cap.read() # 读
    cv2.imshow("capture", frame) # 显示
    if cv2.waitKey(100) & 0xFF == ord('q'): #键盘按键q,退出
        break

视频读取的部分截屏如下:

这里写图片描述

——————————————–

OpenCV写入视频

# -*- coding:utf-8 -*-

import cv2

# Step1. 调用VideoCapture构造器
cap = cv2.VideoCapture('video/traffic.flv')
fps = cap.get(cv2.CAP_PROP_FPS)
size = (int(cap.get(cv2.CAP_PROP_FRAME_WIDTH)), int(cap.get(cv2.CAP_PROP_FRAME_HEIGHT)))

# Step2. 改用YUV颜色编码 写入到另一个视频文件中
# 注意,视频文件的后缀改为.avi,由于I420采用YUV颜色编码,只支持.avi格式
writer = cv2.VideoWriter('video/trafficOutput.avi', cv2.VideoWriter_fourcc('I', '4', '2', '0'), fps, size)
ret, frame = cap.read()
while ret:
    writer.write(frame)
    ret, frame = cap.read()


# Step3.读取新的文件
cap = cv2.VideoCapture('video/trafficOutput.avi')
while True:
    ret, frame = cap.read() # 读
    cv2.imshow("capture", frame) # 显示
    if cv2.waitKey(100) & 0xFF == ord('q'): #键盘按键q,退出
        break

运行程序后,会在生成一个新的文件:trafficOutput.avi

这里写图片描述

今天就学到这里啦~~

这里写图片描述

Logo

AtomGit 是由开放原子开源基金会联合 CSDN 等生态伙伴共同推出的新一代开源与人工智能协作平台。平台坚持“开放、中立、公益”的理念,把代码托管、模型共享、数据集托管、智能体开发体验和算力服务整合在一起,为开发者提供从开发、训练到部署的一站式体验。

更多推荐