javascript使用canvas实现饼状图效果


Posted in Javascript onSeptember 08, 2020

使用canvas写一个饼状图,供大家参考,具体内容如下

javascript使用canvas实现饼状图效果

代码:

<!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;
   //产生随机颜色
   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>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
让任务管理器中的CPU跳舞的js代码
Nov 01 Javascript
javascript 学习之旅 (1)
Feb 05 Javascript
ext checkboxgroup 回填数据解决
Aug 21 Javascript
你必须知道的Javascript知识点之&quot;字面量和对应类型&quot;说明介绍
Apr 23 Javascript
JQuery Tips相关(1)----关于$.Ready()
Aug 14 Javascript
js判断滚动条是否已到页面最底部或顶部实例
Nov 20 Javascript
jQuery中:password选择器用法实例
Jan 03 Javascript
javascript中CheckBox全选终极方案
May 20 Javascript
AngularJS 路由和模板实例及路由地址简化方法(必看)
Jun 24 Javascript
Bootstrap列表组学习使用
Feb 09 Javascript
Angular ElementRef简介及其使用
Oct 01 Javascript
小程序选项卡以及swiper套用(跨页面)
Jun 19 Javascript
vue配置多代理服务接口地址操作
Sep 08 #Javascript
全局安装 Vue cli3 和 继续使用 Vue-cli2.x操作
Sep 08 #Javascript
JS删除对象中某一属性案例详解
Sep 08 #Javascript
vue全局使用axios的操作
Sep 08 #Javascript
Vue自定义多选组件使用详解
Sep 08 #Javascript
vue项目中微信登录的实现操作
Sep 08 #Javascript
关于element-ui表单中限制输入纯数字的解决方式
Sep 08 #Javascript
You might like
Zerg建筑一览
2020/03/14 星际争霸
用PHP实现浏览器点击下载TXT文档的方法详解
2013/06/02 PHP
使用php 获取时间今天明天昨天时间戳的详解
2013/06/20 PHP
php5.3提示Function ereg() is deprecated Error问题解决方法
2014/11/12 PHP
TP5(thinkPHP框架)实现后台清除缓存功能示例
2019/05/29 PHP
jquery ajax对特殊字符进行转义防止js注入使用示例
2013/11/21 Javascript
setInterval计时器不准的问题解决方法
2014/05/08 Javascript
JS判断字符串包含的方法
2015/05/05 Javascript
小心!AngularJS结合RequireJS做文件合并压缩的那些坑
2016/01/09 Javascript
JavaScript正则表达式匹配 div  style标签
2016/03/15 Javascript
jQuery循环遍历子节点并获取值的方法
2016/04/14 Javascript
对称加密与非对称加密优缺点详解
2017/02/06 Javascript
angular json对象push到数组中的方法
2018/02/27 Javascript
浅谈AngularJS中$http服务的简单用法
2018/05/15 Javascript
微信小程序 scroll-view 实现锚点跳转功能
2019/12/12 Javascript
JavaScript中条件语句的优化技巧总结
2020/12/04 Javascript
python自动安装pip
2014/04/24 Python
Python 冒泡,选择,插入排序使用实例
2015/02/05 Python
详解Python中的元组与逻辑运算符
2015/10/13 Python
python从入门到精通(DAY 3)
2015/12/20 Python
利用python实现命令行有道词典的方法示例
2017/01/31 Python
Python基于QRCode实现生成二维码的方法【下载,安装,调用等】
2017/07/11 Python
简述:我为什么选择Python而不是Matlab和R语言
2017/11/14 Python
Python 实现使用dict 创建二维数据、DataFrame
2018/04/13 Python
python针对不定分隔符切割提取字符串的方法
2018/10/26 Python
python中的print()输出
2019/04/12 Python
TensorFlow车牌识别完整版代码(含车牌数据集)
2019/08/05 Python
python中struct模块之字节型数据的处理方法
2019/08/27 Python
利用CSS3实现单选框动画特效示例代码
2016/09/26 HTML / CSS
瑞士最大的图书贸易公司:Orell Füssli
2019/12/28 全球购物
医院实习介绍信
2014/01/12 职场文书
升旗仪式演讲稿
2014/05/08 职场文书
食堂厨师岗位职责
2014/08/25 职场文书
办公室文员岗位职责
2015/02/04 职场文书
情人节单身感言
2015/08/03 职场文书
大学生安全教育心得体会
2016/01/15 职场文书