PyQt5 基础知识(六):展示控件
3、 展示控件
3.1 QLabel
3.1.1 描述
提供了文本或图像的显示
- 可以展示普通文本、数字、富文本、图片和动画
但是没有提供用户交互功能,继承自QFrame
3.1.2 功能作用
3.1.2.1 基本功能
#!/usr/bin/env python
# -*- coding: UTF-8 -*-
# @author: kun
from PyQt5.Qt import *
import sys
app = QApplication(sys.argv)
w = QWidget()
w.resize(500, 500)
l = QLabel("标签哦", w) # 创建一个标签
"""
l.adjustSize() # 根据内容适应标签大小
l.setStyleSheet("background-color: skyblue;")
对齐
l.setAlignment(Qt.AlignLeft | Qt.AlignVCenter)
缩进和边距
l.setIndent(20)
l.setMargin(20)
文本格式
l.setTextFormat(Qt.TextFormat) # PlainText/ RichText/ AutoText/ MarkdownText
小伙伴
l.setBuddy(QWidget) # 参数是要关联的输入框,当点击快捷键是可以快速定位到相应的文本框上面
内容缩放
l.setScaledContents(True) # 设置图片内容的缩放,适应控件大小,仅限于图片
打开文本链接
l.setOpenExternalLinks(True) # 使得可以打开超链接
单词换行
l.setWordWrap(True) # 设置单词换行,同时也可以使用 \n 换行
"""
w.show()
sys.exit(app.exec_())
3.1.2.2 文本交互
# 设置交互模式
setTextInteractionFlags(Qt.TextInteractionFlags)
textInteractionFlags()
# 选中文本
setSelection(int start, int length)
hasSelection()
selectedText()
selectionStart() # 返回开始位置的索引
Qt.TextInteractionFlags
:
Qt.NoTextInteraction
:不可能进行交互Qt.TextSelectableByMouse
:可以使用鼠标选择文本并使用上下文菜单或标准键盘快捷键将其复制到剪切板Qt.TextSelectionByKeyboard
:可以使用键盘上的光标键选择文本,显示文本光标Qt.LinksAccessibleByMouse
:可以使用鼠标突出显示和激活链接Qt.LinksAccessibleByKeyborad
:可以使用选项卡聚焦链接并使用enter激活Qt.TextEditable
:改文字完全可以编辑Qt.TextEditiorInteraction
:文本编辑器的默认值;TextSelectableByMouse | TextSelectionByKeyboard | TextEditable
Qt.TextBrowserInteraction
:文本浏览器的默认值;TextSelectableByMouse | TextSelectionByKeyboard | LinksAccessibleByMouse | LinksAccessibleByKeyborad
3.1.2.3 内容操作
3.1.2.3.1 文本字符串
text()
setText(QString) # 里面可以添加富文本
3.1.2.3.2 数值数据
setNum(int / float) # 设置数值
3.1.2.3.3 图形图像
setPicture(QPicture) # 主要用于绘画设备
setPixmap(QPixmap)
3.1.2.3.4 动图
setMovie(QMovie) # 注意不是添加视频,而是添加一个动图
movie()
此类用于显示没有声音的简单动画
常用操作:
setScaledSize(QSize)
setPaused(bool)
setSpeed(int) # setSpeed(200) 两倍速播放
start() # 开始播放
3.1.2.3.5 清空
clear() # 清空所有内容
3.1.3 信号
# 超链接有关的信号
linkActivated(link_str)
linkHovered(link_str)
3.2 QLCDNumber
3.2.1 描述
展示LCD样式的数字,它可以展示几乎任何大小的数字;它可以显示十进制、十六进制、八进制或二进制
继承自QFrame
3.2.2 功能作用
3.2.2.1 基本使用
#!/usr/bin/env python
# -*- coding: UTF-8 -*-
# @author: kun
from PyQt5.Qt import *
import sys
app = QApplication(sys.argv)
w = QWidget()
w.resize(500, 500)
ql = QLCDNumber(w) # 构造函数,还可以传入一个数字,限制要展示的内容的位数
ql.resize(100, 50)
ql.display("12345") # 设置展示的内容,里面可以传入字符串,浮点数据,整型数据
print(ql.value()) # 获取ql里面的值,返回浮点类型数据
ql.setDigitCount(5) # 限制5位数字
w.show()
sys.exit(app.exec_())
3.2.2.2 模式设置
setMode(QLCDNumber.Mode)
mode()
# 快速设置方法
setHexMode() # 十六进制
setDecMode() # 十进制
setOctMode() # 八进制
setBinMode() # 二进制
3.2.2.3 溢出判定
checkOverflower(float/ int) # 判断数据是否溢出,如果溢出会发送一个溢出信号
3.2.2.4 分段样式
setSegmentStyle(QLCDNumber.SegmentStyle)
segmentStyle()
QLCDNumber.SegmentStyle
:
QLCDNumber.Outline
:生成填充了背景颜色的凸起部分QLCDNumber.Filled
:默认值,生成填充前景色的凸起部分QLCDNumber.Flat
:生成填充前景色的平坦段
3.2.3 信号
overflow() # 当数据溢出时,发送信号
3.3 QProgressBar
3.3.1 描述
提供一个水平或垂直进度条;进度条用于向用户提供操作进度提示,并向他们保证应用程序仍在运行
继承自 QWidget
3.3.2 功能作用
3.3.2.1 基本功能
#!/usr/bin/env python
# -*- coding: UTF-8 -*-
# @author: kun
from PyQt5.Qt import *
import sys
app = QApplication(sys.argv)
w = QWidget()
w.resize(500, 500)
qp = QProgressBar(w) # 创建对象
qp.setMaximum(100)
qp.setMinimum(0)
# qp.setRange(0, 100) # 设置取值范围,最大值和最小值,当最大值和最小值相等时,处于繁忙状态
qp.setValue(20) # 设置当前的值
# qp.reset() # 重置进度条
print(qp.value()) # 获取当前进度条的值
# 设置进度条的方向
# pq.setOrientation(Qt.Orientation)
# 倒立外观
# pq.setInvertedAppearance(bool)
w.show()
sys.exit(app.exec_())
3.3.2.2 格式设置
setFormat(str) # %p 为百分比;%v 为当前值;%m 为总值
# 如 setFormat("已下载%p %")
resetFormat() # 重置格式设置
setAlignment(Union[Qt.Alignment, Qt.AliginmentFlag]) # 格式化字符对齐方式
3.3.2.3 文本操作
setTextVisible(bool) # 标签是否可见
text() # 获取标签文本内容
setTextDirection(QProcessBar.Direction) # 控制文本的排列方向
3.3.3 信号
valueChanged(int)
3.4 QErrorMessaage
3.4.1 描述
错误消息小部件由文本标签和复选框组成;该复选框允许用户控制将来是否再次显示相同的错误消息
继承自QDialog
3.4.2 功能作用
#!/usr/bin/env python
# -*- coding: UTF-8 -*-
# @author: kun
from PyQt5.Qt import *
import sys
app = QApplication(sys.argv)
w = QWidget()
w.resize(500, 500)
qb = QErrorMessage(w) # 创建对象
qb.setWindowTitle("错误提示") # 修改窗口标题
qb.showMessage("你确定要继续操作吗?") # 如果设置多个,会一次一次展示出来
qb.exec() # 展示对话框
QErrorMessage.qtHandler() # 通过静态方法,展示级别信息,使用此放你发后,后溪所有的返回均会使用对话框显示
qDebug("xxx") # 调试信息
qWarning("eee") # 警告信息
w.show()
sys.exit(app.exec_())
3.4.3 信号
继承父类
3.5 QProgressDialog
3.5.1 描述
提供一个缓慢的操作进度反馈,进度对话框用于向用户指示操作符花费多长时间,并演示应用程序尚未冻结;它还可以为用户提供中止操作的机会
继承自 QDialog
3.5.2 功能作用
3.5.2.1 基础
#!/usr/bin/env python
# -*- coding: UTF-8 -*-
# @author: kun
from PyQt5.Qt import *
import sys
app = QApplication(sys.argv)
w = QWidget()
w.resize(500, 500)
qpd = QProgressDialog("进度条", "确定", 0, 100, w) # 0 为进度条的最小值
# 自动选择
qpd.setAutoClose(False) # 设置对话框完成后是否关闭
qpd.setAutoReset(False) # 进度条满后是否重置信息
# 弹出:最小展示时长——展示之前的等待时间:如果在等待时间内,进度条满了,就不会弹出;否则弹出
# qpd.setMinimumDuration(int) # 默认为 4 秒
# 或者直接使用 open(func_) 弹出
w.show()
sys.exit(app.exec_())
3.5.2.2 界面内容编辑
# 对话框标题
setWindowTitle(str)
# 标签文本
setLabelText(str)
# 取消按钮文本
setCancelButtonText(str)
# 子控件设置
setBar(QProgressBar)
setCancelButton(QPushButton)
setLabel(QLabel)
3.5.2.3 数据处理
# 最大值和最小值
setMinimum(int)
setMaximum(int)
setRange(int min, int max)
# 设置当前的进度
setValue(int)
# 是否取消
cancel() # 取消进度条
wasCanceled()
3.5.3 信号
canceled()
3.6 QMessageBox
3.6.1 描述
用于通知用户或请求用户的提问和接收应答的一个模态窗口;无论其展示方式是什么,都为模态窗口
对话框的构成:
继承自 QDialog
3.6.2 功能作用
3.6.2.1 构造函数
QMessageBox(parent: QWidget = None)
QMessageBox(QMessageBox.Icon, str, str, buttons: Union[QMessageBox.StandardButtons, QMessageBox.StandardButton] = QMessageBox.NoButton, parent: QWidget = None, flags: Union[Qt.WindowFlags, Qt.WindowType] = Qt.Dialog|Qt.MSWindowsFixedSizeDialogHint) # str 可以为富文本
3.6.2.2 内容展示
# 对话框标题
setWindowTitle(str)
# 标准图标
seticon(QMessageBox.Icon) # 参数请到源码查看
# 自定义图标
setIconPixmap(QPixmap)
# 主要标题
setText(str)
setTextFormat(Qt.TextFormat) # 设置文本的格式,富文本、普通文本或者自动识别
# 提示信息
setInformativeText(str)
# 详细文本
setDetailedText(str)
# 复选框
setCheckBox(QCheckBox)
3.6.2.3 按钮
添加移除按钮
addButton(QabstractButton, QMessageBoxButtonRole)
addButton(str, QMessageBox.ButtonRole)
addButton(QMessageBox.StandardButton)
removeButton(QAbstractButton)
设置标准按钮
setStandardButtons(Union[QMessageBox.StandardButtons, QMessageBox.StandardBox.StandardButton])
默认按钮
setDefaultButton(QPushButton)
setDefaultButton(QMessageBox.StandardButton)
退出按钮
setEscapeButton(QAbstractButton)
setEscapeButton(QMessageBox.StandardButton)
# 按 Esc 时激活按钮
获取按钮
buttons()
button(QMessageBox.StandardButton)
按钮角色
buttonRole(QAbstractButton)
被点击的按钮
clickedButton()
参数请到源码查看
3.6.2.4 文本交互
setTextInteractionFlags(Qt.TextInteractionFlag)
textInteractionFlags()
相关参数和上文的文本交互类似:【[点我](#3.1.2.2 文本交互)】,其仅仅控制主标题
3.6.2.5 静态方法
# 关于表
about(QWidget, str, str)
# 关于 Qt 的对话框
aboutQt(QWidget, title)
# 危险按钮
critical(QWidget, str, str, buttons: Union[QMessageBox.StandardButtons, QMessageBox.StandardButton] = QMessageBox.Ok, defaultButton: QMessageBox.StandardButton = QMessageBox.NoButton) -> QMessageBox.StandardButton
# 展示相关信息
information(QWidget, str, str, buttons: Union[QMessageBox.StandardButtons, QMessageBox.StandardButton] = QMessageBox.Ok, defaultButton: QMessageBox.StandardButton = QMessageBox.NoButton) -> QMessageBox.StandardButton
# 询问按钮
question(QWidget, str, str, buttons: Union[QMessageBox.StandardButtons, QMessageBox.StandardButton] = QMessageBox.StandardButtons(QMessageBox.Yes|QMessageBox.No), defaultButton: QMessageBox.StandardButton = QMessageBox.NoButton) -> QMessageBox.StandardButton
# 警告按钮
warning(QWidget, str, str, buttons: Union[QMessageBox.StandardButtons, QMessageBox.StandardButton] = QMessageBox.Ok, defaultButton: QMessageBox.StandardButton = QMessageBox.NoButton) -> QMessageBox.StandardButton
静态方法,快速展出对话框
3.6.3 信号
buttonClicked(QAbstractButton)
PyQt5 基础知识(六):展示控件的更多相关文章
- Android学习之基础知识五—ListView控件(最常用和最难用的控件)
ListView控件允许用户通过上下滑动来将屏幕外的数据拉到屏幕内,把屏幕内的数据拉到屏幕外. 一.ListView的简单用法第一步:先创建一个ListViewTest项目,在activity_mia ...
- qt 5 基础知识 2(控件篇)
QVBoxLayout *lay = new QVBoxLayout(this); // 创建一个竖直的盒子 lebel 篇 lay->addWidget(label = new QLabel( ...
- Android微信九宫格图片展示控件
版权声明:本文为xing_star原创文章,转载请注明出处! 本文同步自http://javaexception.com/archives/214 Android微信九宫格图片展示控件 半年前,公司产 ...
- winform快速开发平台 -> 基础组件之分页控件
一个项目控件主要由及部分的常用组件,当然本次介绍的是通用分页控件. 处理思想:我们在处理分页过程中主要是针对数据库操作. 一般情况主要是传递一些开始位置,当前页数,和数据总页数以及相关关联的业务逻辑. ...
- 重新想象 Windows 8 Store Apps (16) - 控件基础: 依赖属性, 附加属性, 控件的继承关系, 路由事件和命中测试
原文:重新想象 Windows 8 Store Apps (16) - 控件基础: 依赖属性, 附加属性, 控件的继承关系, 路由事件和命中测试 [源码下载] 重新想象 Windows 8 Store ...
- HTML5的video虽然可用controls来展示控件
HTML5的video虽然可用controls来展示控件,并进行控制播放暂停等,但是不同的浏览器显示的效果可能不一样,所以很多时候我们需要使用Dom来进行自定义的一些操作和控制.下面是一个小例子. 当 ...
- python基础知识六 文件的基本操作+菜中菜
基础知识六 文件操作 open():打开 file:文件的位置(路径) mode:操作文件模式 encoding:文件编码方式 f :文件句柄 f = open("1.t ...
- Python基础知识(六)------小数据池,集合,深浅拷贝
Python基础知识(六)------小数据池,集合,深浅拷贝 一丶小数据池 什么是小数据池: 小数据池就是python中一种提高效率的方式,固定数据类型使用同一个内存地址 代码块 : 一个文 ...
- jquery分页展示控件:kkpager
kkpager v1.2 js分页展示控件,传入简单参数就能使用的分页效果控件 准备工作,引入js.css <script type="text/javascript" sr ...
随机推荐
- 浏览器中 Http缓存
分类: web缓存主要有:数据库缓存.服务器缓存(代理服务器缓存.CDN缓存),浏览器缓存. 数据库缓存 当web应用的关系比较复杂,数据库中的表很多的时候,如果频繁进行数据库查询,很容易导致数据库不 ...
- dotnet 委托的实现解析
缘起 最近被问到什么是.Net中的委托.问题虽然简单却无从回答.只能说委托是托管世界的函数指针,这么说没啥大毛病,但也都是毛病(当时自己也知道这么说不太对,不过自己不太爱用这个也没准备确实没有更好的答 ...
- ASP.NET Core 6框架揭秘实例演示[26]:跟踪应用接收的每一次请求
很多人可能对ASP.NET Core框架自身记录的诊断日志并不关心,其实这些日志对纠错排错和性能监控提供了很有用的信息.如果需要创建一个APM(Application Performance Mana ...
- 跑马灯带你深入浅出TextView的源码世界
一.背景 想必大家平时也没那么多时间是单独看源码,又或者只是单纯的看源码遇到问题还是不知道怎么从源码的角度解决. 但是大家平时开发过程中肯定会遇到这样或那样的小问题,通过百度.Google搜索都无果, ...
- 🍛 餐厅吃饭版理解 IO 模型:阻塞 / 非阻塞 / IO 复用 / 信号驱动 / 异步
IO 概念 一个基本的 IO,它会涉及到两个系统对象,一个是调用这个 IO 的进程对象,另一个就是系统内核 (kernel).当一个 read 操作发生时,它会经历两个阶段: 通过 read 系统调用 ...
- java 学习笔记(一)
书 head first java 1. 2.加强版的FOR循环 3. 通过super引用父类 4.多态 5.接口和抽象类 接口 6.多线程锁 7.JDBC
- java继承:extends
继承:extends 1.java只支持单继承,不支持多继承 2.java支持多层继承(继承体系) 3.子类不能继承父类所有非私有的成员(成员方法和成员变量) 4.子类不能继承父类的构造方法,但是可以 ...
- spring-boot-learning-Web开发-深入理解springMVC
处理器映射 11spring启动阶段就会将@RequestMapping所配置的内容保存到处理器映射HandlerMapping机制中去 22等待请求,通过拦截器拦截请求信息与HandlerMappi ...
- 使用docker-compose+nginx+uwsgi+django部署项目
(1)centos上下载docker + docker-compose (2)基础目录 (3)首先创建一个纯净的python+django+uwsgi的镜像,便于后期使用(也可不用创建,后期docke ...
- 去掉win10的命令行
FluentTerminal 和xshell类似,多个终端在一个页面,比较舒服,可复制,可粘贴 界面: https://github.com/felixse/FluentTerminal 自己去git ...