Python制作一個仿QQ辦公版的圖形登錄界面
最近,QQ的辦公版本——TIM進(jìn)行了一次更新升級。本次更新升級大幅修改了界面的樣式,看起來更加的清爽、簡潔和高效了。

這種界面州的先生還是比較喜歡的,沒有QQ那么花里胡哨,也比微信那些殘缺的功能更加豐富。
并且這次的登錄界面還新增了微信登錄的選項,看來 TIM 還打算從微信那邊爭取一部分用戶過來。
閑話少說,進(jìn)入正題。
州的先生看到這個出自大廠的圖形界面程序,不由得想用 Python 的圖形界面模塊來實現(xiàn)一個。在上古時代,前端開發(fā)還是被稱為“切圖仔”的崗位,那時候的一個練手方式就是使用手寫 HTML 和 CSS 來模仿各個網(wǎng)站的樣式。
同樣的,要想把桌面圖形程序?qū)懙镁?、好看,對?yōu)秀桌面圖形界面程序進(jìn)行模仿必不可少。今天,咱們就來使用 Python 的圖形界面模塊 PyQt5 模仿實現(xiàn)最新版本的 TIM 的登錄界面。
最終的成果如下圖所示:

一、畫虎先畫骨
在動工之前,我們先來分析和設(shè)計一下這個登錄界面的結(jié)構(gòu)。TIM 原始的界面布局咱們無從得知,但是根據(jù)呈現(xiàn)出來的樣式,咱們可以確定自己按照什么結(jié)構(gòu)的組織這個登錄界面。

首先,整個登錄界面,由2塊組成:
- 左側(cè)的宣傳圖片
- 右側(cè)的功能按鈕
左側(cè)的宣傳圖片沒啥功能點(diǎn),咱們可以直接用一個背景圖片搞定;右側(cè)的功能按鈕則分了很多類和層級:
- 頂部的程序控制按鈕組
- 中部的QQ/微信登錄方式圖標(biāo)切換組;
- 中下部的表單輸入框組;
- 底部的選項控制組;
基于此,咱們綜合選擇網(wǎng)格布局、垂直布局和水平布局來排列各個控件。
然后,登陸界面的各個子模塊和功能按照如下圖所示來選擇 PyQt5 中的控件:

這樣,登錄界面的結(jié)構(gòu)就完成了。

二、準(zhǔn)備素材
圖標(biāo)在現(xiàn)代軟件設(shè)計中的作用越來越大,恰當(dāng)?shù)膱D標(biāo)使用可以增強(qiáng)界面的視覺美觀和交互友好。在TIM的登錄界面中,也是使用的很多的圖標(biāo)來表示各個功能的操作,比如設(shè)置按鈕、關(guān)閉按鈕、切換按鈕、賬號選擇按鈕、登錄按鈕等。
在此,我們通過著名的阿里巴巴在線矢量圖標(biāo)庫——IconFont 來獲取所需的圖標(biāo)文件,經(jīng)過選擇,最終下載得到:

準(zhǔn)備好圖標(biāo)之后,我們就可以在代碼中使用了。對于這些圖標(biāo)文件,有兩種使用方式:
- 直接使用setIcon()方法進(jìn)行圖標(biāo)設(shè)置,例如:
self.qq_icon.setIcon(QtGui.QIcon("./qq_hover.svg"))
- 在QSS中編寫樣式引用圖標(biāo)文件,例如:
QPushButton#setting_icon{
border-image: url("./setting.svg");
}
上述兩種方式,我們根據(jù)實際的情況,都使用了。

三、完善細(xì)節(jié)
在界面結(jié)構(gòu)搭建好之后,按鈕圖標(biāo)準(zhǔn)備和使用上之后,剩下的就是邊邊角角的細(xì)節(jié)優(yōu)化和美化了。
色彩、間距的調(diào)整
TIM的登錄界面主體上采用了灰色的字體顏色,還有QQ/微信登錄切換的圖標(biāo)顏色、各個組件之間的間距、對齊方式都需要我們進(jìn)行細(xì)致的調(diào)整。這些通過 QSS 、控件的setFixedSize()方法和布局的setAlignment()方法都可以完美實現(xiàn)。
窗口邊框的隱藏
將窗口默認(rèn)的工具欄邊框隱藏掉,然后使用自定義的按鈕來實現(xiàn)窗口的控制;
self.setWindowFlags(QtCore.Qt.FramelessWindowHint)
窗口陰影的實現(xiàn)
取消掉窗口邊框之后,窗口與外界之間就沒有的隔離的標(biāo)志,我們可以重寫繪制一個窗口的邊框線,但是TIM使用的是窗口陰影的方式來突出和隔離界面,所以咱們也使用陰影的方式來實現(xiàn):
shadow = QtWidgets.QGraphicsDropShadowEffect(self, blurRadius=9.0, color=QtGui.QColor(116, 116, 116), offset=QtCore.QPointF(0, 0)) window.setGraphicsEffect(shadow)
四、成果展示
最終,使用 Python 模仿TIM編寫出來的登錄圖形界面效果如下圖所示:

文章版權(quán)所有:州的先生博客,轉(zhuǎn)載必須保留出處及原文鏈接
原文地址:https://zmister.com/archives/1590.html
以上就是Python制作一個仿QQ辦公版的圖形登錄界面的詳細(xì)內(nèi)容,更多關(guān)于python 圖形登錄界面的資料請關(guān)注腳本之家其它相關(guān)文章!
- python實現(xiàn)校園網(wǎng)自動登錄的示例講解
- python爬蟲_實現(xiàn)校園網(wǎng)自動重連腳本的教程
- Python內(nèi)置函數(shù)hex()的實現(xiàn)示例
- Python爬蟲實現(xiàn)自動登錄、簽到功能的代碼
- python 識別登錄驗證碼圖片功能的實現(xiàn)代碼(完整代碼)
- Python 實現(xiàn)自動登錄+點(diǎn)擊+滑動驗證功能
- Python +Selenium解決圖片驗證碼登錄或注冊問題(推薦)
- Python實現(xiàn)用戶登錄并且輸入錯誤三次后鎖定該用戶
- Python GUI自動化實現(xiàn)繞過驗證碼登錄
- 利用Python優(yōu)雅的登錄校園網(wǎng)
相關(guān)文章
一小時學(xué)會TensorFlow2之基本操作1實例代碼
這篇文章主要介紹了TensorFlow2的基本操作第一節(jié),本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-09-09
關(guān)于torch.optim的靈活使用詳解(包括重寫SGD,加上L1正則)
今天小編就為大家分享一篇關(guān)于torch.optim的靈活使用詳解(包括重寫SGD,加上L1正則),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-02-02
django創(chuàng)建超級用戶時指定添加其它字段方式
這篇文章主要介紹了django創(chuàng)建超級用戶時指定添加其它字段方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-05-05
python實現(xiàn)FTP服務(wù)器服務(wù)的方法
本篇文章主要介紹了python實現(xiàn)FTP服務(wù)器的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-04-04
Python利用matplotlib繪制圓環(huán)圖(環(huán)形圖)的實戰(zhàn)案例
環(huán)形圖也被稱為圓環(huán)圖,它在功能上與餅圖相同,只是中間有一個空白,并且能夠同時支持多個統(tǒng)計數(shù)據(jù),下面這篇文章主要給大家介紹了關(guān)于Python利用matplotlib繪制圓環(huán)圖的實戰(zhàn)案例,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-08-08
python讀取raw binary圖片并提取統(tǒng)計信息的實例
今天小編就為大家分享一篇python讀取raw binary圖片并提取統(tǒng)計信息的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-01-01
python根據(jù)完整路徑獲得盤名/路徑名/文件名/文件擴(kuò)展名的方法
這篇文章主要介紹了python根據(jù)完整路徑獲得盤名,路徑名,文件名,文件擴(kuò)展名的代碼,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-04-04

