根据需求,其中有一个点需要调取网络摄像头的画面。我们选择的是萤石CS-C3W这款网络摄像头,参考文档完成了Python通过OpenCV调取视频流
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
import requests #导包
import cv2
login_url="https://open.ys7.com/api/lapp/token/get" #请求地址
url=login_url #拼接地址
#参数
body1={'appKey': 'xxxx',
'appSecret': '自己在控制台创建项目获取',
}
#发送请求
r=requests.post(url=url, params=body1).json()
#输出返回
print(r)
print(r['data']['accessToken'])
live_url="https://open.ys7.com/api/lapp/v2/live/address/get" #请求地址
body2={'accessToken': r['data']['accessToken'],
'deviceSerial': '填写摄像头的序列号',
'protocol': 2,
}
r=requests.post(url=live_url, params=body2).json()
#输出返回
print(r)
print(r['data']['url'])
cap = cv2.VideoCapture(r['data']['url'])
fps = cap.get(cv2.CAP_PROP_FPS)
print(fps)
# 获取cap视频流的每帧像素大小
size = (int(cap.get(cv2.CAP_PROP_FRAME_WIDTH)),
int(cap.get(cv2.CAP_PROP_FRAME_HEIGHT)))
print(size)
# 定义编码格式mpge-4
fourcc = cv2.VideoWriter_fourcc('M', 'P', '4', '2')
# 定义视频文件输入对象
outVideo = cv2.VideoWriter('saveDir.avi', fourcc, fps, size) #size必须和视频流的帧大小一致,否则无法执行
# 获取视频流打开状态
if cap.isOpened():
rval, frame = cap.read()
print('ture')
else:
rval = False
print('False')
tot = 1
c = 1
# 循环使用cv2的read()方法读取视频帧
while rval:
rval, frame = cap.read()
frame = cv2.resize(frame, (400, 300)) #调整画面大小
cv2.imshow('test', frame)
# 使用VideoWriter类中的write(frame)方法,将图像帧写入视频文件
outVideo.write(frame)
cv2.waitKey(25)
cap.release()
outVideo.release()
cv2.destroyAllWindows()