欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Qt之實現(xiàn)圓形進度條的示例代碼

 更新時間:2023年10月09日 08:35:08   作者:視圖猿人  
在平時做頁面開發(fā)時,有些時候會用到圓形進度條,本文主要介紹了Qt之實現(xiàn)圓形進度條的示例代碼,具有一定的參考價值,感興趣的可以了解一下

在Qt自帶的控件中,只有垂直進度條、水平進度條兩種。

在平時做頁面開發(fā)時,有些時候會用到圓形進度條,比如說:下載某個文件的下載進度。

展示效果,如下圖所示:

實現(xiàn)這個功能主要由以下幾個重點:

1:圖形繪制

2:數(shù)值計算

也算是一個初級例子,下面我來講解下如何實現(xiàn)這個簡單的小功能吧!

功能

自定義繪制類:QRoundedProgress

繼承自QWidget

圖形繪制

1.繪制窗口整體背景色值

QPainter painter(this);
painter.fillRect(this->rect(), m_crBack);
painter.setRenderHint(QPainter::Antialiasing); //抗鋸齒

m_crBack:窗口背景色,默認(rèn)是 QColor(255, 255, 255);

因為后續(xù)要繪制圓形,在繪制之前加上抗鋸齒效果。

2.圓形進度條通道繪制

什么叫做圓形進度條的通道呢?

如圖所示的灰色區(qū)域就是圓形進度條的通道,也就是我們說的圓環(huán)。

實現(xiàn)方式:兩個半徑不同的圓重疊在一起(且圓心相同),未重疊的部分也就是圓形的通道區(qū)域。

假設(shè)QRoundedProgress類大小是:QSize(100, 100),也就是說該窗口的寬度=100,高度=100。

大圓形代碼:

painter.setPen(m_crProgressChannel);
painter.setBrush(m_crProgressChannel);
painter.drawEllipse(this->rect());

以整個窗口作為圓形的區(qū)域進行繪制,顯示效果如下:

m_crProgressChannel:通道號顏色值,默認(rèn)是 QColor(220, 220, 220);

小圓形代碼:

QRect rectInCircl = this->rect();
rectInCircl.adjust(10, 10, -10, -10);
painter.setPen(m_crBack);
painter.setBrush(m_crBack);
painter.drawEllipse(rectInCircl);

以窗口的整體區(qū)域為標(biāo)準(zhǔn),向內(nèi)調(diào)整10個像素大小,采用了QRect::adjust方法。

10就是圓環(huán)的寬度了。

3.圓形進度條繪制

進度條也就是在文章最開始gif動畫中藍(lán)色的動態(tài)條。

該如何簡單的繪制整個進度呢?

最簡單的方式:采用QPainter扇形的繪制方式!

在程序中,進度條的變化可以采用扇形的區(qū)域進行表示。隨著數(shù)據(jù)的變化,扇形的面積也逐漸遞增,直到達到設(shè)定的最大值為止。

該如何繪制呢?

要是繪制一個實心的扇形,直接在小圓形代碼后面追加肯定是不行的,會出現(xiàn)下面的效果:

小圓形直接被覆蓋住了,這樣的效果與文章最開始的展示效果是不一致的。

修改方式:將扇形繪制的方法放置到大圓形、小圓形代碼之間

繪制扇形代碼如下:

painter.setPen(m_crProgressBar);
painter.setBrush(m_crProgressBar);
painter.drawPie(this->rect(), 90 * 16, -m_nValue * m_fStep * 16);

m_crProgressBar:圓形進度條顏色值,默認(rèn)是 QColor(16, 142, 233);

4.文本繪制

圖形繪制完成后,最后繪制文本展示

painter.setFont(m_font);
painter.setPen(m_crText);
painter.drawText(rectInCircl, Qt::AlignHCenter| Qt::AlignVCenter, m_sValue);

數(shù)值計算

在圓形進度條中需要設(shè)置以下幾種計算

1.計算步長

m_fStep = 360.0/ (maximum - minimum);

根據(jù)步長大小,計算每次移動的扇面面積

painter.drawPie(this->rect(), 90 * 16, -m_nValue * m_fStep * 16);

 通常情況下,圓形進度條的走向一般是順時針,但是,在圓形中走向卻是逆時針方向,所以在進行扇形面積計算時,會從90°逆向繪制。

2.實時數(shù)據(jù)計算

由外界調(diào)用者傳入實時變化數(shù)據(jù),并計算當(dāng)前加載的百分比數(shù)值。

float fNum = (value*1.0) / (m_nMaxMum - m_nMinMum);
m_sValue = QString::number(fNum*100, 'f', 0) + QStringLiteral("%");

其中,m_sValue該變量是應(yīng)用到drawText中文本繪制的。

到這里,簡單的圓形進度條就繪制完成了~

到此這篇關(guān)于Qt之實現(xiàn)圓形進度條的示例代碼的文章就介紹到這了,更多相關(guān)Qt 圓形進度條內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C語言之實現(xiàn)單鏈表指定結(jié)點的插入方式

    C語言之實現(xiàn)單鏈表指定結(jié)點的插入方式

    這篇文章主要介紹了C語言之實現(xiàn)單鏈表指定結(jié)點的插入方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • C語言版二值圖像統(tǒng)計連通區(qū)域

    C語言版二值圖像統(tǒng)計連通區(qū)域

    這篇文章主要為大家詳細(xì)介紹了C語言版二值圖像統(tǒng)計連通區(qū)域的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • C++使用UDP通訊的實現(xiàn)示例

    C++使用UDP通訊的實現(xiàn)示例

    本文實現(xiàn)對C++使用UDP做了簡單封裝,實現(xiàn)通訊,包括服務(wù)端和客戶端,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-12-12
  • Qt使用隨機驗證碼的實現(xiàn)示例

    Qt使用隨機驗證碼的實現(xiàn)示例

    有時候在登錄界面需要驗證碼功能,這樣能夠防止被惡意程序攻擊,本文主要介紹了Qt使用隨機驗證碼的實現(xiàn)示例,具有一定的參考價值,感興趣的可以了解一下
    2024-01-01
  • Easyx實現(xiàn)窗口自動碰撞的小球

    Easyx實現(xiàn)窗口自動碰撞的小球

    這篇文章主要為大家詳細(xì)介紹了Easyx實現(xiàn)窗口自動碰撞的小球,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • C語言如何解決約瑟夫環(huán)問題

    C語言如何解決約瑟夫環(huán)問題

    文章總結(jié)了四種解決特定問題的方法,包括單循環(huán)鏈表法、循環(huán)數(shù)組法、遞歸法和迭代法,并分享了個人經(jīng)驗
    2024-12-12
  • C語言詳解格式控制符scanf與printf的輸入輸出

    C語言詳解格式控制符scanf與printf的輸入輸出

    這篇文章主要介紹了C語言格式控制符中輸入scanf()和輸出printf()的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2022-04-04
  • 關(guān)于C++中void*的小作用淺析

    關(guān)于C++中void*的小作用淺析

    這篇文章主要給大家介紹了關(guān)于C++中void*的一些小作用,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用C++具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考借鑒,下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-08-08
  • c++讀取sqlserver示例分享

    c++讀取sqlserver示例分享

    這篇文章主要介紹了c++讀取sqlserver的示例,需要的朋友可以參考下
    2014-02-02
  • C++入門之vector使用詳解

    C++入門之vector使用詳解

    這篇文章主要為大家介紹了C++入門之vector使用,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-11-11

最新評論