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

javascript使用canvas實現(xiàn)餅狀圖效果

 更新時間:2020年09月08日 15:12:07   作者:HaiRong_21  
這篇文章主要為大家詳細(xì)介紹了javascript使用canvas實現(xiàn)餅狀圖效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下

使用canvas寫一個餅狀圖,供大家參考,具體內(nèi)容如下

代碼:

<!DOCTYPE html>
<html lang="en">

<head>
 <meta charset="UTF-8">
 <meta name="viewport" content="width=device-width, initial-scale=1.0">
 <title>Document</title>
</head>

<body>
 <canvas id='canvas' width='800' height='400' style="border: 1px solid red;"></canvas>

 <script>
  let data = [
   { title: "服飾1", money: 400 },
   { title: "服飾2", money: 300 },
   { title: "服飾3", money: 400 },
   { title: "服飾4", money: 200 },
   { title: "服飾5", money: 500 },
   { title: "服飾6", money: 180 },
   { title: "服飾7", money: 500 }]

  /** @type {HTMLCanvasElement} */
  let canvas = document.querySelector("#canvas");
  let ctx = canvas.getContext("2d");
  let r = 100;

  let money = function (obj, sum) {
   for (let i = 0; i < obj.length; i++) {
    sum += data[i].money
    
   }
   return sum;
  }
  let totalmoney = money(data, 0);

  let nowsum = 0;
  let start = 0;
  let end = 0;
  let R = 100;
  let i=0;
  data.forEach(function (item) {
   ctx.beginPath()
   nowsum += item.money;
   end = (nowsum / totalmoney) 
   ctx.moveTo(150, 150);
   ctx.arc(150, 150, R, start*Math.PI*2, end*Math.PI*2)
   start = end;
   //產(chǎn)生隨機顏色
   ctx.fillStyle = '#' + Math.floor(Math.random() * 0xffffff).toString(16);
   ctx.rect(350,5+(35*i),30,30);
   ctx.font="14px 黑體"
   ctx.fillText(item.title,400,25+(35*i))
   ctx.strokeStyle = "gray"
   ctx.fill();
   ctx.stroke();
   i++;
  })
 </script>
</body>

</html>

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • JSON與String互轉(zhuǎn)的實現(xiàn)方法(Javascript)

    JSON與String互轉(zhuǎn)的實現(xiàn)方法(Javascript)

    下面小編就為大家?guī)硪黄狫SON與String互轉(zhuǎn)的實現(xiàn)方法(Javascript) 。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧,祝大家游戲愉快哦
    2016-09-09
  • alert中斷settimeout計時功能

    alert中斷settimeout計時功能

    在測試過程中發(fā)現(xiàn)alert會中斷settimeout的計時功能,關(guān)閉對話框后,settimeout的時間會重頭開始計時,而不是從中斷處,感興趣的朋友可以了解下
    2013-07-07
  • BootStrap Table復(fù)選框默認(rèn)選中功能的實現(xiàn)代碼(從數(shù)據(jù)庫獲取到對應(yīng)的狀態(tài)進(jìn)行判斷是否為選中狀態(tài))

    BootStrap Table復(fù)選框默認(rèn)選中功能的實現(xiàn)代碼(從數(shù)據(jù)庫獲取到對應(yīng)的狀態(tài)進(jìn)行判斷是否為選中狀態(tài))

    本文通過實例代碼給大家介紹了BootStrap Table復(fù)選框默認(rèn)選中功能(從數(shù)據(jù)庫獲取到對應(yīng)的狀態(tài)進(jìn)行判斷是否為選中狀態(tài)),代碼簡單易懂,非常不錯,具有參考借鑒價值,需要的的朋友參考下吧
    2017-07-07
  • JsonServer安裝及啟動過程圖解

    JsonServer安裝及啟動過程圖解

    這篇文章主要介紹了JsonServer安裝及啟動過程圖解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-02-02
  • Scala解析Json字符串的實例詳解

    Scala解析Json字符串的實例詳解

    這篇文章主要介紹了 Scala解析Json字符串的實例詳解的相關(guān)資料,希望通過本文能幫助到大家,讓大家學(xué)習(xí)理解這部分內(nèi)容,需要的朋友可以參考下
    2017-10-10
  • 最新評論