HTML5canvas 繪制一個(gè)圓環(huán)形的進(jìn)度表示實(shí)例
HTML5 canvas 繪制圓環(huán)形進(jìn)度
先看一下畫(huà)出來(lái)的效果,如下圖,這樣一個(gè)圓環(huán)形的進(jìn)度.

我這里使用HTML5的Canvas來(lái)要制作這樣一個(gè)圓環(huán)形的進(jìn)度,
首先是HTML頁(yè)面,HTML5的文檔標(biāo)識(shí)是:
<!DOCTYPE html>
這個(gè)文檔標(biāo)識(shí)要比HTML4的簡(jiǎn)單多了.
第二步,在頁(yè)面上創(chuàng)建一個(gè)Canvas畫(huà)布元素:
<canvas class="process" width="48px" height="48px">61%</canvas>
我這里創(chuàng)建了一個(gè)長(zhǎng)寬都是48像素的畫(huà)布,因?yàn)槲乙?huà)的圓外直徑是48個(gè)像素的,在canvas元素中間寫(xiě)的是"61%",這個(gè)文字可不是顯示在圓環(huán)中間的那個(gè)哦,這個(gè)61%是當(dāng)老的瀏覽器不支持canvas元素時(shí)顯示的文字.
好了,到此為止HTML頁(yè)面的內(nèi)容就基本完成了,接下來(lái)就交給Javascript了,用Javascript來(lái)描繪圓環(huán).
function drawProcess() {
// 選出頁(yè)面上所有class為process的canvas元素,然后迭代每一個(gè)元素畫(huà)圖(這里用Jquery的選擇器選的)
$('canvas.process').each(function() {
// 第一部先拿到canvas標(biāo)簽中間的文字,就是那個(gè)61%(這里的stringTrim方法是我自己的方法,去前后空格的方法很多的,這里就不貼出來(lái)了)
var text = commonutil.stringTrim($(this).text());
var process = text.substring(0, text.length-1);
// 一個(gè)canvas標(biāo)簽
var canvas = this;
// 拿到繪圖上下文,目前只支持"2d"
var context = canvas.getContext('2d');
// 將繪圖區(qū)域清空,如果是第一次在這個(gè)畫(huà)布上畫(huà)圖,畫(huà)布上沒(méi)有東西,這步就不需要了
context.clearRect(0, 0, 48, 48);
// ***開(kāi)始畫(huà)一個(gè)灰色的圓
context.beginPath();
// 坐標(biāo)移動(dòng)到圓心
context.moveTo(24, 24);
// 畫(huà)圓,圓心是24,24,半徑24,從角度0開(kāi)始,畫(huà)到2PI結(jié)束,最后一個(gè)參數(shù)是方向順時(shí)針還是逆時(shí)針
context.arc(24, 24, 24, 0, Math.PI * 2, false);
context.closePath();
// 填充顏色
context.fillStyle = '#ddd';
context.fill();
// ***灰色的圓畫(huà)完
// 畫(huà)進(jìn)度
context.beginPath();
// 畫(huà)扇形的時(shí)候這步很重要,畫(huà)筆不在圓心畫(huà)出來(lái)的不是扇形
context.moveTo(24, 24);
// 跟上面的圓唯一的區(qū)別在這里,不畫(huà)滿圓,畫(huà)個(gè)扇形
context.arc(24, 24, 24, 0, Math.PI * 2 * process / 100, false);
context.closePath();
context.fillStyle = '#e74c3c';
context.fill();
// 畫(huà)內(nèi)部空白
context.beginPath();
context.moveTo(24, 24);
context.arc(24, 24, 21, 0, Math.PI * 2, true);
context.closePath();
context.fillStyle = 'rgba(255,255,255,1)';
context.fill();
// 畫(huà)一條線
context.beginPath();
context.arc(24, 24, 18.5, 0, Math.PI * 2, true);
context.closePath();
// 與畫(huà)實(shí)心圓的區(qū)別,fill是填充,stroke是畫(huà)線
context.strokeStyle = '#ddd';
context.stroke();
//在中間寫(xiě)字
context.font = "bold 9pt Arial";
context.fillStyle = '#e74c3c';
context.textAlign = 'center';
context.textBaseline = 'middle';
context.moveTo(24, 24);
context.fillText(text, 24, 24);
}
好了,畫(huà)完了.要看到效果別忘了調(diào)用一下畫(huà)圖的drawprocess方法哦.
大小: 2.4 KB 查看圖片附件
感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
相關(guān)文章
JavaScript常見(jiàn)的跨標(biāo)簽頁(yè)通信方式總結(jié)
跨標(biāo)簽頁(yè)通信是指在瀏覽器中的不同標(biāo)簽頁(yè)之間進(jìn)行數(shù)據(jù)傳遞和通信的過(guò)程,這篇文章為大家整理了前端常見(jiàn)的跨標(biāo)簽頁(yè)通信方式,有需要的小伙伴可以了解下2023-10-10
javascript伸縮菜單欄實(shí)現(xiàn)代碼分享
這篇文章主要介紹了javascript伸縮菜單欄實(shí)現(xiàn)代碼,點(diǎn)擊標(biāo)題顯示下級(jí)菜單,節(jié)約了空間,使頁(yè)面排版更加緊湊,感興趣的小伙伴們可以參考一下2015-11-11
document.execCommand()的用法小結(jié)
本篇文章主要是對(duì)document.execCommand()的用法進(jìn)行了詳細(xì)的介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助2014-01-01
網(wǎng)絡(luò)之美 JavaScript中Get和Set訪問(wèn)器的實(shí)現(xiàn)代碼
前兩天IE9 Beta版發(fā)布了,對(duì)于從事Web開(kāi)發(fā)的朋友們來(lái)說(shuō)真是個(gè)好消息啊,希望將來(lái)有一天各個(gè)瀏覽器都能遵循統(tǒng)一的標(biāo)準(zhǔn)。今天要和大家分享的是JavaScript中的Get和Set訪問(wèn)器,和C#中的訪問(wèn)器非常相似。2010-09-09
JavaScript面向?qū)ο笾薪涌趯?shí)現(xiàn)方法詳解
這篇文章主要介紹了JavaScript面向?qū)ο笾薪涌趯?shí)現(xiàn)方法,結(jié)合實(shí)例形式分析了javascript面向?qū)ο蠼涌诘母拍?、?shí)現(xiàn)方法及相關(guān)操作注意事項(xiàng),需要的朋友可以參考下2019-07-07

