国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > HTML5 > 正文

canvas實現(xiàn)圓形進度條動畫的示例代碼

2024-09-05 07:22:16
字體:
供稿:網(wǎng)友

本文介紹了canvas實現(xiàn)圓形進度條動畫,分享給大家,具體如下:

先給大家看看效果圖,然后在上代碼。

進度條動畫

1. canvas的HTML部分很簡單就一個canvas標(biāo)簽

canvas畫布的寬高是自身的屬性,要在行間樣式設(shè)置,若是在style設(shè)置寬高會使你畫的圖片變形。

<canvas id="mycanvas" width="100" height="100">70%</canvas>

2.畫布的js代碼

主要思路:效果圖中是由三個圓組成的,最外層是一個有黑邊的大圓,里面一個改變進度條進度的圓和一個現(xiàn)實百分比的圓。

注意:每畫一個圓都要新建一個圖層,這樣可以單獨設(shè)置每個圖層的樣式,之間不相互影響,就像ps的圖層一樣,一個完整的設(shè)計稿都是很多圖層組成的。

var canvas = document.getElementById("mycanvas");var context = canvas.getContext("2d");function draw(i){// 大圓框context.beginPath();context.lineWidth = 1;context.arc(50,50,46,0,Math.PI*2);context.strokeStyle = "grey";context.stroke();// 大圓context.beginPath();var grd = context.createLinearGradient(15,15,80,80);grd.addColorStop(0,"red");grd.addColorStop(0.5,"yellow");grd.addColorStop(1,"blue");context.arc(50,50,38,0,Math.PI*2*(i/100));context.lineWidth = 16;context.strokeStyle = grd;context.stroke();// context.fillStyle = grd;// context.fill();// 小圓context.beginPath();context.arc(50,50,30,0,Math.PI*2);context.lineWidth = 1;context.strokeStyle = "grey";context.stroke();context.fillStyle = "white";context.fill();// 字context.beginPath();context.textBaseline = "middle";context.textAlign = "center";context.font = "20px Arial";context.fillStyle = "black";context.fillText(i+"%",50,50);}

3. 使用計時器來刷新畫布,達到進度條的效果

使用context.clearRect()方法來清空畫布的

var i = 0;var progress = parseInt(canvas.innerHTML);// console.log(progress);var timer = setInterval(function(){if(i >= progress){clearInterval(timer);}context.clearRect(0,0,canvas.width,canvas.height);draw(i);i++;},50);

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持武林網(wǎng)。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 佛坪县| 连云港市| 中牟县| 汉源县| 府谷县| 南漳县| 泽州县| 万盛区| 随州市| 彭阳县| 宜阳县| 万载县| 定日县| 屯留县| 宿松县| 宣城市| 库车县| 名山县| 陈巴尔虎旗| 弥勒县| 英吉沙县| 祥云县| 长岭县| 呼玛县| 儋州市| 包头市| 金山区| 孟州市| 长顺县| 沁水县| 日喀则市| 沙田区| 盐池县| 山丹县| 阳东县| 宁津县| 三河市| 潢川县| 子长县| 墨竹工卡县| 余江县|