vue動態(tài)繪制四分之三圓環(huán)圖效果
參照網(wǎng)上的一個案例“參照的為繪制的是一個動態(tài)的圓環(huán)”,現(xiàn)在我的需求是改編成四分之三的圓環(huán)
實現(xiàn)效果:

樣式展示 canvas繪圖基本操作設(shè)置就可以
參考源代碼鏈接:原文:http://www.dbjr.com.cn/html5/682215.html
> 引用的上文源代碼進行修改,注意幾點
1. 理解繪制圓環(huán)的原理,是根據(jù)弧度進行繪制
2. 弧度的計算公式
3. 每一角度轉(zhuǎn)換成弧度
4. 起點和終點的坐標
> 自己畫個圖,方便理解!

首先根據(jù)圖可以看到起點和重點,看坐標知道起點是-240度,這個正負還是要區(qū)分的,每一弧度的計算公式
將角度轉(zhuǎn)換為弧度:
var radians = degrees * (Math.PI/180);
這樣就可以進行改版了
改版之后的代碼
`drawMain(drawing_elem, percent, forecolor, bgcolor,fillColor) {
/*
@drawing_elem: 繪制對象
@percent:繪制圓環(huán)百分比, 范圍[0, 100]
@forecolor: 繪制圓環(huán)的前景色,顏色代碼
@bgcolor: 繪制圓環(huán)的背景色,顏色代碼
*/
var context = drawing_elem.getContext('2d')
var center_x = drawing_elem.width / 2;
var center_y = drawing_elem.height / 2;
var rad = Math.PI/3*5/100; //繪制的為300度的圓
// 65 * Math.PI / 180, 115 * Math.PI / 180
// var speed = 0;
// 繪制背景圓圈
function backgroundCircle(){
context.save();
context.beginPath();
context.lineWidth = 8; //設(shè)置線寬
var radius = center_x - context.lineWidth;
context.lineCap = "round";
context.strokeStyle = bgcolor;
context.arc(center_x, center_y, radius,-Math.PI/180*240, Math.PI/180*60, false);
**起點,終點,半徑,開始點,結(jié)束點,是否順/逆時針**
context.stroke();
context.closePath();
context.restore();
}
//繪制運動圓環(huán)
function foregroundCircle(n){
context.save();
context.strokeStyle = forecolor;
context.lineWidth = 8;
context.lineCap = "round";
var radius = center_x - context.lineWidth;
// console.log(endAngle)
context.beginPath();
context.arc(center_x, center_y, radius ,-Math.PI/180*240 ,-Math.PI/180*240+n*rad , false); //用于繪制圓弧context.arc(x坐標,y坐標,半徑,起始角度,終止角度,順時針/逆時針)
context.stroke();
context.closePath();
context.restore();
}
//繪制文字
function text(n){
context.save(); //save和restore可以保證樣式屬性只運用于該段canvas元素
context.fillStyle = fillColor;
var font_size = 20;
context.font = font_size + "px Helvetica";
var text_width = context.measureText(n.toFixed(0)+"%").width;
context.fillText(n.toFixed(0)+"%", center_x-text_width/2, center_y + font_size/2);
context.restore();
}
//執(zhí)行動畫
(function drawFrame(){
// 去掉動畫加載效果
// window.requestAnimationFrame(drawFrame);
// context.clearRect(0, 0, drawing_elem.width, drawing_elem.height);
backgroundCircle();
text(percent);
foregroundCircle(percent);
**// 去掉動畫加載效果,這兩行代碼,由于網(wǎng)速加載慢的時候繪制的比較慢,動態(tài)效果繪制的太緩慢,所以去掉了**
// if(speed >= percent) return;
// speed += 1;
}());
},
接下來就是調(diào)用該方法了,調(diào)用的時候放到了nextTick中,當時遇到的問題就是加載只能加載第一個,下面的加載不出來,自我感覺加載順序的問題,繪制了但是沒渲染出來
this.$nextTick(()=>{
for(var i =0;i<this.couponCenterLists.length;i++) {
this.childrenTag = document.getElementById("time-graph-canvas"+i);
let score = this.couponCenterLists[i].couponPercentage * 100;
this.drawMain(this.childrenTag, score, "#fff", "rgba(255,255,255,0.4)","#fff");
**score變量是我從接口取出來的數(shù)據(jù)存到了score變量中**
}
})
總結(jié)
以上所述是小編給大家介紹的vue動態(tài)繪制四分之三圓環(huán)圖效果,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!
相關(guān)文章
vue 實現(xiàn)可拖曳的樹狀結(jié)構(gòu)圖
這篇文章主要介紹了vue 實現(xiàn)可拖曳的樹狀結(jié)構(gòu)圖,幫助大家更好的理解和學(xué)習使用vue框架,感興趣的朋友可以了解下2021-04-04
elementui 日期選擇器el-date-picker如何給指定日期添加圓點標注
這篇文章主要介紹了elementui 日期選擇器el-date-picker如何給指定日期添加圓點標注,本文通過實例代碼給大家介紹的非常詳細,需要的朋友可以參考下2024-07-07
vue+element樹組件 實現(xiàn)樹懶加載的過程詳解
這篇文章主要介紹了vue+element樹組件 實現(xiàn)樹懶加載的過程,本文通過圖文實例代碼相結(jié)合給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2019-10-10
Vue項目pdf(base64)轉(zhuǎn)圖片遇到的問題及解決方法
這篇文章主要介紹了Vue項目pdf(base64)轉(zhuǎn)圖片遇到的問題及解決方法,需要的朋友可以參考下2018-10-10
在vue中使用echarts(折線圖的demo,markline用法)
這篇文章主要介紹了在vue中使用echarts(折線圖的demo,markline用法),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-07-07

