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 相关文章推荐
utf8的编码算法 转载
Dec 27 Javascript
Jquery中显示隐藏的实现代码分析
Jul 26 Javascript
JS实现仿京东淘宝竖排二级导航
Dec 08 Javascript
JQuery实现的购物车功能(可以减少或者添加商品并自动计算价格)
Jan 13 Javascript
js+css实现文字散开重组动画特效代码分享
Aug 21 Javascript
JS+CSS实现简易的滑动门效果代码
Sep 24 Javascript
JavaScript对象数组如何按指定属性和排序方向进行排序
Jun 15 Javascript
JS中的hasOwnProperty()和isPrototypeOf()属性实例详解
Aug 11 Javascript
Vue-cli项目获取本地json文件数据的实例
Mar 07 Javascript
微信小程序获取用户信息的两种方法wx.getUserInfo与open-data实例分析
May 03 Javascript
微信小程序实现类似微信点击语音播放效果
Mar 30 Javascript
微信小程序实现限制用户转发功能的实例代码
Feb 22 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
详细介绍:Apache+PHP+MySQL配置攻略
2006/09/05 PHP
PHP setcookie() cannot modify header information 的解决方法
2009/01/09 PHP
PHP 写文本日志实现代码
2010/05/18 PHP
PHP插入排序实现代码
2013/04/04 PHP
thinkPHP5.0框架配置格式、加载解析与读取方法
2017/03/17 PHP
jquery 选项卡效果 新手代码
2011/07/08 Javascript
简单总结JavaScript中的String字符串类型
2016/05/26 Javascript
ionic+AngularJs实现获取验证码倒计时按钮
2017/04/22 Javascript
详解Javascript获取缓存和清除缓存API
2017/05/25 Javascript
在Vue中使用echarts的方法
2018/02/05 Javascript
在Vue methods中调用filters里的过滤器实例
2018/08/30 Javascript
JS正则表达式封装与使用操作示例
2019/05/15 Javascript
Vue封装Axios请求和拦截器的步骤
2020/09/16 Javascript
在RedHat系Linux上部署Python的Celery框架的教程
2015/04/07 Python
python中enumerate函数用法实例分析
2015/05/20 Python
巧用python和libnmapd,提取Nmap扫描结果
2016/08/23 Python
利用Python实现网络测试的脚本分享
2017/05/26 Python
Python分支语句与循环语句应用实例分析
2019/05/07 Python
CSS3动画:5种预载动画效果实例
2017/04/05 HTML / CSS
最好的意大利皮夹克:D’Arienzo
2018/12/04 全球购物
美国地毯购买网站:Rugs USA
2019/02/23 全球购物
德国亚马逊官方网站:Amazon.de
2020/11/15 全球购物
为什么要用EJB
2014/04/17 面试题
财务方面个人工作的自我评价
2013/12/28 职场文书
护理专业优质毕业生自荐书
2014/01/31 职场文书
竞选学生会演讲稿
2014/04/25 职场文书
给校长的建议书500字
2014/05/15 职场文书
高中美术教师事迹材料
2014/08/22 职场文书
关键在于落实心得体会
2014/09/03 职场文书
青年文明号汇报材料
2014/12/23 职场文书
2015小学毕业班工作总结
2015/07/21 职场文书
Python开发工具Pycharm的安装以及使用步骤总结
2021/06/24 Python
使用goaccess分析nginx日志的详细方法
2021/07/09 Servers
深入浅析Django MTV模式
2021/09/04 Python
pd.drop_duplicates删除重复行的方法实现
2022/06/16 Python
Nginx如何配置根据路径转发详解
2022/07/23 Servers