校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > PyQt5設置登錄界面及界面美化的實現

PyQt5設置登錄界面及界面美化的實現

熱門標簽:如何在地圖標注文字 廈門crm外呼系統如何 百應ai電銷機器人鄭州 地圖標注推廣單頁 ai地圖標注 女王谷地圖標注 長春人工智能電銷機器人官網 n400電話申請多少錢 西藏快速地圖標注地點

寫在前面

前一段時間博主刷了半個多月的LeetCode算法題,刷的歸類為簡單的那些題,做到自己簡直要懷疑人生。想著人生在世,何苦這么為難自己呢,何不做點自己擅長的東西。想到博主還有個項目沒做完呢,于是開始搗鼓起來。項目的最終成果是要寫一個軟件,把所有研究的內容可視化的展示出來,研究的內容都寫的差不多了,還差個登錄界面,于是就開始元氣滿滿的干起來。

先上編譯環境:

  • Python3.7
  • pycharm2020專業版
  • PyQt5

博主習慣用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設置登錄界面內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • python通過PyQt5實現登錄界面的示例代碼
  • PyQt5實現登錄頁面
  • PyQt5+Caffe+Opencv搭建人臉識別登錄界面
  • pyqt5利用pyqtDesigner實現登錄界面
  • pyqt5實現登錄界面的模板
  • pyqt5制作登錄窗口的詳細過程

標簽:亳州 拉薩 渭南 黔東 興安盟 內江 廊坊 綿陽

巨人網絡通訊聲明:本文標題《PyQt5設置登錄界面及界面美化的實現》,本文關鍵詞  PyQt5,設置,登錄,界面,及,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PyQt5設置登錄界面及界面美化的實現》相關的同類信息!
  • 本頁收集關于PyQt5設置登錄界面及界面美化的實現的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    成人精品鲁一区一区二区| 欧美精三区欧美精三区| 欧美最猛黑人xxxxx猛交| 欧美一级高清大全免费观看| 国产精品丝袜黑色高跟| 青青草97国产精品免费观看| 色婷婷av一区二区三区软件| 久久免费看少妇高潮| 国产精品丝袜在线| 精品一区二区三区免费观看 | 91原创在线视频| 欧美一卡二卡在线| 亚洲激情图片qvod| 国产91丝袜在线18| 2023国产精华国产精品| 亚洲午夜视频在线观看| 99国产麻豆精品| 国产精品国产自产拍高清av | 99re这里只有精品首页| 久久久久久久网| 久久99精品久久只有精品| 欧美群妇大交群的观看方式| 亚洲理论在线观看| 成人黄色免费短视频| 欧美经典一区二区| 国产在线麻豆精品观看| 精品99一区二区| 日韩不卡一二三区| 欧美人妇做爰xxxⅹ性高电影 | 国产精品乱码妇女bbbb| 极品少妇一区二区三区精品视频| 制服丝袜国产精品| 日韩精品电影一区亚洲| 欧美精品高清视频| 日韩电影在线看| 欧美一级免费观看| 老司机午夜精品| 2022国产精品视频| 丁香婷婷深情五月亚洲| 亚洲国产激情av| av资源网一区| 亚洲影院在线观看| 欧美日本一区二区三区四区| 日本亚洲电影天堂| 精品成a人在线观看| 国产风韵犹存在线视精品| 国产精品人人做人人爽人人添 | 亚洲欧美在线视频观看| 99re热这里只有精品免费视频| 中文字幕精品综合| 色噜噜夜夜夜综合网| 午夜日韩在线观看| 欧美一级一级性生活免费录像| 日本91福利区| 久久女同性恋中文字幕| 99久久精品情趣| 亚洲一区二区在线视频| 欧美一区二区播放| 国产成人综合在线| 亚洲综合无码一区二区| 日韩视频国产视频| 高清在线成人网| 亚洲一区中文在线| 精品粉嫩超白一线天av| 成人国产精品免费| 亚欧色一区w666天堂| 精品国产乱码久久久久久夜甘婷婷| 国产传媒久久文化传媒| 亚洲一区二区三区四区在线免费观看 | 日韩欧美国产精品一区| av一区二区久久| 日日摸夜夜添夜夜添亚洲女人| 久久九九99视频| 欧美日韩国产一区二区三区地区| 国产自产v一区二区三区c| 一区二区三区在线观看国产 | 91精彩视频在线观看| 久久国产精品第一页| 亚洲视频香蕉人妖| 日韩欧美高清dvd碟片| 波多野结衣中文字幕一区二区三区 | 久久精品免费观看| 综合色中文字幕| 欧美精品一区二区三区在线播放| 色婷婷国产精品综合在线观看| 精品一区二区综合| 亚洲国产日韩a在线播放性色| 国产亚洲污的网站| 制服丝袜激情欧洲亚洲| 色综合天天综合网天天看片| 国产在线播放一区三区四| 亚洲综合另类小说| 国产精品久线在线观看| 欧美精品一区二区三区久久久| 欧美性高清videossexo| 99久久99精品久久久久久| 国产呦萝稀缺另类资源| 日本一道高清亚洲日美韩| 亚洲成在人线在线播放| 亚洲欧洲av在线| 国产精品欧美精品| 国产丝袜在线精品| www亚洲一区| 精品99久久久久久| 亚洲精品一区二区三区香蕉| 欧美日韩国产大片| 欧美亚洲精品一区| 欧美午夜一区二区| 色悠久久久久综合欧美99| 国产91精品露脸国语对白| 国产一区二区在线看| 久久99国产精品久久99果冻传媒 | 亚洲女爱视频在线| 国产精品无圣光一区二区| 国产欧美综合色| 精品国产伦一区二区三区免费| 欧美一区二区三区四区在线观看| 欧美猛男gaygay网站| 欧美性高清videossexo| 7777精品伊人久久久大香线蕉的| 色综合久久综合| 色婷婷香蕉在线一区二区| 99精品国产91久久久久久| 91片在线免费观看| 91国产福利在线| 欧美午夜影院一区| 欧美一区二区视频免费观看| 日韩女优制服丝袜电影| 26uuu另类欧美亚洲曰本| 久久精品亚洲精品国产欧美| 亚洲国产精品黑人久久久| 国产精品久久久久久久久晋中| 亚洲免费高清视频在线| 亚洲与欧洲av电影| 老司机精品视频一区二区三区| 国模一区二区三区白浆| 成人网男人的天堂| 在线视频国产一区| 日韩一区二区在线免费观看| 久久久不卡网国产精品二区| 中文字幕一区二区视频| 亚洲第一主播视频| 九一久久久久久| 99久久久久免费精品国产 | 午夜日韩在线观看| 黑人巨大精品欧美一区| 成人毛片视频在线观看| 欧美日韩国产美女| 久久精品欧美一区二区三区不卡 | 一本色道综合亚洲| 欧美一区二区三区啪啪| 国产亚洲自拍一区| 亚洲在线视频免费观看| 久草中文综合在线| 91在线观看污| 日韩一区和二区| 亚洲欧美日韩精品久久久久| 亚洲国产一区二区a毛片| 国产激情91久久精品导航| 欧美色综合影院| 国产视频亚洲色图| 午夜精品久久久久久不卡8050| 国产精品 日产精品 欧美精品| 欧美天天综合网| 久久久久久久久蜜桃| 天天av天天翘天天综合网色鬼国产| 国产电影一区二区三区| 欧美一区二区三区免费在线看| 日韩美女视频一区| 国产剧情在线观看一区二区| 色婷婷综合久久久中文字幕| 国产网红主播福利一区二区| 日韩不卡在线观看日韩不卡视频| 99久久精品国产导航| 久久久国产精品午夜一区ai换脸| 午夜精品一区二区三区电影天堂 | 久久精品国产99国产| 色综合久久久网| 国产网站一区二区| 免费久久99精品国产| 欧美在线|欧美| 亚洲私人影院在线观看| 成人国产一区二区三区精品| 精品国产人成亚洲区| 日本在线不卡视频| 欧美日韩在线播放| 日韩理论在线观看| 成人99免费视频| 欧美激情资源网| 成熟亚洲日本毛茸茸凸凹| 久久久久久久久免费| 国产综合久久久久久鬼色| 精品国产青草久久久久福利| 日韩成人一级片| 欧美高清精品3d| 日本不卡高清视频| 91精品国产乱| 美日韩一区二区| 久久综合狠狠综合久久综合88| 精品伊人久久久久7777人|