1. 程式人生 > >canvas實現圓形進度條動畫的示例

canvas實現圓形進度條動畫的示例

本篇文章小編主要和大家分享一下canvas實現圓形進度條動畫的示例,文章中會有程式碼列出供大家參考學習,對HTML5開發感興趣的小夥伴就隨小編一起來了解一下吧。

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

1、canvas的HTML部分很簡單就一個canvas標籤

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

<canvas id="mycanvas" width="100" height="100">

70%

</canvas>

2、畫布的js程式碼

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

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

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);

以上就是小編給大家分享的canvas實現圓形進度條動畫的示例程式碼,希望對小夥伴們有所幫助。

 

最後,如果有想一起學習web前端,HTML5及JavaScript的可以來一下我的前端群733581373,好友都會在裡面交流,分享一些學習的方法和需要注意的小細節,每天也會準時的講一些前端的炫酷特效,及前端直播課程學習

 

如果想看到更加系統的文章和學習方法經驗可以關注的微訊號:‘web前端技術圈’或者‘webxh6’關注後回覆‘2018’可以領取一套完整的學習視訊