国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > HTML5 > 正文

html5 canvas簡單封裝一個echarts實現不了的餅圖

2024-09-05 07:22:32
字體:
來源:轉載
供稿:網友

說明

我用echars很久了,如果出現如上圖所示樣式的餅圖,我用echarts很難實現,官方給的文檔沒有這種模式的餅圖。試過用d3和canvas分別畫餅圖,因為本人對canvas比較熟悉和d3還要引入插件,本著輕量化的原則,所以采用canvas封裝。

官方餅圖兩種模式:(1)半徑模式(2)面積模式

實現過程

(1)封裝的函數如下:

function drawCircle(canvasId, option) {    const color_arr = option.color    let data_arr = option.data    const pi2 = Math.PI * 2;    let canvas = document.getElementById(canvasId);    let c = canvas.getContext("2d");    let startAgl = 0;    let agl;    let sum = 0;    const cW = canvas.width;    const cH = canvas.height;    for (let item of data_arr) {      sum += item.value * 1.0    }    data_arr = data_arr.map((v, i) => {      return {        name: v.name,        value: (v.value) * 1.0 / sum      }    })    for (let i = 0; i < data_arr.length; i++) {      //繪制餅圖      let min = (cW > cH ? cH : cW); //獲取canvas寬高的最小值      agl = data_arr[i].value * pi2 + startAgl; //終點      c.strokeStyle = color_arr[i];      c.lineWidth = data_arr[i].value * min * 0.3; // 線的粗細      c.beginPath();      c.arc(cW / 2, cH / 2, min * 0.3, startAgl, agl, false); //畫圓      c.stroke();      c.closePath();      startAgl = agl;      //繪制圖例      c.fillStyle = color_arr[i];      c.fillRect(cW * 0.8, 50 + 18 * i, 16, 16);      c.fillText(data_arr[i].name, cW * 0.8 + 20, 62 + 18 * i);    }  }

(2)調用方式:

let color = ['#0580F2', '#FAA732', '#E1575D', '#8B73CC', '#8CD123', '#4B53BA', '#429588'];  let option = {    color: color,    data: [      { name: '20', value: '20' },      { name: '30', value: '30' },      { name: '40', value: '40' },      { name: '50', value: '50' },      { name: '60', value: '60' },    ]  }  drawCircle('myCanvas', option)

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 丰镇市| 武穴市| 唐河县| 阿荣旗| 涿州市| 衡阳县| 大田县| 沙坪坝区| 井陉县| 吉林省| 桐梓县| 龙里县| 绿春县| 佳木斯市| 海门市| 阿荣旗| 博白县| 砀山县| 安新县| 荥经县| 逊克县| 商都县| 乐陵市| 阿鲁科尔沁旗| 东宁县| 平遥县| 商河县| 威远县| 长岭县| 呼玛县| 房产| 七台河市| 南召县| 太仓市| 汉沽区| 白水县| 新安县| 门源| 阳西县| 搜索| 宣化县|