一个简单地svg绘制饼图的demo,代码如下

<!DOCTYPE html>
<html> <head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" />
<meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
<title>chart</title>
<style>
#container {
width: 400px;
height: 400px;
}
</style>
</head> <body>
<div id="container"></div>
<script>
var data = [
{name: '苹果', value: 5},
{name: '香蕉', value: 10},
{name: '橙子', value: 8},
{name: '梨子', value: 16}
];
myChartPie(
document.getElementById('container'),
data
);
function myChartPie(ele,data) {
var rectx = 100; // x 半径
var recty = 100; // y 半径
var pointx = 200; // 圆心坐标x
var pointy = 200; //圆心坐标y
var pathhtml = '';
var html = '<svg xlms="http://www.w3c.org/2000/svg" version="1.1" width="800" height="800">'
var htmlclose = "</svg>";
var count = 0;
for (var j = 0;j < data.length;j++) {
count = count + (data[j].value-0);
}
var cx = 200; //起始点x
var cy = 100; //起始点y
var cxto = 0; //结束点x
var cyto = 0; // 结束点y
var countsqrt = 0;
for (var i = 0;i < data.length;i++) {
// 角度
countsqrt += data[i].value;
var sqrt = countsqrt / count;
if (data[i].value / count > 1 * 0.5) {
cxto = pointx + rectx * Math.sin(Math.PI * 2 * sqrt);
cyto = pointy - recty * Math.cos(Math.PI * 2 * sqrt);
pathhtml += '<path fill="' + MathColor(0,255) + '" stroke="' + '#000' + '"d="' + 'M ' + cx + ' ' + cy + ' ' +
'A ' + rectx + ' ' + recty + ' ' + '0 1 1 ' + cxto + ' ' + cyto + ' ' +
'L ' + pointx + ' ' + pointy + ' Z'
+ '"></path>';
}else {
cxto = pointx + rectx * Math.sin(Math.PI * 2 * sqrt);
cyto = pointy - recty * Math.cos(Math.PI * 2 * sqrt);
pathhtml += '<path fill="' + MathColor(0,255) + '" stroke="' + '#000' + '"d="' + 'M ' + cx + ' ' + cy + ' ' +
'A ' + rectx + ' ' + recty + ' ' + '0 0 1 ' + cxto + ' ' + cyto + ' ' +
'L ' + pointx + ' ' + pointy + ' Z'
+ '"></path>';
}
cx = cxto;
cy = cyto;
}
ele.innerHTML = html + pathhtml + htmlclose;
}
function MathColor (x,y) {
var r = Math.floor(Math.random() * (y-x + 1)) + x;
var g = Math.floor(Math.random() * (y-x + 1)) + x;
var b = Math.floor(Math.random() * (y-x + 1)) + x;
return 'rgb(' + r + ',' + g + ',' + b + ')';
}
</script>
</body> </html>

svg绘制一个简单地饼图的更多相关文章

  1. opengl学习笔记(五):组合变换,绘制一个简单的太阳系

    创建太阳系模型 描述的程序绘制一个简单的太阳系,其中有一颗行星和一颗太阳,用同一个函数绘制.需要使用glRotate*()函数让这颗行星绕太阳旋转,并且绕自身的轴旋转.还需要使用glTranslate ...

  2. Quartz2D之绘制一个简单的机器猫

    学习iOS有一段时间了,在博客园也默默的潜水了两个月,见识了很多大神,收获不少. 今天整理笔记,发现忘记的不少,我感觉需要及时的整理一下了,同时也把做的小东西贴上来和大家分享一下. 最近学习了Quar ...

  3. SVG绘制圆形简单示例分享

    今天分享“svg绘制圆形”部分 1.简单圆形 效果图如下: 关键代码: <svg xmlns="http://www.w3.org/2000/svg" version=&qu ...

  4. 如何使用openscad绘制一个简单的键帽.

    1 新建空项目 2测数据 测量得出数据.这个长方体的长宽高分别是1.6.4.6.8 注意,这三个数据并不是测量得到的数据,而且加了一点公差值(为3D打印做准备) 3画图 写代码 导入模型 为了方便以后 ...

  5. SVG绘制矩形简单示例分享

    最近我初学HTML5,刚在一步步学习SVG,积累了一些个人心得和程序代码,希望和大家分享,今天分享“svg之矩形”部分 1.简单矩形 效果图如下: 关键代码: <svg xmlns=" ...

  6. Unity3D学习笔记2——绘制一个带纹理的面

    目录 1. 概述 2. 详论 2.1. 网格(Mesh) 2.1.1. 顶点 2.1.2. 顶点索引 2.2. 材质(Material) 2.2.1. 创建材质 2.2.2. 使用材质 2.3. 光照 ...

  7. JavaScript+svg绘制的一个饼状图

    结果: svg参考:https://www.w3.org/TR/SVG/<body onload='document.body.appendChild( pieChart([12,23,34,4 ...

  8. 如何用DAX实现查看每个月中不同类别排名前一位,以及一个简单的svg案例

    现在给大家带来的是如何用DAX实现查看每个月中不同类别的排名前一位,最终完成效果如下!!! 首先我们需要两张简单的表 基数表 和类别表 当我们创建好表之后,我们再创建一个表格,然后我们将类别表里的列值 ...

  9. VC6下OpenGL 开发环境的构建外加一个简单的二维网络棋盘绘制示例

    一.安装GLUT 工具包 GLUT 不是OpenGL 所必须的,但它会给我们的学习带来一定的方便,推荐安装. Windows 环境下的GLUT 本地下载地址:glut-install.zip(大小约为 ...

随机推荐

  1. Java高级框架-----Spring(一)

    一: 1. Spring几大核心功能: IOC/DI 控制反转/依赖注入 AOP 面向切面编程 声明式事务 2. Spring 框架的的runtime 2.1 test:Spring提供测试功能 2. ...

  2. ReentrantLock原理

    ReentrantLock主要利用CAS+CLH队列来实现.它支持公平锁和非公平锁,两者的实现类似. CAS:Compare and Swap,比较并交换.CAS有3个操作数:内存值V.预期值A.要修 ...

  3. java.lang.IllegalArgumentException: Document base XXX does not exist or is not a readable directory解决方法

    一.配置Eclipse,部署项目 1.双击打开Tomcat设置页面 2.选择Modules模式 3.选择Add External Web Module.. (1)Document base:选择htd ...

  4. AET PN结

    电场方向 电场方向和正电荷受力方向相同 飘移运动和扩散运动 多子和电场方向互相抵制,而多子是扩散运动,而对少子则是促进作用,当扩散和漂移达到动态平衡时,我们称PN结形成 PN结特性 单项导电性

  5. python-day3集合、文件读写、函数

    @集合运算 s.union(t) s | t 返回一个新的 set 包含 s 和 t 中的每一个元素 s.intersection(t) s & t 返回一个新的 set 包含 s 和 t 中 ...

  6. [Nginx]Nginx的一些概念

    Nginx 关注:一.性能  1)高并发下资源不浪费在处理进程切换休眠等,保持高的吞吐量  2)高并发下如何保持平均时延低  3)提高网络效率,例如长连接代替短链接,高压缩算法提高信息量,使用缓存减少 ...

  7. react源码第一天

    1.下载源码:github 16.7版本 2.找到笔记:https://react.jokcy.me/book/api/react.html#

  8. P1219 八皇后

    题目描述 检查一个如下的6 x 6的跳棋棋盘,有六个棋子被放置在棋盘上,使得每行.每列有且只有一个,每条对角线(包括两条主对角线的所有平行线)上至多有一个棋子. 上面的布局可以用序列2 4 6 1 3 ...

  9. idea相关

    一些小技巧 ctrl + n 全文搜索文件,未搜索不能关闭,搜索过一个文件,并打开后自动关闭 鼠标点击idea之外也会关闭 双击shift 搜索所有文件 ctrl + d 向下复制一行 idea导入的 ...

  10. 1506.01186-Cyclical Learning Rates for Training Neural Networks

    1506.01186-Cyclical Learning Rates for Training Neural Networks 论文中提出了一种循环调整学习率来训练模型的方式. 如下图: 通过循环的线 ...