广告
返回顶部
首页 > 资讯 > 后端开发 > Python >PyQt5设置登录界面及界面美化的实现
  • 815
分享到

PyQt5设置登录界面及界面美化的实现

2024-04-02 19:04:59 815人浏览 独家记忆

Python 官方文档:入门教程 => 点击学习

摘要

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

写在前面

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

先上编译环境:

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

控件配置和美化

背景设置

首先咱们的登录界面一定要炫酷,这样才能彰(唬)显(得)技(住)术(人),找了半天,从身为资深程序媛的lp大人那里盗了张图,上一下博主最终的登录界面

在这里插入图片描述

打码了软件的名称和其他隐私信息,这样是不是有科技感了?虽然我觉得也不是很美观,但也还行吧,毕竟博主可不是搞美工设计的。
那来讲讲这个界面是怎么做出来的。

背景元素添加

最初图片上啥都没有,就是一张纯粹的图片,上面的文字可以在PyQt5中通过代码来添加,不过博主推荐使用一种最快捷的处理方式——PS,甚至都不用PS,博主用的是工科生写论文必备软件——visio,如下

在这里插入图片描述

这样,我在背景图片上添加了最上面的那行字,还有中间添加了一个半透明的蒙版,以及下面的一行英文。
看看原来的背景图

在这里插入图片描述

这样省去了很多工作。

登录界面的类和方法

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


class logindialog(QDialog):
  def __init__(self, *args, **kwargs):
    super().__init__(*args, **kwargs)
    self.setWindowTitle('XXXXXXX')
    self.setWindowIcon(QIcon('wheel.ico'))
    self.resize(1920, 1080)
    # self.setFixedSize(self.width(), self.height())
    self.setWindowFlags(Qt.WindowMinimizeButtonHint | Qt.WindowMaximizeButtonHint | Qt.WindowCloseButtonHint)

    palette = QPalette()
    palette.setBrush(QPalette.Background, QBrush(QPixmap('background3.jpg')))
    self.setPalette(palette)

    # 设置界面控件

    self.frame = QFrame(self)
    self.frame.move(800, 300)
    # self.verticalLayout = QVBoxLayout(self.frame)
    self.mainLayout = QVBoxLayout(self.frame)

    # self.nameLb1 = QLabel('&Name', self)
    # self.nameLb1.setFont(QFont('Times', 24))
    self.nameEd1 = QLineEdit(self)
    self.nameEd1.setPlaceholderText("Account")
    self.nameEd1.setFont(QFont('Arial', 24))
    # 设置透明度
    op1 = QGraphicsOpacityEffect()
    op1.setOpacity(0.5)
    self.nameEd1.setGraphicsEffect(op1)
    # 设置文本框为圆角
    self.nameEd1.setStyleSheet('''QLineEdit{border-radius:5px;}''')
    # self.nameLb1.setBuddy(self.nameEd1)

    # self.nameLb2 = QLabel('&PassWord', self)
    # self.nameLb2.setFont(QFont('Times', 24))
    self.nameEd2 = QLineEdit(self)
    self.nameEd2.setPlaceholderText("Admin")
    self.nameEd2.setFont(QFont('Arial', 24))
    op2 = QGraphicsOpacityEffect()
    op2.setOpacity(0.5)
    self.nameEd2.setGraphicsEffect(op2)
    self.nameEd2.setStyleSheet('''QLineEdit{border-radius:5px;}''')
    # self.nameLb2.setBuddy(self.nameEd2)

    self.nameEd3 = QLineEdit(self)
    self.nameEd3.setPlaceholderText("Password")
    self.nameEd3.setFont(QFont('Arial', 24))
    op5 = QGraphicsOpacityEffect()
    op5.setOpacity(0.5)
    self.nameEd3.setGraphicsEffect(op5)
    self.nameEd3.setStyleSheet('''QLineEdit{border-radius:5px;}''')

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

    self.btnCancel = QPushButton('Cancel')
    op4 = QGraphicsOpacityEffect()
    op4.setOpacity(0.5)
    self.btnCancel.setGraphicsEffect(op4)
    self.btnCancel.setStyleSheet(
      '''QPushButton{background:#1E90FF;border-radius:5px;}QPushButton:hover{background:#4169E1;}\
      QPushButton{font-family:'Arial';color:#FFFFFF;}''')

    self.btnOK.setFont(QFont('Microsoft YaHei', 24))
    self.btnCancel.setFont(QFont('Microsoft YaHei', 24))

    # self.mainLayout.addWidget(self.nameLb1, 0, 0)
    self.mainLayout.addWidget(self.nameEd1)

    # self.mainLayout.addWidget(self.nameLb2, 1, 0)
    self.mainLayout.addWidget(self.nameEd2)

    self.mainLayout.addWidget(self.nameEd3)

    self.mainLayout.addWidget(self.btnOK)
    self.mainLayout.addWidget(self.btnCancel)

    self.mainLayout.setSpacing(60)

    '''
    self.lineEdit_account = QLineEdit()
    self.lineEdit_account.setPlaceholderText("请输入账号")
    # self.lineEdit_account.move(900, 540)
    self.verticalLayout.addWidget(self.lineEdit_account)

    self.lineEdit_password = QLineEdit()
    self.lineEdit_password.setPlaceholderText("请输入密码")
    self.verticalLayout.addWidget(self.lineEdit_password)

    self.pushButton_enter = QPushButton()
    self.pushButton_enter.setText("确定")
    self.verticalLayout.addWidget(self.pushButton_enter)

    self.pushButton_quit = QPushButton()
    self.pushButton_quit.setText("取消")
    self.verticalLayout.addWidget(self.pushButton_quit)
    '''

    ###### 绑定按钮事件
    self.btnOK.clicked.connect(self.on_pushButton_enter_clicked)
    self.btnCancel.clicked.connect(QCoreApplication.instance().quit)

  def on_pushButton_enter_clicked(self):
    # 账号判断
    if self.nameEd1.text() == "":
      return

    # 权限判断
    if self.nameEd2.text() == "":
      return

    # 密码判断
    if self.nameEd3.text() == "":
      return

    # 通过验证,关闭对话框并返回1
    self.accept()

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

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

		self.setWindowTitle('XXXXXXX')
    self.setWindowIcon(QIcon('wheel.ico'))
    self.resize(1920, 1080)

self.setWindowFlags(Qt.WindowMinimizeButtonHint | Qt.WindowMaximizeButtonHint | Qt.WindowCloseButtonHint)这行代码在界面顶端设置了最小化、最大化和关闭点击事件,如下:

在这里插入图片描述

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


		palette = QPalette()
    palette.setBrush(QPalette.Background, QBrush(QPixmap('background3.jpg')))
    self.setPalette(palette)

下面进入界面的控件设置环节:

从我上面的那张整体图来看,应该是有3个文本输入框,分别是账号、权限、密码,以及两个按钮,分别是确认和取消按钮,采用的布局是垂直布局,如果对PyQt5布局还有困惑的,可以去看我我之前的博客——PyQt5的相对布局管理。


self.frame = QFrame(self)
self.frame.move(800, 300)

在设置垂直布局前,我先新建了一个QFrame,这个玩意儿很有用,我通过它,把我的垂直布局组合在一起,然后去设置它的形状、线条等。我通过move函数把它移动到窗口的中间来。

然后就建立一个垂直布局窗口:self.mainLayout = QVBoxLayout(self.frame)

后面就是为这个垂直布局窗口添加控件了,由于控件都差不多,我先重点介绍第一个控件。


    self.nameEd1 = QLineEdit(self)
    self.nameEd1.setPlaceholderText("Account")
    self.nameEd1.setFont(QFont('Arial', 24))
    # 设置透明度
    op1 = QGraphicsOpacityEffect()
    op1.setOpacity(0.5)
    self.nameEd1.setGraphicsEffect(op1)
    # 设置文本框为圆角
    self.nameEd1.setStyleSheet('''QLineEdit{border-radius:5px;}''')
    # 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;}'''),我把文本框修改为圆角的了,里面还有很多参数可以修改,比如颜色,字体等等。

下面再来看看我对按钮控件的修改和美化:


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

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

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


    self.btnOK.clicked.connect(self.on_pushButton_enter_clicked)
    self.btnCancel.clicked.connect(QCoreApplication.instance().quit)

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


  def on_pushButton_enter_clicked(self):
    # 账号判断
    if self.nameEd1.text() == "":
      return

    # 权限判断
    if self.nameEd2.text() == "":
      return

    # 密码判断
    if self.nameEd3.text() == "":
      return

    # 通过验证,关闭对话框并返回1
    self.accept()

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

功能实现

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


if __name__ == '__main__':
  app = QApplication(sys.argv)
  dialog = logindialog()
  if dialog.exec_() == QDialog.Accepted:
    demo = Demo()
    demo.show()
    sys.exit(app.exec_())

首先,实例logindialog类,当对象返回接受时,就进入你的主界面了,然后你就实例化你的软件主体类。
开始愉快的玩耍吧~~

Mark一下陪伴我一路完成我整个项目开发、我最心爱的电脑~~

在这里插入图片描述

写在后面

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

到此这篇关于PyQt5设置登录界面及界面美化的实现的文章就介绍到这了,更多相关PyQt5设置登录界面内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: PyQt5设置登录界面及界面美化的实现

本文链接: https://www.lsjlt.com/news/121657.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • PyQt5设置登录界面及界面美化的实现
    写在前面 前一段时间博主刷了半个多月的LeetCode算法题,刷的归类为简单的那些题,做到自己简直要怀疑人生。想着人生在世,何苦这么为难自己呢,何不做点自己擅长的东西。想到博主还有个...
    99+
    2022-11-11
  • PyQt5如何设置登录界面及界面美化功能
    这篇文章主要介绍“PyQt5如何设置登录界面及界面美化功能”,在日常操作中,相信很多人在PyQt5如何设置登录界面及界面美化功能问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”PyQt5如何设置登录界面及界面美...
    99+
    2023-06-14
  • PyQt5实现用户登录GUI界面及登录后跳转
    PyQt5是强大的GUI工具之一,通过其可以实现优秀的桌面应用程序。希望通过一个简单的登录页面可以让大家顺利入坑,如有不妥之处还请大佬指点改正! 导入业务需要的所有的扩展包。 ...
    99+
    2022-11-12
  • PyQt5怎么实现用户登录GUI界面及登录后跳转
    这篇文章主要讲解了“PyQt5怎么实现用户登录GUI界面及登录后跳转”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“PyQt5怎么实现用户登录GUI界面及登录后跳转”吧!导入业务需要的所有的扩...
    99+
    2023-06-25
  • python通过PyQt5实现登录界面的示例代码
    目录1. pyQt5简单使用 安装 界面化操作 2.开始实现登录界面今天为大家介绍一个利用开发登录界面模板,基于pyqt5库,pyqt5这也一个PythonGUI界面开发的库,非常强...
    99+
    2022-11-12
  • android实现简易登录注册界面及逻辑设计
    本文实例为大家分享了android实现登录注册界面及逻辑设计,供大家参考,具体内容如下 1. 第一步 新建文件(相信各位码农一定会这一步)略。 2. 第二步 登录注册界面设计 登录界...
    99+
    2022-11-12
  • Android实现简洁的APP登录界面
    今天需求要做一个所有app都有的登录界面,正好巩固一下我们之前学的基础布局知识。 先来看下效果图 1.布局的xml文件 <?xml version="1.0...
    99+
    2022-06-06
    界面 app Android
  • 用Shell脚本美化登录界面装饰图的方法
    本篇内容介绍了“用Shell脚本美化登录界面装饰图的方法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!脚本1:cat clcal.sh#!/...
    99+
    2023-06-09
  • 如何实现漂亮的Qt 登录界面
    本篇文章为大家展示了如何实现漂亮的Qt 登录界面,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。前言最近在使用Qt5,Qt Creator做一个管理系统类的项目,自然需要用到登录界面,故记录...
    99+
    2023-06-21
  • Android登录界面的实现代码分享
    最近由于项目需要,宝宝好久没搞Android啦,又是因为项目需要,现在继续弄Android,哎,说多了都是泪呀,别的不用多说,先搞一个登录界面练练手,登录界面可以说是Andro...
    99+
    2022-06-06
    界面 Android
  • Android实现登录界面的注册功能
    本文实例为大家分享了Android登录界面的注册实现代码,供大家参考,具体内容如下 注册一个登录界面在控制台将输入的信息文本选框展示出来 xml界面设计(前面已发) <xml ...
    99+
    2022-11-13
  • 腾讯云服务器图形化界面设置密码登录
    1. 登录腾讯云控制台 首先,打开浏览器,访问腾讯云官方网站(https://cloud.tencent.com/)。在页面右上角点击"登录"按钮,输入您的账号和密码,然后点击"登录"。 2. 进入云服务器控制台 成功登录后,您将进入腾讯...
    99+
    2023-10-28
    腾讯 图形化 界面
  • Android开发实例之登录界面的实现
    本文要演示的Android开发实例是如何完成一个Android中的miniTwitter登录界面,下面将分步骤讲解怎样实现图中的界面效果,让大家都能轻松的做出美观的登录界面。 ...
    99+
    2022-06-06
    界面 android开发 Android
  • 华为云服务器登录界面怎么设置的
    华为云服务器登录界面设置需要使用用户名和密码进行登录,以下是具体步骤: 在华为云服务器页面的“登录设置”中找到“安全设置”按钮,点击进入。 在安全设置页面中,找到“密码安全性”选项,点击进入。 在密码安全性页面中,我们可以设置一些用户名...
    99+
    2023-10-26
    华为 界面 服务器
  • Windows8修改登录界面DPI设置默认的96 DPI
    近年来随着显示器技术的发展,屏幕的分辨率在不断地提升,1920x1080分辨率的显示器也开始成为一般设备了。不过 Windows 系统的默认 DPI 还停留在 96 DPI ,这在高分辨率的显示器下面查看文字效...
    99+
    2023-06-06
    Windows8 登录界面 DPI 界面 96
  • Android studio 学习2:实现密码登录界面和验证码登录界面的切换(在同一xml页面)
    Android studio :实现密码登录界面和验证码登录界面的切换(不用新建xml页面) 一、了解Xml设置隐藏属性 android:vis...
    99+
    2022-06-06
    Android Studio XML studio 界面 学习 验证码 Android
  • C#WinForm制作登录界面的实现步骤
    在【解决方案资源管理器】中找到Form1.cs,单击,快捷键F2重命名为“Login.cs”(命名很重要,不然之后项目多了根据不知道哪个项目的内容是什么) ...
    99+
    2022-11-13
  • java实现简单登录界面的实战过程
    目录一、概要二、分类部分三、代码实现总结一、概要 我们可以用java实现简单的登录界面。 如上效果,直观但也需要一步一步来完成,从界面弹窗的设置,图片的插入,文本框的设置,到登录的...
    99+
    2022-11-13
  • 华为云服务器登录界面怎么设置的呢
    华为云服务器登录界面设置需要使用一个华为云服务器的账户和密码,以下是具体步骤和设置方法: 打开华为云服务器控制台:选择“账户”下拉菜单,然后选择“管理”选项卡,然后选择“登录选项”下拉菜单。 配置账户和密码:使用华为云服务器管理员账户登...
    99+
    2023-10-26
    华为 界面 服务器
  • 轻量应用服务器登录界面怎么设置的
    轻量应用服务器登录界面的设置可能涉及以下几个方面: 安全性:在登录界面中,应用服务器应该使用多种身份验证和访问控制机制,保护用户和应用程序。应用服务器应该使用强密码、数据加密、反向代理等技术来保护用户数据的安全性。 用户验证:轻量应用服...
    99+
    2023-10-26
    界面 服务器
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作