主頁 > 軟體設計 > Fdog系列(四):使用Qt框架模仿QQ實作登錄界面,界面篇。

Fdog系列(四):使用Qt框架模仿QQ實作登錄界面,界面篇。

2021-04-26 10:22:02 軟體設計

文章目錄

  • 一. 前言
  • 二. 正文
    • 1. 創建視窗,添加基本組件
    • 2. 自定義標題,隱藏任務欄標題,實作系統托盤顯示
    • 3. 美化主界面,文本框的奇思妙想
    • 4. 實作背景陰影


一. 前言

Fdog系列已寫目錄:

Fdog系列(一):思來想去,不如寫一個聊天軟體,那就從仿QQ注冊頁面開始吧,

Fdog系列(二):html寫完注冊頁面之后怎么辦,用java寫后臺回應呀,

Fdog系列(三):使用騰訊云短信介面發送短信,資料庫寫入,部署到服務器,web收尾篇,


哈嘍,我的小伙伴們,在之前的三篇中,我們實作了網頁端注冊一個Fdog賬號,包括第一篇html的設計,第二篇,html頁面的回應,以及第三篇的發送短信,資料庫寫入等等,關于網頁端的撰寫,用了三篇進行描述,從第四篇開始,將進入Qt階段,我將開始使用Qt繼續進一步創造,帶領大家將一些知識進行綜合,

先看一下效果圖
在這里插入圖片描述
學習該篇,你將學會:

自定義標題框,實作移動
隱藏任務欄圖示,將圖示顯示在系統托盤(系統右下角)
創建右擊選單
文本框的奇思妙想
自定義邊框如何添加邊框陰影效果
樣式設計
等等等等

圖中的下拉框,以及如何獲取內容,改變內容,洗掉內容,將在第五篇功能篇為大家講解,還包括獲取本地登錄資訊,識別用戶是否記住密碼,以及ListWdiget自定義,關注我不迷路!

那么下面我們就開搞吧!go!


二. 正文

1. 創建視窗,添加基本組件

首先創建一個Widget視窗,不要創建MainWindow視窗,因為MainWindow視窗將作為我們后面主界面的視窗,

右鍵專案,添加新檔案,選中Qt下面的Qt設計師界面類,選擇創建widget型別的視窗,

然后照貓畫虎,模仿QQ添加必要的控制元件,
在這里插入圖片描述
包括幾個標簽,按鈕,以及文本框,

你可以看到文本框下面的三個控制元件中右邊那個貌似不是很對齊,怎么做呢,給他們三加一個水平布局就可以解決問題,你可能會說使用XY值也可以條件,好吧,隨便你,

我們拉一個水平布局,將這三個控制元件拉進去,效果如下:

在這里插入圖片描述

小提示:

如果你想讓某個控制元件特別的長,或特別的短,可以試試設定他們的最大值最小值,如果控制元件,例如按鈕,在水平控制元件中寬會縮放自如,而高則不然,原因是什么呢?你可以點擊按鈕,選中屬性頁面的sizepolicy,你可以看到水平策略和垂直策略兩者值的不同,這就是其中的原因,以及垂直伸展屬性,適當的設定這些屬性,將有助于你設計出更好的界面,

現在,我們點擊運行,效果如下:
在這里插入圖片描述


2. 自定義標題,隱藏任務欄標題,實作系統托盤顯示

現在我們將系統自動的標題隱藏掉,使用我們自定義的標題,在這之前,我們先把最小化,關閉按鈕實作,雖然可以直接切后臺~~~

同樣使用到水平布局,將最小化,最大化按鈕(ToolButton)和左側的綠色標簽放在水平布局中,如果在布局中兩個控制元件需要間隔一定距離,可以使用彈簧進行間隔,

在這里插入圖片描述
右擊最小按鈕和關閉按鈕,轉到槽,選擇選中(clicked())信號,

void Login::on_toolButton_clicked()//最小化
{
    this->hide();
}

void Login::on_toolButton_2_clicked()//關閉
{
    this->close();
}

并為按鈕添加圖示,以及左上角的標簽添加logo圖片,運行效果如下(黑色效果不明顯,我換了一個):
在這里插入圖片描述
如果你給按鈕添加了圖示,但是是像關閉按鈕那樣后面有白色的話,可以選中按鈕屬性中的autoRaise,勾選一下,你就會發現背景透明了,

如果你不會添加資源的話,我教你呀,右擊專案,創建新檔案,選中Qt中的Qt Resources檔案,創建之后工程串列會多出一個Resources檔案,然后在專案檔案夾下面創建一個lib的檔案夾,圖片放在里面,然后點擊Resources,添加現有檔案,選擇lib下面的圖片即可,

差了忘了最主要的,如何取消系統標題,在建構式中,為表單設定Flags,

this->setWindowFlags(Qt::SplashScreen|Qt::WindowStaysOnTopHint|Qt::FramelessWindowHint);

運行看看
在這里插入圖片描述
你會發現沒有了系統標題,但是這里有一個很大的問題,你發沒發現它根本移動不了????

我們來解決它,

添加兩個頭檔案

#include<QPoint>
#include<QMouseEvent>

在頭檔案中添加三個函式和兩個變數,

	bool isPressedWidget;
	QPoint last;
    void mousePressEvent(QMouseEvent *event);//滑鼠點擊
    void mouseMoveEvent(QMouseEvent *event);//滑鼠移動
    void mouseReleaseEvent(QMouseEvent *event);//滑鼠釋放

并對其進行實作

void Login::mousePressEvent(QMouseEvent *event)
{
    isPressedWidget = true; // 當前滑鼠按下的即是QWidget而非界面上布局的其它控制元件
    last = event->globalPos();
}

void Login::mouseMoveEvent(QMouseEvent *event)
{
    if (isPressedWidget)
        {
            int dx = event->globalX() - last.x();
            int dy = event->globalY() - last.y();
            last = event->globalPos();
            move(x()+dx, y()+dy);
        }
}

void Login::mouseReleaseEvent(QMouseEvent *event)
{
    int dx = event->globalX() - last.x();
    int dy = event->globalY() - last.y();
    move(x()+dx, y()+dy);
    isPressedWidget = false; // 滑鼠松開時,置為false
}

這里還有我之前發的一篇對于滑鼠移動有另一種寫法:Qt隱藏系統標題欄,使用自定義標題欄

運行效果如下:
在這里插入圖片描述

除此之外任務欄也不顯示程式標題,這正是我們想要的,現在我們為這個視窗添加系統托盤,和QQ一樣,我們將在系統托盤對其操作,

QSystemTrayIcon類可以幫助我們完成這一操作,

在頭檔案創建一個QSystemTrayIcon類物件

 QSystemTrayIcon  * systemtrayicon;  //系統托盤

cpp檔案中對其實體化

//初始化系統托盤
    systemtrayicon = new QSystemTrayIcon(this);
    QIcon icon = QIcon(":/lib/qusefdogicon.png");
    //添加圖示
    systemtrayicon->setIcon(icon);
    //當滑鼠懸浮,顯示文字
    systemtrayicon->setToolTip(QObject::trUtf8("Fdog"));
    //顯示圖示
    systemtrayicon->show();

在這里插入圖片描述

唯一不足的是qq有右擊選單,我們沒有,現在我們來試著添加右擊選單,并實作打開主界面和退出功能,

創建一個選單物件,兩個action,兩個槽函式

#inlcude<QMenu>
QMenu * menu;
QAction *m_pShowAction;
QAction *m_pCloseAction;
private slots:
void showwidget();
void closewidget();

對其實體化

menu = new QMenu(this);
m_pShowAction = new QAction("打開主界面");
m_pCloseAction = new QAction("退出");
menu->addAction(m_pShowAction);
menu->addSeparator();
menu->addAction(m_pCloseAction);
systemtrayicon->setContextMenu(menu);
connect(m_pShowAction,SIGNAL(triggered(bool)),this,SLOT(showwidget()));
connect(m_pCloseAction,SIGNAL(triggered(bool)),this,SLOT(closewidget()));

void Login::showwidget()
{
    this->show();
}

void Login::closewidget()
{
    this->close();
}

效果如下,右擊,可以選擇打開主界面或者是退出,
在這里插入圖片描述


3. 美化主界面,文本框的奇思妙想

在這里插入圖片描述
現在,我們著重對樣式進行一個美化,讓它從左邊的圖向右邊靠攏,

比如上半部分的一個動態圖,怎么顯示動態圖呢

#include<QMovie>
QMovie * m_movie;
//加載動態圖
m_movie = new QMovie(":/lib/mian.gif");//這是需要播放的動態圖
//設定動態圖大小
m_si.setWidth(431);
m_si.setHeight(151);
m_movie->setScaledSize(m_si);
//添加動態圖
ui->mian_label->setMovie(m_movie); //mian_label是粉色的標簽
//開始影片
m_movie->start();

將頭像設定為圓形需要設定qss,也就是樣式表,可以右擊label為頭像的改變樣式表添加如下陳述句

border-image: url(:/lib/icon2505897252.png);
border-width:0px;
border-radius:33px;
border-style:solid;
border-color: rgb(255, 255, 255);

包括頭像后面的白框也是同樣的方法,

然后關于注冊帳戶,以及自動登錄,記住密碼等標簽或是按鈕等等,可以設定普通狀態和滑鼠懸浮狀態,文字顏色深淺的一個不同,
這里就拿按鈕舉例,設定其qss,:hover代表滑鼠懸浮,

#pushButton_2{
color: rgb(149, 149, 149);
}
#pushButton_2:hover{
color: rgb(120, 120, 120);
}

登錄按鈕的qss美化

#pushButton{
background-color: rgb(99, 188, 255);
color: rgb(255, 255, 255);
border-radius: 5px;
font-size:14px;
}
#pushButton:hover{
background-color: rgb(99, 170, 255);
color: rgb(255, 255, 255);
border-radius: 5px;

}
#pushButton:pressed{
background-color: rgb(99, 188, 255);
color: rgb(255, 255, 255);
border-radius: 5px;
padding-left:2px;
padding-top:2px;
}

默認的按鈕,當我們點擊按鈕時,按鈕上的文字會向右上角晃動,但是當我們添加了自定義的圖片,該效果則消失,如何做到這一點,可以使用padding-left:2px; padding-top:2px;來實作,

下面是一個主要的點,文本框的奇思妙想,
在這里插入圖片描述

1.如何添加默認文本,文本框屬性中找placeholderText設定即可,

2.如何在文本框添加圖示,包括左邊和右邊

//Fdog號碼文本框
QAction * searchAction = new QAction(ui->lineEdit);
searchAction->setIcon(QIcon(":/lib/suo.png"));
ui->lineEdit->addAction(searchAction,QLineEdit::LeadingPosition);//表示action所在方位(左側),
//密碼文本框
QAction * searchAction_2 = new QAction(ui->lineEdit);
searchAction_2->setIcon(QIcon(":/lib/jianpan.png"));
ui->lineEdit->addAction(searchAction_2,QLineEdit::TrailingPosition);//表示action所在方位(右側),
QAction * searchAction_3 = new QAction(ui->lineEdit);
searchAction_3->setIcon(QIcon(":/lib/fdog.png"));
ui->lineEdit_2->addAction(searchAction_3,QLineEdit::LeadingPosition);//表示action所在方位(左側),

3.如何實作右邊下拉選項框,其實這里是一個文本框和一個combox下拉串列框組成的

在這里插入圖片描述
點擊三角按鈕,將選中的內容顯示在文本框就可以了,

這個三角好像有點丑,我們可以給它一個替換

::down-arrow{
border-image: url(:/lib/jietou.png);
}

如果不清楚一個控制元件有哪些子控制元件,可以看這篇子控制元件查閱,

之后就是將文本框左右兩邊以及上面的邊改為白色或透明,下邊改成黑色,大功告成,

border-style:solid;
border-width:1px;
border-top-color: rgba(255, 255, 255, 0);
border-right-color: rgba(255, 255, 255, 0);
border-left-color: rgba(255, 255, 255, 0);
border-bottom-color: rgb(129, 129, 129);

4. 實作背景陰影

到目前為止,還剩下最后一個問題,當使用自帶的標題欄后,視窗是自帶陰影邊框的,但是當我們取消了系統自帶的標題欄之后,邊框也隨之消失,如何自己搞一個邊框陰影?我來教你,首先準備一張邊框陰影圖,沒有?別擔心,狗子我是全能的,PS走起,好歹我也是負責學生會海報的優秀人才,

創建一個透明圖層,然后再創建一個白色圖層,邊框要小于透明圖層,給白色圖層設定圖層樣式,投影里面,引數如下:
在這里插入圖片描述
在這里插入圖片描述
后面放了一個白色背景方便觀察,然后保存為png圖,記得把后面白色圖層隱藏,再說一遍要注意透明圖層和陰影圖層的距離,
在這里插入圖片描述
會到qt,拖一個widget,然后把除了頂層視窗所有我們自己創建的控制元件都拖進去,然后設定最小大小和最大大小,然后給頂層視窗一個布局,并且設定適當邊距,如圖中藍色區域,這個藍色區域就是放陰影的地方,
在這里插入圖片描述
然后設定表單透明

    //表單透明
    setAttribute(Qt::WA_TranslucentBackground);

重寫void paintEvent(QPaintEvent *e);

void paintEvent(QPaintEvent *e);

void Login::paintEvent(QPaintEvent *e)
{
    Q_UNUSED(e)
    QPainter painter(this);
    QPixmap pixmap(":/lib/background.png");//做好的圖
    qDrawBorderPixmap(&painter, this->rect(), QMargins(0, 0, 0, 0), pixmap);
    QRect rect(this->rect().x()+8, this->rect().y()+8, this->rect().width()-16, this->rect().height()-16);
    painter.fillRect(rect, QColor(255, 255, 255));
}

在這里插入圖片描述


在這里插入圖片描述
最后再放一張美圖,我知道大家好這口【手動狗頭】,看了我的美圖,還不趕緊點個贊,給個關注?

原始碼還有圖片資源想要的話,可以在評論區留個郵箱,也可以加我微信獲取sui2506897252,


轉載請註明出處,本文鏈接:https://www.uj5u.com/ruanti/280231.html

標籤:其他

上一篇:Web安全:跨站點攻擊csrf

下一篇:package xxx does not exist cannot find symbol

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 面試突擊第一季,第二季,第三季

    第一季必考 https://www.bilibili.com/video/BV1FE411y79Y?from=search&seid=15921726601957489746 第二季分布式 https://www.bilibili.com/video/BV13f4y127ee/?spm_id_fro ......

    uj5u.com 2020-09-10 05:35:24 more
  • 第三單元作業總結

    1.前言 這應該是本學期最后一次寫作業總結了吧。總體來說,對作業的節奏也差不多掌握了,作業做起來的效率也更高了。雖然和之前的作業一樣,作業中都要用到新的知識,但是相比之前,更加懂得了如何利用工具以及資料。雖然之間卡過殼,但總體而言,這幾次作業還算完成的比較好。 2.作業程序總結 相比前兩個單元,此單 ......

    uj5u.com 2020-09-10 05:35:41 more
  • 北航OO(2020)第四單元博客作業暨課程總結博客

    北航OO(2020)第四單元博客作業暨課程總結博客 本單元作業的架構設計 在本單元中,由于UML圖具有比較清晰的樹形結構,因此我對其中需要進行查詢操作的元素進行了包裝,在樹的父節點中存盤所有孩子的參考。考慮到性能問題,我采用了快取機制,一次查詢后盡可能快取已經遍歷過的資訊,以減少遍歷次數。 本單元我 ......

    uj5u.com 2020-09-10 05:35:48 more
  • BUAA_OO_第四單元

    一、UML決議器設計 ? 先看下題目:第四單元實作一個基于JDK 8帶有效性檢查的UML(Unified Modeling Language)類圖,順序圖,狀態圖分析器 MyUmlInteraction,實際上我們要建立一個有向圖模型,UML中的物件(元素)可能與同級元素連接,也可與低級元素相連形成 ......

    uj5u.com 2020-09-10 05:35:54 more
  • 6.1邏輯運算子

    邏輯運算子 1. && 短路與 運算式1 && 運算式2 01.運算式1為true并且運算式2也為true 整體回傳為true 02.運算式1為false,將不會執行運算式2 整體回傳為false 03.只要有一個運算式為false 整體回傳為false 2. || 短路或 運算式1 || 運算式2 ......

    uj5u.com 2020-09-10 05:35:56 more
  • BUAAOO 第四單元 & 課程總結

    1. 第四單元:StarUml檔案決議 本單元采用了圖模型決議UML。 UML檔案可以抽象為圖、子圖、邊的邏輯結構。 在實作中,圖的節點包括類、介面、屬性,子圖包括狀態圖、順序圖等。 采用了三次遍歷UML元素的方法建圖,第一遍遍歷建點,第二、三次遍歷設定屬性、連邊,實作圖物件的初始化。這里借鑒了一些 ......

    uj5u.com 2020-09-10 05:36:06 more
  • 談談我對C# 多型的理解

    面向物件三要素:封裝、繼承、多型。 封裝和繼承,這兩個比較好理解,但要理解多型的話,可就稍微有點難度了。今天,我們就來講講多型的理解。 我們應該經常會看到面試題目:請談談對多型的理解。 其實呢,多型非常簡單,就一句話:呼叫同一種方法產生了不同的結果。 具體實作方式有三種。 一、多載 多載很簡單。 p ......

    uj5u.com 2020-09-10 05:36:09 more
  • Python 資料驅動工具:DDT

    背景 python 的unittest 沒有自帶資料驅動功能。 所以如果使用unittest,同時又想使用資料驅動,那么就可以使用DDT來完成。 DDT是 “Data-Driven Tests”的縮寫。 資料:http://ddt.readthedocs.io/en/latest/ 使用方法 dd. ......

    uj5u.com 2020-09-10 05:36:13 more
  • Python里面的xlrd模塊詳解

    那我就一下面積個問題對xlrd模塊進行學習一下: 1.什么是xlrd模塊? 2.為什么使用xlrd模塊? 3.怎樣使用xlrd模塊? 1.什么是xlrd模塊? ?python操作excel主要用到xlrd和xlwt這兩個庫,即xlrd是讀excel,xlwt是寫excel的庫。 今天就先來說一下xl ......

    uj5u.com 2020-09-10 05:36:28 more
  • 當我們創建HashMap時,底層到底做了什么?

    jdk1.7中的底層實作程序(底層基于陣列+鏈表) 在我們new HashMap()時,底層創建了默認長度為16的一維陣列Entry[ ] table。當我們呼叫map.put(key1,value1)方法向HashMap里添加資料的時候: 首先,呼叫key1所在類的hashCode()計算key1 ......

    uj5u.com 2020-09-10 05:36:38 more
最新发布
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:20:47 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:20:25 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:20:17 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:20:10 more
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:19:44 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:19:07 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:18:57 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:18:49 more
  • 05單件模式

    #經典的單件模式 public class Singleton { private static Singleton uniqueInstance; //一個靜態變數持有Singleton類的唯一實體。 // 其他有用的實體變數寫在這里 //構造器宣告為私有,只有Singleton可以實體化這個類! ......

    uj5u.com 2023-04-19 08:42:51 more
  • 【架構與設計】常見微服務分層架構的區別和落地實踐

    軟體工程的方方面面都遵循一個最基本的道理:沒有銀彈,架構分層模型更是如此,每一種都有各自優缺點,所以請根據不同的業務場景,并遵循簡單、可演進這兩個重要的架構原則選擇合適的架構分層模型即可。 ......

    uj5u.com 2023-04-19 08:42:41 more