PyQt5设置登录界面及界面美化

r囧r小猫 2022-12-20 12:43 602阅读 0赞

写在前面

前一段时间博主刷了半个多月的LeetCode算法题,刷的归类为简单的那些题,做到自己简直要怀疑人生。想着人生在世,何苦这么为难自己呢,何不做点自己擅长的东西。想到博主还有个项目没做完呢,于是开始捣鼓起来。项目的最终成果是要写一个软件,把所有研究的内容可视化的展示出来,研究的内容都写的差不多了,还差个登录界面,于是就开始元气满满的干起来。
先上编译环境:

  • Python3.7
  • pycharm2020专业版
  • PyQt5

博主习惯用Spyder做编译器,但如果做大项目,最好还是用pycharm,不然总会遇到各种问题,让人头大,况且pycharm的代码填充简直不要太香。
好了,进入正题。

控件配置和美化

背景设置

首先咱们的登录界面一定要炫酷,这样才能彰(唬)显(得)技(住)术(人),找了半天,从身为资深程序媛的lp大人那里盗了张图,上一下博主最终的登录界面
在这里插入图片描述
打码了软件的名称和其他隐私信息,这样是不是有科技感了?虽然我觉得也不是很美观,但也还行吧,毕竟博主可不是搞美工设计的。
那来讲讲这个界面是怎么做出来的。

背景元素添加

最初图片上啥都没有,就是一张纯粹的图片,上面的文字可以在PyQt5中通过代码来添加,不过博主推荐使用一种最快捷的处理方式——PS,甚至都不用PS,博主用的是工科生写论文必备软件——visio,如下
在这里插入图片描述
这样,我在背景图片上添加了最上面的那行字,还有中间添加了一个半透明的蒙版,以及下面的一行英文。
看看原来的背景图
在这里插入图片描述
这样省去了很多工作。

登录界面的类和方法

我先上代码,再慢慢解释。

  1. class logindialog(QDialog):
  2. def __init__(self, *args, **kwargs):
  3. super().__init__(*args, **kwargs)
  4. self.setWindowTitle('XXXXXXX')
  5. self.setWindowIcon(QIcon('wheel.ico'))
  6. self.resize(1920, 1080)
  7. # self.setFixedSize(self.width(), self.height())
  8. self.setWindowFlags(Qt.WindowMinimizeButtonHint | Qt.WindowMaximizeButtonHint | Qt.WindowCloseButtonHint)
  9. palette = QPalette()
  10. palette.setBrush(QPalette.Background, QBrush(QPixmap('background3.jpg')))
  11. self.setPalette(palette)
  12. # 设置界面控件
  13. self.frame = QFrame(self)
  14. self.frame.move(800, 300)
  15. # self.verticalLayout = QVBoxLayout(self.frame)
  16. self.mainLayout = QVBoxLayout(self.frame)
  17. # self.nameLb1 = QLabel('&Name', self)
  18. # self.nameLb1.setFont(QFont('Times', 24))
  19. self.nameEd1 = QLineEdit(self)
  20. self.nameEd1.setPlaceholderText("Account")
  21. self.nameEd1.setFont(QFont('Arial', 24))
  22. # 设置透明度
  23. op1 = QGraphicsOpacityEffect()
  24. op1.setOpacity(0.5)
  25. self.nameEd1.setGraphicsEffect(op1)
  26. # 设置文本框为圆角
  27. self.nameEd1.setStyleSheet('''QLineEdit{border-radius:5px;}''')
  28. # self.nameLb1.setBuddy(self.nameEd1)
  29. # self.nameLb2 = QLabel('&Password', self)
  30. # self.nameLb2.setFont(QFont('Times', 24))
  31. self.nameEd2 = QLineEdit(self)
  32. self.nameEd2.setPlaceholderText("Admin")
  33. self.nameEd2.setFont(QFont('Arial', 24))
  34. op2 = QGraphicsOpacityEffect()
  35. op2.setOpacity(0.5)
  36. self.nameEd2.setGraphicsEffect(op2)
  37. self.nameEd2.setStyleSheet('''QLineEdit{border-radius:5px;}''')
  38. # self.nameLb2.setBuddy(self.nameEd2)
  39. self.nameEd3 = QLineEdit(self)
  40. self.nameEd3.setPlaceholderText("Password")
  41. self.nameEd3.setFont(QFont('Arial', 24))
  42. op5 = QGraphicsOpacityEffect()
  43. op5.setOpacity(0.5)
  44. self.nameEd3.setGraphicsEffect(op5)
  45. self.nameEd3.setStyleSheet('''QLineEdit{border-radius:5px;}''')
  46. self.btnOK = QPushButton('OK')
  47. op3 = QGraphicsOpacityEffect()
  48. op3.setOpacity(0.5)
  49. self.btnOK.setGraphicsEffect(op3)
  50. self.btnOK.setStyleSheet(
  51. '''QPushButton{background:#1E90FF;border-radius:5px;}QPushButton:hover{background:#4169E1;}\
  52. QPushButton{font-family:'Arial';color:#FFFFFF;}''') # font-family中可以设置字体大小,如下font-size:24px;
  53. self.btnCancel = QPushButton('Cancel')
  54. op4 = QGraphicsOpacityEffect()
  55. op4.setOpacity(0.5)
  56. self.btnCancel.setGraphicsEffect(op4)
  57. self.btnCancel.setStyleSheet(
  58. '''QPushButton{background:#1E90FF;border-radius:5px;}QPushButton:hover{background:#4169E1;}\
  59. QPushButton{font-family:'Arial';color:#FFFFFF;}''')
  60. self.btnOK.setFont(QFont('Microsoft YaHei', 24))
  61. self.btnCancel.setFont(QFont('Microsoft YaHei', 24))
  62. # self.mainLayout.addWidget(self.nameLb1, 0, 0)
  63. self.mainLayout.addWidget(self.nameEd1)
  64. # self.mainLayout.addWidget(self.nameLb2, 1, 0)
  65. self.mainLayout.addWidget(self.nameEd2)
  66. self.mainLayout.addWidget(self.nameEd3)
  67. self.mainLayout.addWidget(self.btnOK)
  68. self.mainLayout.addWidget(self.btnCancel)
  69. self.mainLayout.setSpacing(60)
  70. '''
  71. self.lineEdit_account = QLineEdit()
  72. self.lineEdit_account.setPlaceholderText("请输入账号")
  73. # self.lineEdit_account.move(900, 540)
  74. self.verticalLayout.addWidget(self.lineEdit_account)
  75. self.lineEdit_password = QLineEdit()
  76. self.lineEdit_password.setPlaceholderText("请输入密码")
  77. self.verticalLayout.addWidget(self.lineEdit_password)
  78. self.pushButton_enter = QPushButton()
  79. self.pushButton_enter.setText("确定")
  80. self.verticalLayout.addWidget(self.pushButton_enter)
  81. self.pushButton_quit = QPushButton()
  82. self.pushButton_quit.setText("取消")
  83. self.verticalLayout.addWidget(self.pushButton_quit)
  84. '''
  85. ###### 绑定按钮事件
  86. self.btnOK.clicked.connect(self.on_pushButton_enter_clicked)
  87. self.btnCancel.clicked.connect(QCoreApplication.instance().quit)
  88. def on_pushButton_enter_clicked(self):
  89. # 账号判断
  90. if self.nameEd1.text() == "":
  91. return
  92. # 权限判断
  93. if self.nameEd2.text() == "":
  94. return
  95. # 密码判断
  96. if self.nameEd3.text() == "":
  97. return
  98. # 通过验证,关闭对话框并返回1
  99. self.accept()

博主默认读者对PyQt5有一定的了解,导包过程不再赘述。下面开始讲代码

  1. 第一行代码,建立一个类,这个类使用的是PyQt5中的QDialog也就是对话框;
  2. __init__是初始化方法,为了更好去理解,我没有再去写更多其他的方法,所有的设置按钮,文本输入框,都在这里进行;
  3. 下面这几行代码分别表示设置界面名称、图标和大小;

    self.setWindowTitle(‘XXXXXXX’)

    1. self.setWindowIcon(QIcon('wheel.ico'))
    2. self.resize(1920, 1080)
  4. self.setWindowFlags(Qt.WindowMinimizeButtonHint | Qt.WindowMaximizeButtonHint | Qt.WindowCloseButtonHint)这行代码在界面顶端设置了最小化、最大化和关闭点击事件,如下:在这里插入图片描述

  5. 下面这三行代码挺关键,就是把咱前面设计好的背景图设为登录界面的背景,用QPalette方法;

    palette = QPalette()

    1. palette.setBrush(QPalette.Background, QBrush(QPixmap('background3.jpg')))
    2. self.setPalette(palette)
  6. 下面进入界面的控件设置环节:
    从我上面的那张整体图来看,应该是有3个文本输入框,分别是账号、权限、密码,以及两个按钮,分别是确认和取消按钮,采用的布局是垂直布局,如果对PyQt5布局还有困惑的,可以去看我我之前的博客——PyQt5的相对布局管理。

    self.frame = QFrame(self)

    1. self.frame.move(800, 300)

在设置垂直布局前,我先新建了一个QFrame,这个玩意儿很有用,我通过它,把我的垂直布局组合在一起,然后去设置它的形状、线条等。我通过move函数把它移动到窗口的中间来。
然后就建立一个垂直布局窗口:self.mainLayout = QVBoxLayout(self.frame)
后面就是为这个垂直布局窗口添加控件了,由于控件都差不多,我先重点介绍第一个控件。

  1. self.nameEd1 = QLineEdit(self)
  2. self.nameEd1.setPlaceholderText("Account")
  3. self.nameEd1.setFont(QFont('Arial', 24))
  4. # 设置透明度
  5. op1 = QGraphicsOpacityEffect()
  6. op1.setOpacity(0.5)
  7. self.nameEd1.setGraphicsEffect(op1)
  8. # 设置文本框为圆角
  9. self.nameEd1.setStyleSheet('''QLineEdit{border-radius:5px;}''')
  10. # self.nameLb1.setBuddy(self.nameEd1)

用setPlaceholderText函数来设置文本框里面的提示内容self.nameEd1.setPlaceholderText("Account")
然后为这个文本框设置字体和大小self.nameEd1.setFont(QFont('Arial', 24))
后面self.nameEd1.setGraphicsEffect(op1)是设置这个控件的透明度,主要是为了美观,注意,我每设置一个控件就定义了一个变量来设置透明度,如果我只设置一个的话,那它修改的只是最后一个控件的透明度。这里不注意很容易搞错。
接下来我用QSS来美化文本框,就这行代码self.nameEd1.setStyleSheet('''QLineEdit{border-radius:5px;}'''),我把文本框修改为圆角的了,里面还有很多参数可以修改,比如颜色,字体等等。
下面再来看看我对按钮控件的修改和美化:

  1. self.btnOK = QPushButton('OK')
  2. op3 = QGraphicsOpacityEffect()
  3. op3.setOpacity(0.5)
  4. self.btnOK.setGraphicsEffect(op3)
  5. self.btnOK.setStyleSheet(
  6. '''QPushButton{background:#1E90FF;border-radius:5px;}QPushButton:hover{background:#4169E1;}\
  7. QPushButton{font-family:'Arial';color:#FFFFFF;}''') # font-family中可以设置字体大小,如下font-size:24px;

同样设置透明度,然后QSS里面设置的东西就更复杂了,background是按钮背景颜色,QPushButton:hover是指当鼠标滑动到按钮上市按钮显示的颜色。
后面类似self.mainLayout.addWidget(self.nameEd1)这样的代码,就是把控件添加到布局里面去了,不多说了。

  1. 控件都添加完了,下面是最重要的一步,为你的OK按钮添加回调函数,看下面代码:

    self.btnOK.clicked.connect(self.on_pushButton_enter_clicked)

    1. self.btnCancel.clicked.connect(QCoreApplication.instance().quit)

第一行是为OK按钮添加了一个槽函数,函数名是on_pushButton_enter_clicked,我们来看看这个函数是啥样的:

  1. def on_pushButton_enter_clicked(self):
  2. # 账号判断
  3. if self.nameEd1.text() == "":
  4. return
  5. # 权限判断
  6. if self.nameEd2.text() == "":
  7. return
  8. # 密码判断
  9. if self.nameEd3.text() == "":
  10. return
  11. # 通过验证,关闭对话框并返回1
  12. self.accept()

这里写的很简单,账号密码随便填,只要不是空就行了
第二行代码是将cancel按钮链接到QT内置的退出槽函数。
好了,主体功能写完了。

功能实现

其实就是写main函数了
看看我的代码:

  1. if __name__ == '__main__':
  2. app = QApplication(sys.argv)
  3. dialog = logindialog()
  4. if dialog.exec_() == QDialog.Accepted:
  5. demo = Demo()
  6. demo.show()
  7. sys.exit(app.exec_())

首先,实例logindialog类,当对象返回接受时,就进入你的主界面了,然后你就实例化你的软件主体类。
开始愉快的玩耍吧~~
Mark一下陪伴我一路完成我整个项目开发、我最心爱的电脑~~
在这里插入图片描述

写在后面

感觉博客写起来简单,但具体实现过程却是很麻烦的,主要是Qt开发也还不是很熟练,总之对菜鸟来说,来自C++的东西,都不是很友好,只有熟练了各个函数后,才能写好。Qt开发其实相当牛逼的,感觉在界面上很棒。
最后的最后,算法题也还是要刷的,加油~~

发表评论

表情:
评论列表 (有 0 条评论,602人围观)

还没有评论,来说两句吧...

相关阅读

    相关 C#--winform界面美化

    1、界面的美化 一般的工控界面分成三部分: (1)、标题菜单部分,即项目名称、界面菜单等 (2)、数据显示及按钮等部分,即图形显示区,可以显示工艺流程图,采集到的相关

    相关 PyQt5设置登录界面界面美化

    写在前面 前一段时间博主刷了半个多月的LeetCode算法题,刷的归类为简单的那些题,做到自己简直要怀疑人生。想着人生在世,何苦这么为难自己呢,何不做点自己擅长的东西。想