---作者吴疆,未经允许,严禁转载,违权必究---

---欢迎指正,需要源码和文件可站内私信联系---

-----------点击此处链接至博客园原文-----------

功能说明:PyQt界面程序,触发播放按钮实现显示图片、一窗体一屏一放视频、一窗体多屏多放视频功能

运行环境:Windows7、Python3、PyQt5、Pycharm5.0

一、环境搭建

参考链接:PyQt5环境搭建PyQt工具栏菜单汉化

1.PyQt5和PyQt5-tools安装(注:PyQt5与PyQt4存在一定区别)

pip安装命令为 pip install PyQt5和pip install PyQt5-tools

2.Pycharm中Qt Designer(用于绘画界面)和PyUIC(将界面ui文件转化为py文件供继承)配置

Pycharm中菜单栏依此点击File----Settings----Tools----External Tools-----点击“+”号,按下图分别添加Qt Designer、PyUIC

Program参数为“designer.exe”的全路径,Working directory:$ProjectFileDir$

Program参数为“python.exe”的全路径,Arguments:-m PyQt5.uic.pyuic  $FileName$ -o $FileNameWithoutExtension$.py

3.Qt Designer工具栏菜单汉化(英语大神可跳过此步)

下载designer_zh_CN.qm将它放在你的...\Lib\site-packages\pyqt5-tools\translations文件夹中,重新打开QT就汉化成功了

designer_zh_CN.qm的下载地址为:https://pan.baidu.com/s/1jzkumqjw-3VQiJxvo4V6Xw

二、实例上手----实现显示图片

参考链接:计算售价界面程序(只学习其中如何绘制ui界面)、PyQt 用label控件显示图片基于Qt Designer和PyUIC开发PyQt程序的步骤

----------------上述3个博客建议看下,可以有个初步了解,也可跳过----------------------

1.使用Qt Designer设计界面

Pycharm中顶部菜单栏依此点击Tools ----External Tools----Qt Designer,如下图所示,选择创建Main Window(主窗体),可在“屏幕大小”选项选择适当大小,此时若不选择可以后续再更改相关属性

注:作为我们初学者,先别管main windows、Widget、Dialog的区别(之间存在继承关系、功能略有差异)

就像做ppt一样开始绘制界面ui,左侧为控件箱,中间为绘制窗口面板,右侧可更改窗口、控件相关属性

本节涉及的控件主要包括label、Push Button等,只需在控件箱将相应控件拖入面板

以label控件为例,拖入面板,点击label控件,在右侧一列属性栏内编辑其属性,一般需要改objectName(通过pythpn代码调用这个控件的变量名,尽量取有意义的名字)、text(显示文字)、宽度、高度等属性

pushbotton控件同样照此操作,得到的简易界面如下图所示

保存当前窗体(如:起名为test.ui),将自动生成xx.ui文件(实际上是一个xml文件,可用任何文本编辑器打开),此时,对该文件右键 External Tools ----PyUIC ,“xx.ui”文件在同目录下被转为“xx.py”文件以便继承,转换为“xx.py”的原因是IDE能自动识别对象和函数。然后在当前目录下新建一个.py文件(如下图中show_single_channel.py)。

在该py文件中添加如下头文件

创建一个类MyApp,继承Ui_MainWindow类,类内添加初始化方法

类内添加槽函数及槽函数需调用的函数等,当点击pushButton将触发槽函数相应事件

添加主函数

实现效果:点击播放按钮,屏幕显示该图片

三、实例上手----实现一窗体一屏一放

参考链接:BGR图像转换为QImage对象QPixmap详解    (以上博客建议阅读)

项目名:qt_show_single(百度云盘备份不对外提供)

实现效果:点击播放按钮,屏幕实时播放视频

与实例二代码逻辑上无本质上区别,主要修改槽函数即可,修改说明可见如下截图注释

仅提供代码截图(show_single_channel.py):

四、实例上手----实现一窗体多屏多放

项目名:qt_show_double(百度云盘备份不对外提供)

实现效果:分别点击播放1、播放2,屏幕实时播放对应视频。

代码说明:按上述操作单屏能实现的话,多屏是一样的道理,主要问题在于代码如何写的更精简,由于项目要求,在此不提供参考代码。

五、常见报错

1.native Qt signal is not callable

将信号与槽函数未关联,此处若缺少connect会导致该错误发生。

2.环境的错误:如PyQt4与PyQt5环境不同导致的,具体可百度解决。

利用PyQt GUI显示图片、实时播放视频的更多相关文章

  1. 利用matplot简单显示图片

    import matplotlib.pyplot as plt from matplotlib.image import imread img = imread('F:\\ml\\DL\\source ...

  2. ckplayer插件播放视频

    官网:超酷网页视频 本篇介绍:插件播放视频,  添加插件(额外的功能),  视频格式之间的转换 PC端一般都是利用插件(Flash)来播放视频,可以支持很多格式.网上很多说这个插件的,这里只是做个记录 ...

  3. video播放视频以及相关事件

    <!DOCTYPE html> <html lang="en"> <head> <meta http-equiv="Conten ...

  4. [Unity3D][Vuforia][IOS]vuforia在unity3d中添加自己的动态模型,识别自己的图片,添加GUI,播放视频

    使用环境 unity3D 5 pro vuforia 4 ios 8.1(6.1) xcode 6.1(6.2) 1.新建unity3d工程,添加vuforia 4.0的工程包 Hierarchy中 ...

  5. Unity3D基础学习 利用NGUI的Texture播放视频

    利用NGUI播放视频,首先你得导入你的视频 你的电脑中必须安装QuickTime软件,没有,去下一个,如果是Windows系统,安装完之后重启. 接下来转换你的视频格式,如果你的视频在QuickTim ...

  6. 使用canvas来实时播放RTSP视频

    HTML5的标签可以用使用下来面的方式来播放静态视频 <video width="320" height="240" controls="con ...

  7. 前端Web浏览器基于Flash如何实时播放监控视频画面(四)之使用videoJs‘拉流’

    本片文章只是起到抛砖引玉的作用,能从头到尾走通就行,并不做深入研究.为了让文章通俗易懂,尽量使用白话描述. 0x001: 下载videoJs 对于Video.js 5.x及更低版本,Flash技术(v ...

  8. 如何利用CSS代码使图片和文字在同一行显示且对齐

    对于初学css的新手朋友来说,经常会遇到这样一个问题,当文字和图片出现在同一行或者同一个div里面的时候,在浏览器中运行出来的显示效果往往是在不同的行,那么,我们怎么才能利用CSS代码使图片和文字在同 ...

  9. iOS使用ffmpeg播放rstp实时监控视频数据流

    一.编译针对iOS平台的ffmpeg库(kxmovie) 最近有一个项目.须要播放各种格式的音频.视频以及网络摄像头实时监控的视频流数据,经过多种折腾之后,最后选择了kxmovie,kxmovie项目 ...

随机推荐

  1. 基于ftp服务实现yum网络共享

    安装ftp服务:yum install vsftpd 安装后: CentOS7 启动服务:systemctl start vsftpd 设置开机启动:systemctl enable vsftpd 同 ...

  2. C语言学习笔记--const 和 volatile关键字

    1.const关键字 (1)const 修饰的变量是只读的,它不是真正的常量,本质还是变量,只是告诉编译器不能出现在赋值号左边! (2)const 修饰的局部变量在栈上分配空间 (3)const 修饰 ...

  3. Dexdump 无法正常反编译问题

    WIN环境下无法正常运行,提示Unable open XXX as zip 解决方案:使用APKTOOL + JD-GUI进行替代反编译

  4. 面试题: mysql 数据库已看 sql安全性 索引 引擎 sql优化

    总结的一些MySQL数据库面试题 2016年06月16日 11:41:18 阅读数:4950 一.sql语句应该考虑哪些安全性? (1)防止sql注入,对特殊字符进行转义,过滤或者使用预编译的sql语 ...

  5. 树莓派 Learning 001 装机 ---之 1 安装NOOBS系统

    树莓派安装NOOBS系统 (使用的树莓派板卡型号:Raspberry Pi 2 Model B V1.1)(板卡的型号在板子正面的丝印层上印着,你可以看到.) RASPBERRY PI 2 MODEL ...

  6. Asp.net 微信企业号网页开发流程

    一.在pageload方法中获取code var code = GetCode(); private string GetCode() { return HttpContext.Current.Req ...

  7. Hadoop添加节点datanode(生产环境)

    Hadoop添加节点datanode 博客分类: hadoop HadoopSSHJDKXML工作  1.部署hadoop    和普通的datanode一样.安装jdk,ssh  2.修改host  ...

  8. 11、比对软件STAR(https://github.com/alexdobin/STAR)

    转载:https://mp.weixin.qq.com/s?__biz=MzI1MjU5MjMzNA==&mid=2247484731&idx=1&sn=b15fbee5910 ...

  9. BerkeleyDB原理及其对应API

    BerkeleyDB(简称为BDB)是一种以key-value为结构的嵌入式数据库引擎: 嵌入式:bdb提供了一系列应用程序接口(API),调用这些接口很简单,应用程序和bdb所提供的库一起编译/链接 ...

  10. Android性能优化系列---管理你的app内存

     文章出处:http://developer.android.com/training/articles/memory.html#YourApp Random-access memory(RAM)在任 ...