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 相关文章推荐
代码精简的可以实现元素圆角的js函数
Jul 21 Javascript
javascript新手语法小结
Jun 15 Javascript
JQuery给元素绑定click事件多次执行的解决方法
May 29 Javascript
ECMAScript6中Map/WeakMap详解
Jun 12 Javascript
JS简单实现无缝滚动效果实例
Aug 24 Javascript
ES6中Iterator与for..of..遍历用法分析
Mar 31 Javascript
js模拟支付宝密码输入框
Apr 11 Javascript
vue自定义底部导航栏Tabbar的实现代码
Sep 03 Javascript
Vue.js实现的购物车功能详解
Jan 27 Javascript
PostgreSQL Node.js实现函数计算方法示例
Feb 12 Javascript
uin-app+mockjs实现本地数据模拟
Aug 26 Javascript
微信小程序canvas实现签名功能
Jan 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
PHP中使用imagick生成PSD文件缩略图教程
2015/01/26 PHP
laravel 使用事件系统统计浏览量的实现
2019/10/16 PHP
自适应高度框架 ----属个人收藏内容
2007/01/22 Javascript
js验证模型自我实现的具体方法
2013/06/21 Javascript
jquery动态改变onclick属性导致失效的问题解决方法
2013/12/04 Javascript
类似天猫商品详情随浏览器移动的示例代码
2014/02/27 Javascript
基于socket.io和node.js搭建即时通信系统
2014/07/30 Javascript
javascript版2048小游戏
2015/03/18 Javascript
JQuery中Ajax()的data参数类型实例分析
2015/12/15 Javascript
javascript深拷贝(deepClone)详解
2016/08/24 Javascript
JS实现密码框的显示密码和隐藏密码功能示例
2016/12/26 Javascript
Spring Boot+AngularJS+BootStrap实现进度条示例代码
2017/03/02 Javascript
JavaScript实现换肤功能
2017/09/15 Javascript
angular的输入和输出的使用方法
2018/09/22 Javascript
解决layer弹出层msg的文字不显示的问题
2019/09/11 Javascript
Python中动态获取对象的属性和方法的教程
2015/04/09 Python
python sys.argv[]用法实例详解
2018/05/25 Python
pandas 将索引值相加的方法
2018/11/15 Python
踩坑:pytorch中eval模式下结果远差于train模式介绍
2020/06/23 Python
用Python实现童年贪吃蛇小游戏功能的实例代码
2020/12/07 Python
美国最灵活的移动提供商:Tello
2017/07/18 全球购物
俄罗斯家居用品购物网站:Евродом
2020/11/21 全球购物
澳大利亚美容产品及化妆品在线:Activeskin
2020/06/03 全球购物
租房协议书
2014/04/10 职场文书
《风娃娃》教学反思
2014/04/19 职场文书
人力资源管理专业应届生求职信
2014/04/24 职场文书
优秀安全员事迹材料
2014/05/11 职场文书
管理提升方案
2014/06/04 职场文书
2014年大学生党员自我评议
2014/09/22 职场文书
纪录片信仰观后感
2015/06/08 职场文书
小学感恩主题班会
2015/08/12 职场文书
2019客服个人年终工作总结范文
2019/07/08 职场文书
详解JS ES6编码规范
2021/05/07 Javascript
MongoDB 常用的crud操作语句
2021/06/20 MongoDB
SQLServer中exists和except用法介绍
2021/12/04 SQL Server
Mysql数据库表中为什么有索引却没有提高查询速度
2022/02/24 MySQL