window.onload = function init() {//绘制饼图 ?var data_arr = [0.5, 0.5]; ???????var color_arr = ["#26b899", "#b370cf"]; ???????var text_arr = ["补票", "卡"]; ???????drawCircle("canvas_circle", data_arr, color_arr, text_arr); ???????//绘制饼图 ???????function drawCircle(canvasId, data_arr, color_arr, text_arr) ???????{ ???????????var c = document.getElementById(canvasId); ???????????var ctx = c.getContext("2d"); ???????????var radius = c.height / 2 - 20; //半径 ???????????var ox = radius + 20, oy = radius + 20; //圆心 ???????????var width = 25, height = 15; //图例宽和高 ???????????var posX = ox * 2 + 20, posY = 70; ??// ???????????var textX = posX + width + 10, textY = posY + 15; ???????????var startAngle = 0; //起始弧度 ???????????var endAngle = 0; ??//结束弧度 ???????????for (var i = 0; i < data_arr.length; i++) ???????????{ ???????????????//绘制饼图 ???????????????endAngle = endAngle + data_arr[i] * Math.PI * 2; //结束弧度 ???????????????ctx.fillStyle = color_arr[i]; ???????????????ctx.beginPath(); ???????????????ctx.moveTo(ox, oy); //移动到到圆心 ???????????????ctx.arc(ox, oy, radius, startAngle, endAngle, false); ???????????????ctx.closePath(); ???????????????ctx.fill(); ???????????????startAngle = endAngle; //设置起始弧度 ???????????????//绘制比例图及文字 ???????????????ctx.fillStyle = color_arr[i]; ???????????????ctx.fillRect(posX, posY + 40 * i, width, height); ???????????????ctx.moveTo(posX, posY + 40 * i); ???????????????ctx.font = ‘18px 微软雅黑‘; ???//斜体 30像素 微软雅黑字体 ???????????????ctx.fillStyle = color_arr[i]; //"#000000"; ???????????????var percent = text_arr[i] + ":" + (100.*data_arr[i]).toFixed(2) + "%"; ???????????????ctx.fillText(percent, textX, textY + 40 * i); ???????????} ???????}}
html:
?<canvas id="canvas_circle" width="600" height="300"> ???????浏览器不支持canvas ???</canvas>
html 饼图统计
原文地址:https://www.cnblogs.com/a565810497/p/9792442.html