当我们使用Echrts很Highcharts的时候,总是觉得各种统计图表是多么神奇,今天我就用现代浏览器支持的canvas来绘制饼状统计图,当然仅仅是画出图并没什么难度,但是统计图一般都有输入,根据不同的输入来绘制,需要发挥你脑力。

1.canvas简单使用

1.1先看我们的html,需要一个绘图的区域

<canvas id="drawing" width="500px" height="500px"></canvas>

1.2获取绘图区域,并且判断浏览器是否支持canvas绘图

var drawing = document.getElementById('drawing')//获取绘图区域
if(drawing.getContext){
context = drawing.getContext('2d')
}else{
  alert('浏览器不支持canvas')
}

1.3介绍简单的api(这里的context指的是上面获取的绘图区域)

  context.beginPath() 绘图开始,一个图可以分多次绘制,例如饼状图每个小部分都是一次完整的绘制,为了填充不同颜色,都需要多次开始和结束

  context.closePath() 本部分绘制结束

  context.moveTo(100,100) 抬笔移动到100,100位置,过程中不留下痕迹

  context.lineTo(100,100) 从某个起点绘制到100,100这个坐标的,

  context.fill() 开始填充,可以先设置填充颜色,context.fillStyle = 'blue';设置填充色,然后在调用context.fill()开始填充本部分

  context.stroke() 描边,就是轮廓的颜色,可以先设置颜色,context.strokeStyle="red",然后调用context.stroke()描边

2.开始我们的封装绘制方法

2.1开始封装绘制方法

    /*下列插件传递json的格式{
     ele:ele
    data:[1,2,3,4]
}*/
function Circle(json) {
this.ele = json.ele;//绘制区域元素
this.data = json.data;//输入的数据
this.step = 0;//绘制的步骤,几个数据,分几次绘制
this.start=0;//其实位置初始化
this.end = 0;//借宿位置初始化
this.init(); //调用初始化方法 }
Circle.prototype.init=function(){
if(this.ele.getContext){ //判断知否支持canvas
this.context = this.ele.getContext('2d')
}else{
console.log('不支持canvas')
}
this.sum() //先统计数据和,以便得到每个数据的占比
this.drawing() //开始绘制
}
Circle.prototype.drawing=function(){
if(this.step >= this.data.length){//超过数据个数,就停止绘制
return
}
this.math()//计算起点和终点
this.context.beginPath();//绘制开始
this.context.fillStyle = Circle.prototype.color();//填充颜色
this.context.moveTo(250,250)//绘制起点移动到的位置,moveTo就像抬笔到某处,过程中不留下痕迹
this.context.arc(250,250,160,this.start,this.end,false)//画圆开始,属性分别是('圆心X轴坐标','原型Y轴坐标','起点','终点',是否逆时针) this.context.lineTo(250,250)//再绘制直线到圆心,这样形成封闭区域,才可以填充颜色
this.context.fill()//填充颜色
this.context.closePath();//关闭绘图
this.step++;//接着下一步骤的绘制
this.drawing() }
Circle.prototype.math = function(start,end){//每次绘制是计算起点和终点
this.start=this.end;
this.end = this.start+this.data[this.step]/this.total*2*Math.PI; }
Circle.prototype.color=function(){//随机颜色的生成
var color="#";
for(var i = 0;i < 6;i++){
color+= parseInt(Math.random()*17).toString(16);
}
return color;
}
Circle.prototype.sum = function(){//得到数据的总和,以便得到每个数据的占比
this.total = this.data.reduce(function(a, b){
return a + b;
});
}

2.2调用方法

var drawing = document.getElementById('drawing')
var img =new Circle({
ele:drawing,
data:[1,2,3,4]
})

2.3查看效果图,(因为我们的填充颜色是随机的,所以每次刷新的饼状图每部分的颜色都会变化)

我的源码地址在https://github.com/jiangzhenfei/canvas/blob/master/circle.html

canvas动态绘制饼状图,的更多相关文章

  1. Canvas(3)---绘制饼状图

    Canvas(3)---绘制饼状图 有关canvas之前有写过两篇文章 1.Canvas(1)---概述+简单示例 2.Canvas(2)---绘制折线图 在绘制饼状图之前,我们先要理解什么是圆弧,如 ...

  2. 第166天:canvas绘制饼状图动画

    canvas绘制饼状图动画 1.HTML <!DOCTYPE html> <html lang="en"> <head> <meta ch ...

  3. 用PNChart绘制饼状图简介

    写在前面 最近做的小Demo中有一个绘制饼状图的需求.在开始实现之前上网了解了一下现有的一些绘制图形的第三方库,相应的库还是有挺多的,PNChart便是其中一个.PNChart是一个90后的中国boy ...

  4. [canvas]用canvas绘制饼状图

    折线图之后又来饼状图啦~\(≧▽≦)/~啦啦啦 <!DOCTYPE html> <html lang="en"> <head> <meta ...

  5. Graphic系统综合练习案例-绘制饼状图

    这里用一个案例来将之前学过的关于绘制相关的东东加强巩固一下,纯绘制,木有加点击效果,先来看下最终效果: github中这种百分比饼图的效果非常非常之多,实际在项目中开发当产品有这样类似的需求时做为开发 ...

  6. IOS之以UIBezierPath绘制饼状图

    1.绘制的饼状图是通过多个扇形拼和而成,绘制一个扇形也是比较简单的,核心代码如下: 先画一条圆弧,再画半径,接着再画一条圆弧,最后闭合路径: UIBezierPath*  aPath = [[UIBe ...

  7. [Echarts]用Echarts绘制饼状图

    在项目网站的网页中,有这样一幅图: 心血来潮,想使用百度Echarts来绘制一下,可是没能绘制得完全一样,Echarts饼状图的label不能在图形下面放成一行,最后的效果是这样子的: 鼠标移动到it ...

  8. d3绘制饼状图

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  9. matplotlib绘制饼状图

    源自http://blog.csdn.net/skyli114/article/details/77508430?ticket=ST-41707-PzNbUDGt6R5KYl3TkWDg-passpo ...

随机推荐

  1. Objective-C反射机制

    oc反射机制有三个用途: 1.获得Class Class LoginViewController = NSClassFromString(@"LoginViewController" ...

  2. oracle12c 新建表空间

    第1步:创建临时表空间 create temporary tablespace jeeplus_temp tempfile 'D:\app\Administrator\virtual\product\ ...

  3. Qt 实现在隐藏标题栏情况下,窗口的缩放(未成功)

    呃,这是一个悲剧的版本,在这版本中,我按照网上大神的说法,试了一下,但是没有效果,不知道出错在了那里,和昨天一样,也是,没有理想的效果,这里贴上代码,记录一下 资料连接:放评论 需要包含头文件 #in ...

  4. C++学习004-Go To 语句使用

    C++中,goto语句主要负责语句的跳转,可以用在循环中跳出循环 注意gotu语句是无条件跳转,用的时候一定要谨慎,一定要少 编写环境 Qt 5.7 for(int i = 0;i<100;i+ ...

  5. Page Object 设计模式介绍

    Page Object 是 Selenium 自动化测试项目开发实践的最佳设计模式之一,Page Object 的主要体现于对界面交互细节的封装,这样可以使测试案例更关注与业务而非界面细节,提高测试案 ...

  6. 3、shader深度测试(Cull、ZWrite 、ZTest )

    剔除和深度测试是渲染法线中的一个流程 Cull:默认情况下,Unity中给的所有Shader都是单面的,它都把反面的渲染给关闭掉了,如果你在开发的过程中需要使用到双面,只要把cull关闭(off)即可 ...

  7. [Linux] umount目录提示device is busy的解决方法

    使用sshfs等方式挂载的目录出现问题时,使用umount卸载经常提示device is busy,如果仔细阅读错误提示就可以找到命令lsof和fuser命令. 其实原因就是有进程占用当前目录,导致不 ...

  8. Tensorflow Estimators

    这篇文章介绍tf.estimator,一个高级TensorFlow API,可以极大简化机器学习编程.Estimators封装了下面几个活动. 训练 评估 预测 出口服务(export for ser ...

  9. tensorflow Importing Data

    tf.data API可以建立复杂的输入管道.它可以从分布式文件系统中汇总数据,对每个图像数据施加随机扰动,随机选择图像组成一个批次训练.一个文本模型的管道可能涉及提取原始文本数据的符号,使用查询表将 ...

  10. MyBatis实例教程--开发环境搭建

    MyBatis实例教程--开发环境搭建 准备工作: 1.mybatis 的开发环境搭建,选择: eclipse j2ee 版本,mysql 5.1 ,jdk 1.7,mybatis3.2.0.jar包 ...