欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

HTML5canvas 繪制一個(gè)圓環(huán)形的進(jìn)度表示實(shí)例

 更新時(shí)間:2016年12月16日 11:38:01   投稿:lqh  
這篇文章主要介紹了HTML5canvas繪制一個(gè)圓環(huán)形的進(jìn)度表示實(shí)例的相關(guān)資料,需要的朋友可以參考下

HTML5 canvas 繪制圓環(huán)形進(jìn)度

先看一下畫出來的效果,如下圖,這樣一個(gè)圓環(huán)形的進(jìn)度.

 我這里使用HTML5的Canvas來要制作這樣一個(gè)圓環(huán)形的進(jìn)度,

首先是HTML頁面,HTML5的文檔標(biāo)識(shí)是:

<!DOCTYPE html>

 這個(gè)文檔標(biāo)識(shí)要比HTML4的簡(jiǎn)單多了.

 第二步,在頁面上創(chuàng)建一個(gè)Canvas畫布元素:

<canvas class="process" width="48px" height="48px">61%</canvas>

 我這里創(chuàng)建了一個(gè)長(zhǎng)寬都是48像素的畫布,因?yàn)槲乙嫷膱A外直徑是48個(gè)像素的,在canvas元素中間寫的是"61%",這個(gè)文字可不是顯示在圓環(huán)中間的那個(gè)哦,這個(gè)61%是當(dāng)老的瀏覽器不支持canvas元素時(shí)顯示的文字.

好了,到此為止HTML頁面的內(nèi)容就基本完成了,接下來就交給Javascript了,用Javascript來描繪圓環(huán). 

function drawProcess() { 
  // 選出頁面上所有class為process的canvas元素,然后迭代每一個(gè)元素畫圖(這里用Jquery的選擇器選的) 
  $('canvas.process').each(function() { 
      // 第一部先拿到canvas標(biāo)簽中間的文字,就是那個(gè)61%(這里的stringTrim方法是我自己的方法,去前后空格的方法很多的,這里就不貼出來了) 
    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è)畫布上畫圖,畫布上沒有東西,這步就不需要了 
    context.clearRect(0, 0, 48, 48); 
     
  // ***開始畫一個(gè)灰色的圓 
    context.beginPath(); 
      // 坐標(biāo)移動(dòng)到圓心 
    context.moveTo(24, 24); 
      // 畫圓,圓心是24,24,半徑24,從角度0開始,畫到2PI結(jié)束,最后一個(gè)參數(shù)是方向順時(shí)針還是逆時(shí)針 
    context.arc(24, 24, 24, 0, Math.PI * 2, false); 
    context.closePath(); 
      // 填充顏色 
    context.fillStyle = '#ddd'; 
    context.fill(); 
      // ***灰色的圓畫完 
     
    // 畫進(jìn)度 
    context.beginPath(); 
      // 畫扇形的時(shí)候這步很重要,畫筆不在圓心畫出來的不是扇形 
    context.moveTo(24, 24); 
      // 跟上面的圓唯一的區(qū)別在這里,不畫滿圓,畫個(gè)扇形 
    context.arc(24, 24, 24, 0, Math.PI * 2 * process / 100, false); 
    context.closePath(); 
    context.fillStyle = '#e74c3c'; 
    context.fill(); 
 
    // 畫內(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(); 
     
  // 畫一條線 
    context.beginPath(); 
    context.arc(24, 24, 18.5, 0, Math.PI * 2, true); 
    context.closePath(); 
      // 與畫實(shí)心圓的區(qū)別,fill是填充,stroke是畫線 
    context.strokeStyle = '#ddd'; 
    context.stroke(); 
     
      //在中間寫字 
    context.font = "bold 9pt Arial"; 
    context.fillStyle = '#e74c3c'; 
    context.textAlign = 'center'; 
    context.textBaseline = 'middle'; 
    context.moveTo(24, 24); 
    context.fillText(text, 24, 24); 
  } 

好了,畫完了.要看到效果別忘了調(diào)用一下畫圖的drawprocess方法哦.

大小: 2.4 KB 查看圖片附件

感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!

相關(guān)文章

  • JavaScript常見的跨標(biāo)簽頁通信方式總結(jié)

    JavaScript常見的跨標(biāo)簽頁通信方式總結(jié)

    跨標(biāo)簽頁通信是指在瀏覽器中的不同標(biāo)簽頁之間進(jìn)行數(shù)據(jù)傳遞和通信的過程,這篇文章為大家整理了前端常見的跨標(biāo)簽頁通信方式,有需要的小伙伴可以了解下
    2023-10-10
  • javascript伸縮菜單欄實(shí)現(xiàn)代碼分享

    javascript伸縮菜單欄實(shí)現(xiàn)代碼分享

    這篇文章主要介紹了javascript伸縮菜單欄實(shí)現(xiàn)代碼,點(diǎn)擊標(biāo)題顯示下級(jí)菜單,節(jié)約了空間,使頁面排版更加緊湊,感興趣的小伙伴們可以參考一下
    2015-11-11
  • document.execCommand()的用法小結(jié)

    document.execCommand()的用法小結(jié)

    本篇文章主要是對(duì)document.execCommand()的用法進(jìn)行了詳細(xì)的介紹,需要的朋友可以過來參考下,希望對(duì)大家有所幫助
    2014-01-01
  • 網(wǎng)絡(luò)之美 JavaScript中Get和Set訪問器的實(shí)現(xiàn)代碼

    網(wǎng)絡(luò)之美 JavaScript中Get和Set訪問器的實(shí)現(xiàn)代碼

    前兩天IE9 Beta版發(fā)布了,對(duì)于從事Web開發(fā)的朋友們來說真是個(gè)好消息啊,希望將來有一天各個(gè)瀏覽器都能遵循統(tǒng)一的標(biāo)準(zhǔn)。今天要和大家分享的是JavaScript中的Get和Set訪問器,和C#中的訪問器非常相似。
    2010-09-09
  • JavaScript編寫棋盤覆蓋代碼詳解

    JavaScript編寫棋盤覆蓋代碼詳解

    這篇文章主要介紹了JavaScript編寫棋盤覆蓋代碼詳解,需要的朋友可以參考下
    2017-08-08
  • js取消單選按鈕選中并判斷對(duì)象是否為空

    js取消單選按鈕選中并判斷對(duì)象是否為空

    取消單選按鈕選中并判斷對(duì)象是否為空,在項(xiàng)目中也是比較常見的,下面有個(gè)不錯(cuò)的示例,感興趣的朋友可以參考下
    2013-11-11
  • JavaScript面向?qū)ο笾薪涌趯?shí)現(xiàn)方法詳解

    JavaScript面向?qū)ο笾薪涌趯?shí)現(xiàn)方法詳解

    這篇文章主要介紹了JavaScript面向?qū)ο笾薪涌趯?shí)現(xiàn)方法,結(jié)合實(shí)例形式分析了javascript面向?qū)ο蠼涌诘母拍?、?shí)現(xiàn)方法及相關(guān)操作注意事項(xiàng),需要的朋友可以參考下
    2019-07-07
  • 原生js滑動(dòng)輪播封裝

    原生js滑動(dòng)輪播封裝

    這篇文章主要為大家詳細(xì)介紹了原生js滑動(dòng)輪播封裝,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-07-07
  • js實(shí)現(xiàn)表單Radio切換效果的方法

    js實(shí)現(xiàn)表單Radio切換效果的方法

    這篇文章主要介紹了js實(shí)現(xiàn)表單Radio切換效果的方法,涉及javascript實(shí)現(xiàn)頁面元素的隱藏與顯示及復(fù)選框的遍歷技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-08-08
  • TypeScript 中接口詳解

    TypeScript 中接口詳解

    TypeScript核心設(shè)計(jì)原則之一就是類型檢查,通過使用接口(Interfaces)可以進(jìn)行類型檢查,滿足傳統(tǒng)面向?qū)ο笏枷?,利于有效開發(fā),有效避免類型轉(zhuǎn)換問題。
    2015-06-06

最新評(píng)論