读取摄像头并播放、暂停功能

  1. import sys
  2. #import scipy.io as sio
  3. from PyQt5 import QtGui, QtCore, QtWidgets
  4. #from wyc import Ui_Form
  5. import cv2
  6. import numpy as np
  7. class VideoCapture(QtWidgets.QWidget):
  8. def __init__(self, filename, parent):
  9. super(QtWidgets.QWidget, self).__init__()
  10. self.cap = cv2.VideoCapture(0)
  11. self.video_frame = QtWidgets.QLabel()
  12. parent.layout.addWidget(self.video_frame)
  13. def nextFrameSlot(self):
  14. ret, frame = self.cap.read()
  15. # frame = cv2.cvtColor(frame, cv2.cv.CV_BGR2RGB)
  16. frame2 = np.zeros((frame.shape), dtype=np.int8)
  17. # BGR
  18. frame2[:, :, 0] = frame[:, :, 2]
  19. frame2[:, :, 1] = frame[:, :, 1]
  20. frame2[:, :, 2] = frame[:, :, 0]
  21. img = QtGui.QImage(frame2, frame2.shape[1], frame2.shape[0], QtGui.QImage.Format_RGB888)
  22. pix = QtGui.QPixmap.fromImage(img)
  23. self.video_frame.setPixmap(pix)
  24. def start(self):
  25. self.timer = QtCore.QTimer()
  26. self.timer.timeout.connect(self.nextFrameSlot)
  27. self.timer.start(1000.0/30)
  28. def pause(self):
  29. self.timer.stop()
  30. def deleteLater(self):
  31. self.cap.release()
  32. super(QtGui.QWidget, self).deleteLater()
  33. class VideoDisplayWidget(QtWidgets.QWidget):
  34. def __init__(self,parent):
  35. super(VideoDisplayWidget, self).__init__(parent)
  36. self.layout = QtWidgets.QFormLayout(self)
  37. self.startButton = QtWidgets.QPushButton('播放', parent)
  38. self.startButton.clicked.connect(parent.startCapture)
  39. self.startButton.setFixedWidth(50)
  40. self.pauseButton = QtWidgets.QPushButton('暂停', parent)
  41. self.pauseButton.setFixedWidth(50)
  42. self.layout.addRow(self.startButton, self.pauseButton)
  43. self.setLayout(self.layout)
  44. class ControlWindow(QtWidgets.QMainWindow):
  45. def __init__(self):
  46. super(ControlWindow, self).__init__()
  47. self.setGeometry(100, 100, 800, 600)
  48. self.setWindowTitle("视频显示demo")
  49. self.capture = None
  50. self.matPosFileName = None
  51. self.videoFileName = None
  52. self.positionData = None
  53. self.updatedPositionData = {'red_x':[], 'red_y':[], 'green_x':[], 'green_y': [], 'distance': []}
  54. self.updatedMatPosFileName = None
  55. self.isVideoFileLoaded = True
  56. self.isPositionFileLoaded = True
  57. self.quitAction = QtWidgets.QAction("&Exit", self)
  58. self.quitAction.setShortcut("Ctrl+Q")
  59. self.quitAction.setStatusTip('Close The App')
  60. self.quitAction.triggered.connect(self.closeApplication)
  61. # self.openMatFile = QtWidgets.QAction("&Open Position File", self)
  62. # self.openMatFile.setShortcut("Ctrl+Shift+T")
  63. # self.openMatFile.setStatusTip('Open .mat File')
  64. # self.openMatFile.triggered.connect(self.loadPosMatFile)
  65. # self.openVideoFile = QtWidgets.QAction("&Open Video File", self)
  66. # self.openVideoFile.setShortcut("Ctrl+Shift+V")
  67. # self.openVideoFile.setStatusTip('Open .h264 File')
  68. # self.openVideoFile.triggered.connect(self.loadVideoFile)
  69. # self.mainMenu = self.menuBar()
  70. # self.fileMenu = self.mainMenu.addMenu('&File')
  71. # self.fileMenu.addAction(self.openMatFile)
  72. # self.fileMenu.addAction(self.openVideoFile)
  73. # self.fileMenu.addAction(self.quitAction)
  74. self.videoDisplayWidget = VideoDisplayWidget(self)
  75. self.setCentralWidget(self.videoDisplayWidget)
  76. def startCapture(self):
  77. if not self.capture and self.isPositionFileLoaded and self.isVideoFileLoaded:
  78. self.capture = VideoCapture(self.videoFileName, self.videoDisplayWidget)
  79. self.videoDisplayWidget.pauseButton.clicked.connect(self.capture.pause)
  80. self.capture.start()
  81. def endCapture(self):
  82. self.capture.deleteLater()
  83. self.capture = None
  84. # def loadPosMatFile(self):
  85. # try:
  86. # self.matPosFileName = str(QtGui.QFileDialog.getOpenFileName(self, 'Select .mat position File'))
  87. # self.positionData = sio.loadmat(self.matPosFileName)
  88. # self.isPositionFileLoaded = True
  89. # except:
  90. # print("Please select a .mat file")
  91. # def loadVideoFile(self):
  92. # try:
  93. # self.videoFileName = QtGui.QFileDialog.getOpenFileName(self, 'Select .h264 Video File')
  94. # self.isVideoFileLoaded = True
  95. # except:
  96. # print("Please select a .h264 file")
  97. def closeApplication(self):
  98. choice = QtGui.QMessageBox.question(self, 'Message','Do you really want to exit?',QtGui.QMessageBox.Yes | QtGui.QMessageBox.No)
  99. if choice == QtGui.QMessageBox.Yes:
  100. print("Closing....")
  101. sys.exit()
  102. else:
  103. pass
  104. if __name__ == '__main__':
  105. import sys
  106. app = QtWidgets.QApplication(sys.argv)
  107. window = ControlWindow()
  108. window.show()
  109. sys.exit(app.exec_())

回放、指定目录保存功能

  1. 以时间戳的形式保存视频:
  2. import cv2
  3. import datetime
  4. cap = cv2.VideoCapture(0)
  5. import os.path
  6. save_path = 'G:/Temp/' #以特定前缀保存视频文件到指定目录
  7. timeNow = "%s.avi" % (datetime.datetime.now().strftime('%Y_%m_%d_%H-%M-0%S'))
  8. completeName = os.path.join(save_path, timeNow)
  9. out = (cv2.VideoWriter(timeNow, cv2.VideoWriter_fourcc(*'PIM1'), 30.0, (640, 480))) #第三个参数是帧率
  10. while cap.isOpened():
  11. ret, frame = cap.read()
  12. if ret==True:
  13. out.write(frame)
  14. cv2.imshow('frame', frame)
  15. if cv2.waitKey(1) & 0xFF == ord('q'):
  16. break
  17. else:
  18. break
  19. # Release everything if job is finished
  20. cap.release()
  21. out.release()
  22. cv2.destroyAllWindows()
  23. 回放视频:
  24. import os
  25. def videoBack(self):
  26. os.startfile("G:/Tx2Project/VideoShow") #录制的视频存放文件

(17)Python读取摄像头并实现视频播放、暂停、指定目录保存、回放功能的更多相关文章

  1. 利用python+graphviz绘制数据结构关系图和指定目录下头文件包含关系图

    作为一名linux系统下的C语言开发,日常工作中经常遇到两个问题: 一是分析代码过程中,各种数据结构互相关联,只通过代码很难理清系统中所有结构体的整体架构,影响代码消化的效率; 二是多层头文件嵌套包含 ...

  2. python读取文件通过正则过滤需要信息然后保存到新文件里

    import osimport reimport fileinput def getDataFromFile():        rt = "/(.*)/(.*).apk"     ...

  3. python实现上传文件到linux指定目录

    今天接到一个小需求,就是想在windows环境下,上传压缩文件到linux指定的目录位置并且解压出来,然后我想了一下,这个可以用python试试写下. 环境:1.linux操作系统一台2.window ...

  4. 【Python】自动生成html文件查看指定目录中的所有图片

    获取本目录下的pic子目录中的所有图片(jpg,png,bmp,gif等,此处以jpg文件为例),然后生成一个image.html文件,打开该html文件即可在浏览器中查看pic子目录中的所有图片. ...

  5. python zip压缩文件 并移动到指定目录

    需要引入的3个包: import os import shutil import zipfile 1. # 创建zip文件对象your_zip_file_obj = zipfile.ZipFile(' ...

  6. Python 解压缩Zip和Rar文件到指定目录

    #__author__ = 'Joker'# -*- coding:utf-8 -*-import urllibimport osimport os.pathimport zipfilefrom zi ...

  7. Python读取JSON数据,并解决字符集不匹配问题

    今天来谈一谈Python解析JSON数据,并写入到本地文件的一个小例子. – 思路如下 从一个返回JSON天气数据的网站获取到目标JSON数据串 使用Python解析出需要的部分 写入到本地文件,供其 ...

  8. 最简单的基于FFmpeg的AVDevice例子(读取摄像头)

    =====================================================最简单的基于FFmpeg的AVDevice例子文章列表: 最简单的基于FFmpeg的AVDev ...

  9. Python 读取图像文件的性能对比

    Python 读取图像文件的性能对比 使用 Python 读取一个保存在本地硬盘上的视频文件,视频文件的编码方式是使用的原始的 RGBA 格式写入的,即无压缩的原始视频文件.最开始直接使用 Pytho ...

随机推荐

  1. 【windows】windows安全基础

    windows安全基础 安全主体 security principal 是可以进行身份验证的实体. 哪个安全主体在要求访问?这个维度可以是用户,计算机和进程.一旦确认以后,系统就会发放SID. 例子: ...

  2. 手把手教你SOAP访问webservice并DOM解析返回的XML数据(转)

    http://blog.csdn.net/u012534831/article/details/51357111 前言: 目前我们项目组还在采用webservice这种http方式,并且某些网站服务提 ...

  3. urllib库认证,代理,cookie

    认证,代理,cookie 1from urllib.request import HTTPBasicAuthHandler, HTTPPasswordMgrWithDefaultRealm, buil ...

  4. 【监控笔记】【2.4】SQL Server中的 Ring Buffer 诊断各种系统资源压力情况

    SQL Server 操作系统(SQLOS)负责管理特定于SQL Server的操作系统资源. 其中相关的动态管理试图sys.dm_os_ring_buffers将被标识为仅供参考.不提供支持.不保证 ...

  5. 2017沈阳区域赛Infinite Fraction Path(BFS + 剪枝)

    Infinite Fraction Path Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java ...

  6. gRPC go安装教程

    安装protobuf go get -u github.com/golang/protobuf/proto go get -u github.com/golang/protobuf/protoc-ge ...

  7. shell脚本又是什么?

    操作系统命令的组合称为Shell脚本: 一个Shell脚本主要由原本需要在命令行输入的命令组成,或在一个文本编辑器中,用户可以使用脚本来把一些常用的操作组合成一组串行.主要用来书写这种脚本的语言叫做脚 ...

  8. C++编译器对属性的初始化检查远没有Java严格

    C++编译器对属性的初始化检查远没有Java严格// Java编译通过:class yy { public static void main(String[] args) { int i; Syste ...

  9. wordpress开发的一些积累

    wordpress 攒知识点 记录开发 wordpress 的一些技能点,以备不时之需 短代码 Shortcode 虽然很多插件都是提供,直接在代码中插入类似[Shortcode] 便可以生效,但是很 ...

  10. 剑指offer-包含min函数的栈-栈和队列-python

    题目描述 定义栈的数据结构,请在该类型中实现一个能够得到栈中所含最小元素的min函数(时间复杂度应为O(1)).   # -*- coding:utf-8 -*- class Solution: de ...