Opencv-python摄像头录制视屏并保存
import cv2 # 导入opencv包
video = cv2.VideoCapture(0) # 打开摄像头
fourcc = cv2.VideoWriter_fourcc(*'XVID') # 视频存储的格式
fps = video.get(cv2.CAP_PROP_FPS) # 帧率
# 视频的宽高
size = (int(video.get(cv2.CAP_PROP_FRAME_WIDTH)), int(video.get(cv2.CAP_PROP_FRAME_HEIGHT)))
out = cv2.VideoWriter('video.avi', fourcc, fps, size) # 视频存储
f=0
while out.isOpened():
ret, img = video.read() # 开始使用摄像头读数据,返回ret为true,img为读的图像
if ret is False: # ret为false则关闭
exit()
cv2.namedWindow('video', cv2.WINDOW_AUTOSIZE) # 创建一个名为video的窗口
cv2.imshow('video', img) # 将捕捉到的图像在video窗口显示
out.write(img) # 将捕捉到的图像存储
print(f ,' ' , 'fps: ',fps)
f+=1
# 按esc键退出程序
if cv2.waitKey(1) & 0xFF == 27:
video.release() # 关闭摄像头
break
拍照
#coding:utf-8
import cv2
cap = cv2.VideoCapture(0)#创建一个 VideoCapture 对象
flag = 1 #设置一个标志,用来输出视频信息
num = 1 #递增,用来保存文件名
while(cap.isOpened()):#循环读取每一帧
ret_flag, Vshow = cap.read() #返回两个参数,第一个是bool是否正常打开,第二个是照片数组,如果只设置一个则变成一个tumple包含bool和图片
cv2.imshow("Capture_Test",Vshow) #窗口显示,显示名为 Capture_Test
k = cv2.waitKey(1) & 0xFF #每帧数据延时 1ms,延时不能为 0,否则读取的结果会是静态帧
if k == ord('s'): #若检测到按键 ‘s’,打印字符串
cv2.imwrite("/home/jie/图片/VOC/image/"+ str(num) + ".jpg", Vshow)
print(cap.get(3)); #得到长宽
print(cap.get(4));
print("success to save"+str(num)+".jpg")
print("-------------------------")
num += 1
elif k == ord('q'): #若检测到按键 ‘q’,退出
break
cap.release() #释放摄像头