主頁 > 知識庫 > canvas實現(xiàn)圓形進度條動畫的示例代碼

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

熱門標簽:成都智能外呼系統(tǒng)平臺 四川點撥外呼系統(tǒng) 當涂高德地圖標注 鎮(zhèn)江智能外呼系統(tǒng)有效果嗎 云南大理400電話申請官方 江蘇智能電銷機器人哪家好 黃島區(qū)地圖標注 電銷機器人電話用什么卡 南寧點撥外呼系統(tǒng)哪家公司做的好

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

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

進度條動畫

1. canvas的HTML部分很簡單就一個canvas標簽

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

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

2.畫布的js代碼

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

注意:每畫一個圓都要新建一個圖層,這樣可以單獨設置每個圖層的樣式,之間不相互影響,就像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);

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

標簽:淮安 酒泉 南京 佳木斯 廣西 十堰 咸寧 西寧

巨人網(wǎng)絡通訊聲明:本文標題《canvas實現(xiàn)圓形進度條動畫的示例代碼》,本文關鍵詞  canvas,實現(xiàn),圓形,進度,條動,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權(quán)與本站無關。
  • 相關文章
  • 下面列出與本文章《canvas實現(xiàn)圓形進度條動畫的示例代碼》相關的同類信息!
  • 本頁收集關于canvas實現(xiàn)圓形進度條動畫的示例代碼的相關信息資訊供網(wǎng)民參考!
  • 推薦文章