echarts的饼图制作分析

echarts底层是使用canvas的类库ZRender实现的,提供直观,生动,可交互,可高度个性化定制的数据可视化图表。

看了echarts的饼状图,思考了他的实现方法


那么canvas怎么绘制饼状图呢?下面上代码:

var canvas=document.getElementById('canvas');
		var ctx = canvas.getContext('2d');
		var x = canvas.width/2,//饼图圆心x
			y = canvas.height/2,//饼图圆心y
			persent = 0.5,//半径占的百分比
			radial = (x>y?y:x)*persent,
			value1 = 20,
			value2=30,
			value3=40,
			sum=value1+value2+value3;
			//定义扇形方法,封装功能
		CanvasRenderingContext2D.prototype.sector = function(x,y,radial,start,end){
		this.beginPath();
		this.moveTo(x,y);
		this.arc(x,y,radial,start,end);
		this.closePath();
		return this;
		}
		ctx.fillStyle = 'red';
		//调用绘制扇形
		ctx.sector(x,y,radial,0,value1*2*Math.PI/sum).fill();
		ctx.fillStyle = 'green';
		ctx.sector(x,y,radial,value1*2*Math.PI/sum,(value1*2*Math.PI/sum+value2*2*Math.PI/sum)).fill();
		ctx.fillStyle = 'blue';
		ctx.sector(x,y,radial,(value1*2*Math.PI/sum+value2*2*Math.PI/sum),2*Math.PI).fill();


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值