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 相关文章推荐
关于二级域名下使用一级域名下的COOKIE的问题
Nov 07 Javascript
JavaScript中的私有/静态属性介绍
Jul 26 Javascript
如何用js控制frame的隐藏或显示的解决办法
Mar 20 Javascript
使用typeof判断function是否存在于上下文
Aug 14 Javascript
jQuery中:reset选择器用法实例
Jan 04 Javascript
JavaScript数据结构和算法之二叉树详解
Feb 11 Javascript
jQuery实现仿微软首页感应鼠标变化滑动窗口效果
Oct 08 Javascript
javascript for-in有序遍历json数据并探讨各个浏览器差异
Nov 30 Javascript
纯JS代码实现隔行变色鼠标移入高亮
Nov 23 Javascript
footer定位页面底部(代码分享)
Mar 07 Javascript
jQuery序列化form表单数据为JSON对象的实现方法
Sep 20 jQuery
vue实现中部导航栏布局功能
Jul 30 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中根据IP地址判断城市实现城市切换或跳转代码
2012/09/04 PHP
鸡肋的PHP单例模式应用详解
2013/06/03 PHP
PHP数据库万能引擎类adodb配置使用以及实例集锦
2014/06/12 PHP
php获取网页请求状态程序示例
2014/06/17 PHP
作为程序员必知的16个最佳PHP库
2015/12/09 PHP
PHP添加文字水印或图片水印的水印类完整源代码与使用示例
2019/03/18 PHP
一个加密JavaScript的开源工具PACKER2.0.2
2006/11/04 Javascript
js获取图片大小的函数代码
2011/09/20 Javascript
关于使用 jBox 对话框的提交不能弹出问题解决方法
2012/11/07 Javascript
javascript 图片裁剪技巧解读
2012/11/15 Javascript
angular十大常见问题
2017/03/07 Javascript
微信小程序的日期选择器的实例详解
2017/09/29 Javascript
JS实现显示当前日期的实例代码
2018/07/03 Javascript
layui自己添加图片按钮并点击跳转页面的例子
2019/09/14 Javascript
Electron 调用命令行(cmd)
2019/09/23 Javascript
[47:55]Ti4第二日主赛事败者组 NaVi vs EG 1
2014/07/20 DOTA
[37:37]DAC2018 4.4 淘汰赛 Optic vs Mineski 第二场
2018/04/05 DOTA
Python下的Mysql模块MySQLdb安装详解
2014/04/09 Python
python写xml文件的操作实例
2014/10/05 Python
Python制作CSDN免积分下载器
2015/03/10 Python
Python中设置变量访问权限的方法
2015/04/27 Python
python 爬取微信文章
2016/01/30 Python
对python 判断数字是否小于0的方法详解
2019/01/26 Python
Python shutil模块用法实例分析
2019/10/02 Python
Python HTMLTestRunner可视化报告实现过程解析
2020/04/10 Python
python中uuid模块实例浅析
2020/12/29 Python
巴西最大的家电和百货零售商:Casas Bahia
2016/11/22 全球购物
Black Halo官方网站:购买连衣裙、礼服和连体裤
2018/06/13 全球购物
财会自我鉴定范文
2013/12/27 职场文书
生育关怀行动实施方案
2014/03/26 职场文书
母校寄语大全
2014/04/10 职场文书
大学新生军训方案
2014/05/03 职场文书
物流专业自荐信
2014/05/23 职场文书
刑事附带民事代理词
2015/05/25 职场文书
二十年同学聚会致辞
2015/07/28 职场文书
Python利用机器学习算法实现垃圾邮件的识别
2021/06/28 Python