gpt4 book ai didi

Python+OpenCV+pyQt5录制双目摄像头视频的实例

转载 作者:qq735679552 更新时间:2022-09-28 22:32:09 27 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章Python+OpenCV+pyQt5录制双目摄像头视频的实例由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

起因 。

说起来录制视频,我们可能有很多的软件,但是比较坑的是,好像很少的软件支持能够同时录制两个摄像头的视频,于是我们用python自己写一个。要是OpenCV+python。貌似很简单就能OK的事情,但是,我们的项目不是一般要展示给老师看嘛。谁愿意看一个没有界面的录制过程是吧~,最后会附上源代码~ 。

依赖的包 。

在这里,我直接把import的包写出来了各位可以进行对号入座,然后就能知道需要安装哪个包啦! 。

?
1
2
3
4
5
6
7
import cv2
import numpy as np
from PyQt5.QtWidgets import (QMainWindow, QApplication, QFileDialog)
import threading
import threadpool
from CvPyGui import ImageCvQtContainer
from CvPyGui.ui import gui

界面设计 。

pyqt的界面可以用designer进行构造,这里因为是双目摄像头,我们构造的界面就是这样子的了:

Python+OpenCV+pyQt5录制双目摄像头视频的实例

其中TextLabel就是用来进行显示图像的,这里更新图像的代码如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
class Image(QWidget):
  """Common base for the images"""
 
  def __init__( self , name, label):
  super ().__init__()
 
  # Label (frame) where the original image will be located, with scaling
  self .frame_lbl = label
 
  def updateImage( self , opencv_rgb_image):
 
  self .cv_img_rgb = opencv_rgb_image
 
  height, width, channel = self .cv_img_rgb.shape
  bytesPerLine = 3 * width
  self .q_image = QImage( self .cv_img_rgb.data, width,
   height, bytesPerLine, QImage.Format_RGB888)
 
  self .frame_lbl.setPixmap(QPixmap.fromImage( self .q_image))
 
  def saveImage( self ):
  # Function for saving the processed image
 
  filter = "Images (*.png *.jpg)"
 
  image_path, _ = QFileDialog.getSaveFileName( self , filter = filter )
 
  cv_img_bgr = cv2.cvtColor(
  self .cv_img_rgb, cv2.COLOR_RGB2BGR)
  cv2.imwrite(image_path, cv_img_bgr)

我们也知道,视频是一帧一帧的进行播放的。所以,我们在播放的时候实际上就是在更新每一帧的画面了.

OpenCV的视频获取 。

使用OpenCV获取视频很简单 。

?
1
2
3
4
5
6
7
8
cap = cv2.VideoCapture( int (text))
cap. set ( 6 ,cv2.VideoWriter_fourcc( 'M' , 'J' , 'P' , 'G' ) );
cap. set ( 3 ,w);
cap. set ( 4 ,h);
global update1
update1 = 1
global shotmark1
ret, frame = cap.read()

这样就能够获取到一帧图像了,其中cap.set()函数用来设置相机的参数,本来应该有宏定义的,但是在python里面老是报错,直接用数字替代了,其中3就是获取视频的宽度像素,4是高度,这个要和摄像头手册上的参数一致。一般的Webcam有两种图像获取格式:一种是YUV2格式这种事10bit回传的数据,理论上质量更好,但是有个很大的问题是分辨率高的时候,帧率就会变得十分低。另一种格式是MJPEG格式,这个是使用了压缩技术得到的视频流。通过这个格式,手册上说在1920x1080分辨率下都能获得30fps的表现,而YUV2只有5fps(后来发现,这个就是坑爹的,信了就怪了)。cap.set(6 ,cv2.VideoWriter_fourcc(‘M', ‘J', ‘P', ‘G') );这个参数就是使用MJPEG格式来读取摄像头的数据.

多线程 。

刚才我们呢也提到了,cap.read()这个函数是获取到了一帧图像,但是呢。我们要的是动画啊,要是写个循环的话,又会吧进程卡死在循环中,照成假死的状态,所以对于图像的绘制,一定要使用多线程技术。在这里我不仅要吐槽一下了。学了好多年计算机,讲了很多串行算法和编程,一讲到多线程,无非就是打印个Hello World!,根本就没有什么实践,理论倒是学了很多,感觉用的时候头真的好大! 。

其实这里的多线程也没有什么是吧,就是起调一下。但是要注意的是要控制线程的退出,在python这个我引入的多线程包里面,贼坑的是没有外界控制线程退出的办法!所以,我设置了一个全局变量,使用判断全局变量的值来判断是否让子线程继续下去.

结尾 。

实际上,还有分辨率/帧率设置功能呢,只不过懒得写了!!!3 。

GitHub:https://github.com/anonymouslycn/bjtu_BinocularCameraRecord 。

路过的还新希望你能够高抬贵手给个Star吖~~ 笔芯~~ 。

以上这篇Python+OpenCV+pyQt5录制双目摄像头视频的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我.

原文链接:https://blog.csdn.net/geng333abc/article/details/79727358 。

最后此篇关于Python+OpenCV+pyQt5录制双目摄像头视频的实例的文章就讲到这里了,如果你想了解更多关于Python+OpenCV+pyQt5录制双目摄像头视频的实例的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com