久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

使用 css3 實現圓形進度條的示例

本篇文章主要介紹了使用 css3 實現圓形進度條的示例,這里整理了詳細的代碼,非常具有實用價值,需要的朋友可以參考下

在開發微信小程序的時候,遇到圓形進度條的需求。使用canvas繪圖比較麻煩:

1、為了實現在不同屏幕上面的適配,必須動態的計算進度條的大小;

2、在小程序中,canvas的畫布具有最高的層級,不易于擴展。

但使用css3和js實現進度條就很容易的避免了這方面的問題。

注:這篇文章里面使用jquery實現,但原理是一樣的,在小程序中只要定義并改變相應的變量就行了

一、進度條樣式的樣式

在平時的開發中,經常使用元素的border來顯示圓形圖案,在使用css3實現圓形進度條時,同樣也是使用這個技巧。為了實現上面的圓形邊框,動態的覆蓋下面圓形邊框,總共需要一個圓形,2個長方形和2個半圓形:一個圓形用來顯示底層背景,兩個半圓形用來覆蓋底層背景顯示進度,另外兩個長方形用來覆蓋不需要顯示的進度。如下圖:

使用 css3 實現圓形進度條的示例

最下面的bottom圓形是進度條的背景,在bottom上面有left和right兩個長方形,用來覆蓋不要顯示的進度條。在兩個長方形的里面分別有一個半圓形用來顯示進度。正常情況下,使用正方形繪制出來的半圓,直徑和水平下都是有45度夾角的。為了能使兩個半圓剛好可以覆蓋整個圓形,就需要使用css3中的rotate使原有正方形旋轉,達到覆蓋整個背景的效果。如下圖(為了顯示清楚,這里用正方形表示):

使用 css3 實現圓形進度條的示例

如圖,將長方形內部的半圓向右(順時針)旋轉45度,就可以得到進度覆蓋整個背景的圖像。將半圓向左(逆時針)旋轉135度就能得到只有進度條背景的圖像。為什么又要向左旋轉,而不是一直向右旋轉,當然是因為要實現的效果是:進度是從頂部開始,順時走完的。到這里,思路就很清晰了,只需要再按百分比的多少來控制左邊和右邊進度的顯示就可以了。

實現這部分的html和css代碼如下:

html代碼

<div class="progressbar">
    <div class="left-container">
        <div class="left-circle"></div>
    </div>
    <div class="right-container">
        <div class="right-circle"></div>
    </div>
</div>

css代碼:

.progressbar{
    position: relative;
    margin: 100px auto;
    width: 100px;
    height: 100px;
    border: 20px solid #ccc;
    border-radius: 50%;
}
.left-container,.right-container{
    position: absolute;
    width: 70px;
    height: 140px;
    top:-20px;
    overflow: hidden;
    z-index: 1;
}
.left-container{
    left: -20px;
}
.right-container{
    right: -20px;
}
.left-circle,.right-circle{
    position: absolute;
    top:0;
    width: 100px;
    height: 100px;
    border:20px solid transparent;   
    border-radius: 50%;
    transform: rotate(-135deg);
    transition: all .5s linear;
    z-index: 2;
}
.left-circle{
    left: 0;
    border-top-color: 20px solid blue;
    border-left-color: 20px solid blue;
}
.right-circle{
    border-right-color: 20px solid blue;
    border-bottom-color: 20px solid blue;
    right: 0;
}

二:控制進度條的js

為了使進度條的邏輯更健壯,js部分的實現需要考慮四中情況:

1、基礎值個更改后的值在同在右邊進度,

2、基礎值在右邊,更改后的值在左邊,

3、基礎值更改后的值同在左邊,

4、基礎值在左邊,更改后的值在右邊。

不管在那種情況下,核心需要考慮只有兩點:角度的變化和使用時間的多少。

第一種情況下,比較簡單,可以很簡單計算出角度的變化和使用時間的多少。首先,需要設定改變整個半圓的所需的時間值。設定之后,只要根據比例計算出改變的角度所需要的時間值即刻。代碼如下:

time = (curPercent - oldPercent)/50 * baseTime;
     //確定時間值為正
     curPercent - oldPercent > 0 ? '' : time = - time;
     deg = curPercent/50*180-135;

第二種情況,稍微麻煩一點。因為中間有一個從右邊進度,到左邊進度的過渡。為了讓進度順暢的改變,這里我們需要使用定時器,在改變完右邊的部分之后,再修改左邊的部分。代碼如下:

//設置右邊的進度
  time = (50 - oldPercent)/50 * baseTime;
deg = (50 - oldPercent)/50*180-135;
$rightBar .css({
    transform: 'rotate('+ deg+ 'deg)',
    transition : 'all '+ time + 's linear'
})
//延時設置左邊進度條的改變
setTimeout(function(){
    time = (curPercent - 50)/50;
    deg = (curPercent - 50)/50*180 -135;

    $leftBar.css({
        transform: 'rotate('+ deg+ 'deg)',
        transition : 'all '+ time + 's linear'
    })
}, Math.floor(time*1000));000));

第三種情況和第四種情況同前面情況類似,這里不再討論。

【網站聲明】本站除付費源碼經過測試外,其他素材未做測試,不保證完整性,網站上部分源碼僅限學習交流,請勿用于商業用途。如損害你的權益請聯系客服QQ:2655101040 給予處理,謝謝支持。

相關文檔推薦

本篇文章主要介紹了詳解CSS3 rem(設置字體大小) 教程,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
本篇文章主要介紹了CSS3 linear-gradient線性漸變生成加號和減號的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
這篇文章主要介紹了CSS mask-image屬性詳細介紹(小結)的相關資料,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
這篇文章主要介紹了css3中的漸進增強和優雅降級的相關資料,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
這篇文章主要介紹了淺談css3新單位vw、vh、vmin、vmax的使用詳解的相關資料,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
這篇文章主要介紹了淺談css3中calc在less編譯時被計算的解決辦法的相關資料,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
主站蜘蛛池模板: 欧美亚洲视频 | 亚洲精品在线免费观看视频 | 综合五月婷 | av在线黄 | 在线播放亚洲 | 成人在线中文字幕 | 高清国产一区二区 | 在线观看中文字幕 | 99re国产| 天天天天天天天干 | 日韩在线免费视频 | 国产一二区免费视频 | a在线观看免费 | 91视频在线看 | 91在线精品一区二区 | 国产精品一区二区久久 | 久久亚洲一区二区三区四区 | 成人欧美一区二区三区黑人孕妇 | 成人精品一区二区 | 日韩欧美在线视频 | 国产精品视频久久 | 91 久久| 九一视频在线播放 | 免费一区二区 | 久久精品一区二区三区四区 | 亚洲综合在线一区 | 黄色大片免费网站 | 日本免费一区二区三区四区 | 欧洲亚洲一区二区三区 | 久久不射网 | 久久精品视频12 | 亚洲精品久久久久久下一站 | 国产成人网 | 精品国产一区二区三区四区在线 | 涩在线| 国产精品国产三级国产aⅴ无密码 | 欧美精品福利视频 | 国产精品久久久久久久久污网站 | 久久99蜜桃综合影院免费观看 | 中文字幕av一区二区三区 | 日韩一级免费观看 |