亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

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

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

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

展示效果,如下圖所示:

實(shí)現(xiàn)這個(gè)功能主要由以下幾個(gè)重點(diǎn):

1:圖形繪制

2:數(shù)值計(jì)算

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

功能

自定義繪制類:QRoundedProgress

繼承自QWidget

圖形繪制

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

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

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

因?yàn)楹罄m(xù)要繪制圓形,在繪制之前加上抗鋸齒效果。

2.圓形進(jìn)度條通道繪制

什么叫做圓形進(jìn)度條的通道呢?

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

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

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

大圓形代碼:

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

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

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ū)域?yàn)闃?biāo)準(zhǔn),向內(nèi)調(diào)整10個(gè)像素大小,采用了QRect::adjust方法。

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

3.圓形進(jìn)度條繪制

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

該如何簡單的繪制整個(gè)進(jìn)度呢?

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

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

該如何繪制呢?

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

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

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

繪制扇形代碼如下:

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

m_crProgressBar:圓形進(jìn)度條顏色值,默認(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ù)值計(jì)算

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

1.計(jì)算步長

m_fStep = 360.0/ (maximum - minimum);

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

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

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

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

由外界調(diào)用者傳入實(shí)時(shí)變化數(shù)據(jù),并計(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中文本繪制的。

到這里,簡單的圓形進(jìn)度條就繪制完成了~

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

相關(guān)文章

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

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

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

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

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

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

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

    Qt使用隨機(jī)驗(yàn)證碼的實(shí)現(xiàn)示例

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

    Easyx實(shí)現(xiàn)窗口自動(dòng)碰撞的小球

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

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

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

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

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

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

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

    c++讀取sqlserver示例分享

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

    C++入門之vector使用詳解

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

最新評論