91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

使用canvas怎么實現一個圓形進度條動畫

發布時間:2021-04-08 17:12:17 來源:億速云 閱讀:288 作者:Leah 欄目:web開發

這期內容當中小編將會給大家帶來有關使用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怎么實現一個圓形進度條動畫了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

横山县| 敦化市| 镇赉县| 龙陵县| 准格尔旗| 闸北区| 奈曼旗| 葫芦岛市| 宁强县| 孟津县| 定襄县| 宁明县| 乌审旗| 潢川县| 镶黄旗| 拜城县| 双辽市| 南乐县| 新巴尔虎左旗| 荔波县| 来安县| 普安县| 龙州县| 勐海县| 丽江市| 独山县| 信阳市| 原阳县| 南平市| 五常市| 峨山| 六盘水市| 孝感市| 南昌市| 朔州市| 墨脱县| 芜湖市| 和静县| 海林市| 芦山县| 涿州市|