【QTdesigner】课时39.复选框控件(QCheckBox)【pyqt5+QTdesigner模式】

** >>> 点击进入:pyqt5专栏<<<**

老师原课件下载地址:
有积分的朋友,支持下我,打赏也OK。
不下载也可以,我每节课会吧代码贴出来


视频链接

P38课时39.复选框控件(QCheckBox)


课程重点

在这里插入图片描述


代码位置

在这里插入图片描述


完整代码

'''

复选框控件(QCheckBox)

3种状态

未选中:0

半选中:1

选中:2

'''

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

class QCheckBoxDemo(QWidget):
    def __init__(self):
        super(QCheckBoxDemo,self).__init__()
        self.initUI()

    def initUI(self):
        self.setWindowTitle('复选框控件演示')

        layout = QHBoxLayout()

        self.checkBox1 = QCheckBox('复选框控件1')
        self.checkBox1.setChecked(True)
        self.checkBox1.stateChanged.connect(lambda:self.checkboxState(self.checkBox1))
        layout.addWidget(self.checkBox1)

        self.checkBox2 = QCheckBox('复选框控件2')
        self.checkBox2.stateChanged.connect(lambda:self.checkboxState(self.checkBox2))
        layout.addWidget(self.checkBox2)

        self.checkBox3 = QCheckBox('半选中')
        self.checkBox3.stateChanged.connect(lambda:self.checkboxState(self.checkBox3))
        self.checkBox3.setTristate(True)
        self.checkBox3.setCheckState(Qt.PartiallyChecked)
        layout.addWidget(self.checkBox3)

        self.setLayout(layout)

    def checkboxState(self,cb):
        check1Status = self.checkBox1.text() + ', isChecked=' + str(self.checkBox1.isChecked()) + ',checkState=' + str(self.checkBox1.checkState()) + '\n'
        check2Status = self.checkBox2.text() + ', isChecked=' + str(self.checkBox2.isChecked()) + ',checkState=' + str(self.checkBox2.checkState()) + '\n'
        check3Status = self.checkBox3.text() + ', isChecked=' + str(self.checkBox3.isChecked()) + ',checkState=' + str(self.checkBox3.checkState()) + '\n'
        print(check1Status + check2Status + check3Status)



if __name__ == '__main__':
    app = QApplication(sys.argv)
    main = QCheckBoxDemo()
    main.show()
    sys.exit(app.exec_())

遇到的问题


改写效果展示


改写注意点

 self.checkBox3.setCheckState(Qt.PartiallyChecked)

在这里插入图片描述

这里连接的时候必须增加lambda,因为传参了就不是一个函数调用了,所以需要用不带参的lambda封装成无名函数。

self.ui.checkBox1.stateChanged.connect(lambda :self.checkboxState(self.ui.checkBox1))

在这里插入图片描述

老师这里定义的传参貌似没有调用,我修改了下,可以起作用了:
在这里插入图片描述


改写代码(QTdesigner模式)

# -*- coding:utf-8 -*-
'''
@Author: knocky
@Blog: https://blog.csdn.net/zzx188891020
@E-mail: 188891020@qq.com
@File: class_X.py
@CreateTime: 2020/5/11 23:36
'''

import sys
from PyQt5.QtWidgets import QApplication
from PyQt5 import uic


class my_form():
    def __init__(self):
        super().__init__()
        self.ui = uic.loadUi("../ui_package/class39.ui")
        self.ui.checkBox1.stateChanged.connect(lambda :self.checkboxState(self.ui.checkBox1))
        self.ui.checkBox2.stateChanged.connect(lambda :self.checkboxState(self.ui.checkBox2))
        self.ui.checkBox3.stateChanged.connect(lambda :self.checkboxState(self.ui.checkBox3))

    def checkboxState(self,cb):
        list_status= cb.text() + ', isChecked=' + str(cb.isChecked()) + ',checkState=' + str(cb.checkState())
        print(list_status)

if __name__ == '__main__':
    app = QApplication(sys.argv)
    main = my_form()
    main.ui.show()
    sys.exit(app.exec_())

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Qt Designer是一个可视化IDE,可以用于创建和编辑PyQt5应用程序的用户界面。以下是一些常见控件的使用方法: 1. QLabel控件 QLabel控件可以显示文本和图像。在Qt Designer中,您可以使用“Label”工具栏按钮将其添加到窗体中。然后,您可以在属性编辑器中设置文本和图像。 2. QPushButton控件 QPushButton控件是一个按钮控件,可以在用户单击时触发操作。在Qt Designer中,您可以使用“Push Button”工具栏按钮将其添加到窗体中。然后,您可以在属性编辑器中设置按钮的文本和操作。 3. QLineEdit控件 QLineEdit控件是一个单行文本框控件,可以用于输入文本。在Qt Designer中,您可以使用“Line Edit”工具栏按钮将其添加到窗体中。然后,您可以在属性编辑器中设置文本框的默认文本和其他属性。 4. QComboBox控件 QComboBox控件是一个下拉列表框控件,可以用于选择一个选项。在Qt Designer中,您可以使用“Combo Box”工具栏按钮将其添加到窗体中。然后,您可以在属性编辑器中设置下拉列表框的选项。 5. QCheckBox控件 QCheckBox控件是一个复选框控件,可以用于选择一个或多个选项。在Qt Designer中,您可以使用“Check Box”工具栏按钮将其添加到窗体中。然后,您可以在属性编辑器中设置复选框的文本和默认状态。 6. QRadioButton控件 QRadioButton控件是一个单选按钮控件,可以用于选择一个选项。在Qt Designer中,您可以使用“Radio Button”工具栏按钮将其添加到窗体中。然后,您可以在属性编辑器中设置单选按钮的文本和默认状态。 这些是一些常见的控件。在Qt Designer中,您可以使用其他工具栏按钮添加其他控件,并使用属性编辑器设置它们的属性。在添加控件之后,您可以使用“Preview”按钮预览窗体,并在需要时进行调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值