python GUI库图形界面开发之PyQt5切换按钮控件QPushButton详细使用方法与实例

作者:jia666666 时间:2021-06-13 09:13:14 

PyQt5切换按钮控件QPushButton简介

QAbstractButton类为抽象类,不能实例化,必须由其他的按钮类继承QAbstractButton类,来实现不同的功能和表现形式,常见的按钮QPushButton,QToolButton,QRadioButton和QCheckBox这些按钮均继承自QAbstractButton类,根据各自的使用场景通过图形显示出来

QAbstractButton提供的状态如下表

状态含义
isDown()提示按钮是否已按下
isChecked()提示按钮是否已经标记
isEnable()提示按钮是否可以被用户点击
isCheckAble()提示按钮是否为可标记的
setAutoRepeat()设置按钮是否在用户长按时可以自动重复执行

QAbstractButton提供的信号如下表

信号含义
Pressed当鼠标指针在按钮上并按下左键时触发该信号
Released当鼠标左键被释放时触发该信号
Clicked当鼠标左键被按下然后释放时,或者快捷键被释放时触发该信号
Toggled当按钮的标记状态发生改变时触发该信号

QPUshButton类中的常用方法

方法描述
setCheckable()设置按钮是否已经被选中,如果设置True,则表示按钮将保持已点击和释放状态
toggle()在按钮状态之间进行切换
setIcon()设置按钮上的图标
setEnabled()设置按钮是否可以使用,当设置为False时,按钮变成不可用状态,点击它不会发射信号
isChecked()返回按钮的状态,返回值为True或者False
setDefault()设置按钮的默认状态
setText()设置按钮的显示文本
text()返回按钮的显示文本

为QPushButton设置快捷键

通过按钮名字能为QPushButton设置快捷键,比如名字为‘&Download'的按键,它的快捷键是‘Alt+D'。其规则是;想要实现快捷键为“Alt+D”,那么按钮的名字里有D这个字母,并且在D的前面加上“&”,这个字母D一般是按钮名称的首字母,而且在按钮显示时。“&”不会显示出来,如果想显示,那么需要转义,核心代码如下


self.btn4=QPushButton('&Download')
self.btn4.setDefault(True)

QPushButton按钮的使用实例


import sys
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *

class Form(QDialog):
 def __init__(self,parent=None):
   super(Form, self).__init__(parent)

#垂直布局
   layout=QVBoxLayout()

#创建按钮1
   self.btn1=QPushButton('Button1')
   #setCheckable():设置按钮是否已经被选中,如果为True,则表示按钮将保持已点击和释放状态
   self.btn1.setCheckable(True)
   #toggle():在按钮状态之间进行切换
   self.btn1.toggle()
   #点击信号与槽函数进行连接,这一步实现:在控制台输出被点击的按钮
   self.btn1.clicked.connect(lambda :self.whichbtn(self.btn1))
   #点击信号与槽函数进行连接,实现的目的:输入安妞的当前状态,按下还是释放
   self.btn1.clicked.connect(self.btnstate)

#添加控件到布局中
   layout.addWidget(self.btn1)

#创建按钮2
   self.btn2=QPushButton('image')
   #为按钮2添加图标
   self.btn2.setIcon(QIcon(QPixmap('E:\pyqt5快速开发与实战\第四章\images\python.png')))
   ##点击信号与槽函数进行连接,这一步实现:在控制台输出被点击的按钮
   self.btn2.clicked.connect(lambda :self.whichbtn(self.btn2))

layout.addWidget(self.btn2)

self.btn3=QPushButton('Disabled')
   #setEnabled()设置按钮是否可以使用,当设置为False的时候,按钮变成不可用状态,点击它不会发射信号
   self.btn3.setEnabled(False)

layout.addWidget(self.btn3)

#创建按钮并添加快捷键
   self.btn4=QPushButton('&Download')
   #setDefault():设置按钮的默认状态
   self.btn4.setDefault(True)
   ##点击信号与槽函数进行连接,这一步实现:在控制台输出被点击的按钮
   self.btn4.clicked.connect(lambda :self.whichbtn(self.btn4))

layout.addWidget(self.btn4)

self.setWindowTitle("Button demo")
   self.setLayout(layout)

def btnstate(self):
   #isChecked():判断按钮的状态,返回值为True或False
   if self.btn1.isChecked():
     print('button pressed')
   else:
     print('button released')

def whichbtn(self,btn):
   #输出被点击的按钮
   print('clicked button is '+btn.text())
if __name__ == '__main__':
 app=QApplication(sys.argv)
 btnDemo=Form()
 btnDemo.show()
 sys.exit(app.exec_())

效果图如下

python GUI库图形界面开发之PyQt5切换按钮控件QPushButton详细使用方法与实例

QPushButton代码分析:

在这个例子中,创建了四个按钮,这四个QPushButton对象被定义为类的实例变量,每个按钮都将clicked的信号发送给指定的槽函数,来响应按钮点击的事件

第一个按钮btn1,**通过toggle()函数来切换按钮的状态,其核心代码是


self.btn1=QPushButton('Button1')
self.btn1.setCheckable(True)
self.btn1.toggle()

当这个按钮点击时,将clicked信号发送给槽函数btnstate(),通过btn.isChecked来获得按钮是否被点击或者释放的状态,其核心代码是


self.btn1.clicked.connect(self.btnstate)

还可以通过lambda表达式来传递额外的参数btn1,将clicked信号发送给槽函数whichbtn(),其核心代码


self.btn1.clicked.connect(lambda :self.whichbtn(self.btn1))

第二个按钮btn2,上面显示一个图标,使用setIcon()方法接受一个QPixmap对象的图像文件作为输入参数,其核心代码是


self.btn2.setIcon(QIcon(QPixmap('E:\pyqt5快速开发与实战\第四章\images\python.png')))

第三个按钮btn3,使用setEnabled()方法来禁用btn3按钮


self.btn3.setEnabled(False)

第四个按钮btn4,使用setDefault()方法·来设置按钮的默认状态。快捷键是‘&+文本'(&Download),通过‘Alt+D'快捷键来调用槽函数


self.btn4=QPushButton('&Download')

本文主要讲解了PyQt5切换按钮控件QPushButton详细使用方法与实例,更多关于PyQt5控件教程请查看下面的相关链接

来源:https://blog.csdn.net/jia666666/article/details/81513443

标签:python,PyQt5
0
投稿

猜你喜欢

  • Python中如何优雅的合并两个字典(dict)方法示例

    2023-08-02 16:15:25
  • 纯ASP结合VML生成完美图-柱图

    2010-05-11 16:48:00
  • Python ChineseCalendar包主要类和方法详解

    2021-10-12 10:40:40
  • 可用性测试过程中需要关注的一些细节

    2009-03-06 12:38:00
  • CSS模块化设计

    2009-01-05 12:10:00
  • 数字人组件反写[asp组件开发实例4]

    2009-06-09 13:20:00
  • 客户端限制只能上传jpg格式图片的js代码

    2023-07-16 00:56:04
  • 用户体验设计何去何从,交互设计师又何去何从?

    2009-12-28 13:07:00
  • python和node.js生成当前时间戳的示例

    2022-05-26 05:07:43
  • asp如何实现网络打印?

    2010-05-24 18:31:00
  • Symfony核心类概述

    2023-11-17 13:59:48
  • 较完善的日历组件js源码(兼容)

    2010-08-08 08:43:00
  • Python实现模拟时钟代码推荐

    2023-08-03 05:26:09
  • python解决循环依赖的问题分析

    2023-03-19 12:22:14
  • sqlserver索引的原理及索引建立的注意事项小结

    2012-08-21 10:54:34
  • 使用网际数据库浏览器在线维护Access数据库

    2008-05-23 13:05:00
  • javascript修正12个浏览器兼容问题[译]

    2009-04-23 12:19:00
  • css命名及书写规范大全

    2008-05-24 08:52:00
  • Python编程之基于概率论的分类方法:朴素贝叶斯

    2023-10-08 10:15:52
  • Python三元运算实现方法

    2021-12-27 06:02:52
  • asp之家 网络编程 m.aspxhome.com