PyQT笔记1-Designer

Button样式

选择Button,在styleSheet样式里设置相关属性

#注释
QPushButton {                                 # 这是按钮原本的原色
	background-color: rgb(194, 80, 28);
	font: 16pt "楷体";
	border-radius:12px;	                 # 这是边框加了弧度
}

QPushButton:hover {                        #当鼠标靠近按钮时设置颜色
	background-color: rgb(85, 255, 127);	
	border-radius:12px
}
QPushButton:pressed {                     # 当鼠标点击后又设置一种颜色
	background-color:rgb(255, 0, 0);	
	border-radius:12px
}

效果如下:
在这里插入图片描述

可能是由于录屏的原因,鼠标靠近按钮时,并未变色,实际没有录屏时,鼠标靠近是变绿色的。

给按钮设置监听

要先从控件编辑模式(Edit Widget) 点进监听模式(Edit sign/slot) 当中,然后拖拽按钮的信号至Form中,就可以创建connet链接了。 注意:在添加 button_test()监听函数后,返回上级菜单后,一定要再选中一下后点击’OK’。

在这里插入图片描述

UI 和 qrc都生成为python文件

为何避免每次用ui生成py文件时,不小心被覆盖,建议每次生成的python文件拖出至上级目录中,这样避免覆盖。另外,资源qrc也要通过pyrcc转为python文件,否则会找不到相应模块。
在这里插入图片描述

创建Live测试模板

在Live模板中,设置 $TITLE$ 可以指定光标定位的位置,将下面代码创建名为“qt”的模板。
注意: define 要记得选择 python后,点击确定。

from PyQt5.Qt import *

# 创建Window_child类,继承控件QWidge为父类
class Window_child(QWidget):
    def __init__(self):
        super().__init__()
        self.setupui()  # 自定义函数
        
    def setupui(self): 
        pass
        
if __name__ == '__main__':
    import sys
    app = QApplication(sys.argv)
    window = Window_child()
    # ------- 控件内容 ------ 开始

    # ------- 控件内容 ------ 结束
    window.show()
    sys.exit(app.exec_())  # 创建Qt消息循环队列,如果正常关闭,app.exex_()返回0,最终sys.exit-> code 0,表示正常退出。

在这里插入图片描述

Designer与Live模板关联,需要修改几处地方

  1. 首先要继承Ui_Form为父类,才能用相关方法,直接写到组件QWidget后面就可。
  2. 删掉自定义的方法,构造函数里引用Ui_Form的setupUi(self)方法,同时传入window对象。
  3. 要补充信号接收函数,已经链接了,但是接收函数需要自己定义相关操作:
    在这里插入图片描述
  4. 注意的是:
    运行时,发现背景图片没有显示,要在初始化,加上 self.setAttribute(Qt.WA_StyledBackground) 这一行,自定义控件只有设置该属性后才能正常设置背景。
    对于顶层窗口,在Designer中设置的背景样式表默认是不生效的,因此需要在顶层窗口的构造函数中显性设置属性:
    self.setAttribute(Qt.WA_StyledBackground, True)
    在这里插入图片描述
    整体代码如下:
from PyQt5.Qt import *
from resource_test import Ui_Form
# 创建Window_child类,继承控件QWidge为父类
class Window_child(QWidget, Ui_Form):
    def __init__(self):
        super().__init__()
        self.setAttribute(Qt.WA_StyledBackground, True)
        self.setupUi(self)

    def button_test(self):
        print('hell world')

if __name__ == '__main__':
    import sys
    app = QApplication(sys.argv)
    window = Window_child()
    # ------- 控件内容 ------ 开始

    # ------- 控件内容 ------ 结束
    window.show()
    sys.exit(app.exec_())  # 创建Qt消息循环队列,如果正常关闭,app.exex_()返回0,最终sys.exit-> code 0,表示正常退出。

执行效果如下:
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
PyQt5是一个Python绑定Qt库的工具包,可以用于创建桌面应用程序。Qt Designer是一个用于创建Qt界面的可视化工具,可以方便地创建GUI界面并导出为.ui文件。 要使用Qt Designer编写PyQt5界面,可以按照以下步骤进行操作: 1. 安装PyQt5和Qt Designer 如果你还没有安装PyQt5和Qt Designer,可以使用以下命令进行安装: ``` pip install PyQt5 pyqt5-tools ``` 2. 创建Qt Designer界面 打开Qt Designer,创建一个新的界面。 3. 设计界面 在Qt Designer中,你可以从工具箱中拖拽控件到界面中,设置控件的属性,布局等。 4. 保存界面 在Qt Designer中,选择“文件”->“保存”,将界面保存为.ui文件。 5. 将.ui文件转换为.py文件 使用以下命令将.ui文件转换为.py文件: ``` pyuic5 -o ui_filename.py ui_filename.ui ``` 其中,ui_filename是你的.ui文件名。这将生成一个.py文件,其中包含Qt Designer界面的Python代码。 6. 编写程序 在Python代码中导入生成的.py文件,然后使用它来创建GUI界面。 下面是一个简单的示例程序: ```python from PyQt5 import QtWidgets, uic class MainWindow(QtWidgets.QMainWindow): def __init__(self): super(MainWindow, self).__init__() # Load the ui file uic.loadUi('ui_filename.ui', self) if __name__ == '__main__': app = QtWidgets.QApplication([]) window = MainWindow() window.show() app.exec_() ``` 在此示例中,我们使用`uic.loadUi`方法将.ui文件加载到`MainWindow`类中,然后创建`QApplication`和`MainWindow`实例,并将窗口显示出来。 以上就是使用Qt Designer编写PyQt5界面的基本步骤。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值