2018-06-12 13:55:56 1454瀏覽
本篇文章小編主要和大家分享一下扣丁學(xué)堂HTML5培訓(xùn)簡述的canvas實現(xiàn)圓形進(jìn)度條動畫的示例,文章中會有代碼列出供大家參考學(xué)習(xí),對HTML5開發(fā)感興趣的小伙伴就隨小編一起來了解一下吧。
本文介紹了canvas實現(xiàn)圓形進(jìn)度條動畫,分享給大家,具體如下:
1、canvas的HTML部分很簡單就一個canvas標(biāo)簽
canvas畫布的寬高是自身的屬性,要在行間樣式設(shè)置,若是在style設(shè)置寬高會使你畫的圖片變形。
<canvas id="mycanvas" width="100" height="100"> 70% </canvas>
2、畫布的js代碼
主要思路:效果圖中是由三個圓組成的,最外層是一個有黑邊的大圓,里面一個改變進(jìn)度條進(jìn)度的圓和一個現(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、使用計時器來刷新畫布,達(dá)到進(jìn)度條的效果
使用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);
以上就是扣丁學(xué)堂HTML5在線學(xué)習(xí)小編給大家分享的canvas實現(xiàn)圓形進(jìn)度條動畫的示例代碼,希望對小伙伴們有所幫助,想要了解更多內(nèi)容的小伙伴可以登錄扣丁學(xué)堂官網(wǎng)咨詢。扣丁學(xué)堂是專業(yè)的HTML5培訓(xùn)機(jī)構(gòu),不僅有專業(yè)的老師和與時俱進(jìn)的課程體系,還有大量的HTML5在線教程供學(xué)員掛看學(xué)習(xí)哦??鄱W(xué)堂H5技術(shù)交流群:559883758。
【關(guān)注微信公眾號獲取更多學(xué)習(xí)資料】
查看更多關(guān)于“HTML5開發(fā)技術(shù)資訊”的相關(guān)文章>>