按钮类控件
1.QAbstractButton
在任何GUI设计中,按钮都是最重要的和常用的触发动作请求的方式,用来与用户进行交互操作。在PyQt中根据不同的使用场景将按钮划分为不同的表现形式。按钮的基类是QAbstractButton,提供了按钮的通用性功能。QAbstractButton类为抽象类,不能实例化,必须由其他的按钮类继承QAbstractButton类,来实现不同的功能、不同的表现形式。
常见的按钮类包括:QPushButton、QToolButton、QRadioButton和 QCheckBox。这些按钮类均继承自QAbstractButton类,根据各自的使用场景通过图形展现出来。
OAbstractButton提供的状态如表1所示。

QAbstractButton提供的信号如表2所示。

2. QPushButton
QPushButton类继承自QAbstractButton类,其形状是长方形,文本标题或图标可以显示在长方形上。它也是一种命令按钮,可以单击该按钮执行一些命令,或者响应一些事件。常见的有“确认”“申请”“取消”“关闭”“是”“否”等按钮。
命令按钮通常通过文本来描述执行的动作,有时候也会通过快捷键来执行对应按钮的命令。
1) QPushButton类中的常用方法
QPushButton类中的常用方法如表3所示。

2)为QPushButton设置快捷键
通过按钮名字能为QPushButton设置快捷键,比如名字为“&Download”的按钮,它的快捷键是“Alt+D”。其规则是:想要实现快捷键为“Alt +D”,那么按钮的名字里就要有这个字母D,并且在字母D前面加上“&”。这个字母D一般是按钮名称的首字母,而且在按钮显示时,“&”不会被显示出来,但字母D会显示一条下画线。如果只想显示“&”,那么需要像转义一样使用“&&”。更多的关于快捷键的使用,请参考QShortcut类。其核心代码如下:
当按下ALT时,"Download"首字母"D"下面会显示横线,显示效果如图,

实例演示1:QPushButton按钮的使用
此示例中,演示了按钮的各种功能,完整代码如下:
运行代码,显示结果如下:

代码分析:
在这个例子中,创建了btnl,btn2、btn3和 btn4 四个按钮,这四个QPushButton对象被定义为类的实例变量。上面的代码符合面向对象的设计思想。每个按钮都将clicked 信号发送给指定的槽函数,以响应按钮点击事件。
第1个按钮btnl,通过toggle()函数来切换按钮状态。其核心代码是:
当点击这个按钮时,将clicked信号发送给槽函数btnstate(),通过btn.isChecked来获得按钮是否被点击或释放的状态。其核心代码是:
还可以通过lambda的方式来传递额外的参数btn1,将clicked信号发送给槽函数whichbtn()。其核心代码是:
第2个按钮btn2,上面显示一个图标。使用setIcon()方法接收一个QPixmap对象的图像文件作为输入参数。其核心代码是:
第三个按钮,使用setDefault(方法来设置按钮的默认状态。设置的快捷键“ALT+D”,可以使用快捷键来调用槽函数。
第四个按钮,使用setEnable()方法来禁用。
3. QRadioButton
QRadioButton类继承自QAbstractButton类,它提供了一组可供选择的按钮和文本标签,用户可以选择其中一个选项,标签用于显示对应的文本信息。单选钮是一种开关按钮,可以切换为on或者off,即checked或者unchecked,主要是为用户提供“多选一”的选择。
QRadioButton是单选钮控件默认是独占的(Exclusive)。对于继承自同一个父类Widget的多个单选钮,它们属于同一个按钮组合,在单选钮组里,一次只能选择一个单选钮。如果需要多个独占的按钮组合,则需要将它们放在QGroupBox或OButtonGroup 中。
当将单选钮切换到on或者off时,就会发送 toggled 信号,绑定这个信号,在按钮状态发生改变时,触发相应的行为。
ORadioButton类中的常用方法如表4所示。

在QRadioButton中,toggled信号是在切换单选钮状态(开、关)时发射的,而clicked信号则在每次点击单选钮时都会发射。在实际中,一般只有状态改变时才有必要去响应,因此toggled信号更适合用于状态监控。
实例演示2:QRadioButton按钮的使用
运行程序,显示效果如下:

代码分析:
在这个例子中,两个互斥的单选钮被放置在窗口中。第1个单选钮 btnl,被设置成默认选中状态。
当选择两个按钮相互切换时,按钮的状态发生改变,将触发toggle信号,并与槽函数btnstate()连接。使用 lambda的方式允许将源信号传递给槽函数,将按钮作为参数。
当发射toggled信号后,使用btnstate()函数来检查按钮的状态。
4. QCheckBox
QCheckBox类继承自QAbstractButton类,它提供了一组带文本标签的复选框,用户可以选择多个选项。和 QPushButton一样,复选框可以显示文本或者图标,其中文本可以通过构造函数或者 setText()来设置;图标可以通过 setlcon()来设置。在视觉上,QButtonGroup可以把许多复选框组织在一起。
OCheckBox(复选框)和QRadioButton(单选钮)都是选项按钮,因为它们都可以在开(选中)或者关(未选中)之间切换。它们的区别是对用户选择的限制:单选钮提供了“多选一”的选择;而复选框提供的是“多选多”的选择。
QCheckBox通常被应用在需要用户选择一个或多个可用的选项的场景中。
只要复选框被选中或者取消选中,都会发射一个 stateChanged信号。如果想在复选框状态改变时触发相应的行为,请连接这个信号,可以使用isChecked()来查询复选框是否被选中。
除了常用的选中和未选中两种状态,QCheckBox还提供了第三种状态(半选中)来表明“没有变化”。当需要为用户提供一个选中或者未选中复选框的选择时,这种状态是很有用的。如果需要第三种状态,则可以通过setTristate()来使它生效,并使用checkState(来查询当前的切换状态。
QCheckBox类中的常用方法如表5所示。

三态复选框有三种状态,如表6所示。

实例演示3:QCheckBox按钮的使用
运行程序,显示效果如下:

代码分析:
在这个例子中,将三个复选框添加到一个水平布局管理器中,并添加到一个QGroupBox组中。
将三个复选框的stateChanged信号都连接到槽函数stateChanged()。使用 lambda的方式传递对象给槽函数。
当QCheckBox状态改变时发射stateChanged信号,当信号发生改变时触发自定义的槽函数btnstate().
实例化checkBoxl和 checkBox2两个对象,并将checkBox1的状态设置为选中,为checkBox1设置快捷键,使用“&”符号,如“&Checkbox 1”,则通过“Alt+C"快捷键可以选中 checkBox1复选框。
使用按钮的isChecked()方法,判断复选框是否被选中,其核心代码是: