利用d3js绘出环形百分比环

 (function() {
var numberData = [{
value : 0.334,
text : "33.4%",
color : "#fd12000",
id : 1
}, {
value : 0.666,
text : "66.6%",
color : "#3611aa",
id : 2
}]; drawCir("#container", numberData, 170, 170); function drawCir(selector, data, height ,width) {
var radius = Math.min(width, height) / 2, spacing = 45; fields = data; var arc = d3.svg.arc().startAngle(0.5 * Math.PI).endAngle(function(d) {
var direction = (d.id % 2 == 0) ? -1 : 1;
return 0.5 * Math.PI + direction * d.value * 2 * Math.PI;
}).innerRadius(function(d) {
return radius - spacing;
}).outerRadius(function(d) {
return radius;
}); var svg = d3.select(selector).append("svg").attr("width", width).attr("height", height).append("g").attr("transform", "translate(" + width / 2 + "," + height / 2 + ")"); var field = svg.selectAll("g").data(fields).enter().append("g"); field.append("path");
field.append("text"); field = field.each(function(d) {
this._value = d.value;
}).data(fields).each(function(d) {
d.previousValue = this._value;
}); field.select("path").transition().attrTween("d", arcTween).duration(1000).style("fill", function(d) {
return d.color;
}); field.select("text").text(function(d) {
return d.text;
}).style("stroke", "white").attr("transform", function(d) {
var direction = (d.id % 2 == 0) ? -1 : 1;
return "rotate(" + direction * 360 * d.value / 2 + ")" + "translate(" + (radius - spacing / 2) + ",0)" + "rotate(" + (d.value < .5 ? -0 : 180) + ")"
}); function arcTween(d) {
var i = d3.interpolateNumber(0, d.value);
return function(t) {
d.value = i(t);
return arc(d);
};
} } })();

最终效果:

d3js资源:

 <script src="http://d3js.org/d3.v3.js"></script>

最新文章

  1. R读取溢出的数据
  2. powerdesigner逆向工程,从数据库导出PDM
  3. Foundation -----&gt;NSSet
  4. kettle定时任务_第三方合作方有订单自动发送邮件通知_20161214
  5. js文件合并,压缩,缓存,延迟加载
  6. curl命令
  7. Windows命令 dos
  8. jQuery数组($.each,$.grep,$.map,$.merge,$.inArray,$.unique,$.makeArray)处理函数详解
  9. css3++js钟表
  10. (转)IOS学习笔记-2015-03-29 int、long、long long取值范围
  11. ASP.NET中的特殊路径标识&quot;~&quot;
  12. Strange Way to Express Integers (一般模线性方程组)
  13. wso2esb源码编译总结
  14. FZU 2086 餐厅点餐(模拟)
  15. C语言中无符号数和有符号数之间的运算
  16. MariaDB:开启日志记录SQL
  17. ubuntu 14.04 pytorch安装
  18. 报错:org.apache.hadoop.hive.metastore.HiveMetaException: Failed to get schema version.
  19. Mabatis三剑客分别是:mybatis-generator、mybatis-plugin、mybatis-pagehelper
  20. Python高效编程技巧

热门文章

  1. 使用Reveal来查看别人的APP界面+白苹果不刷机解决方式
  2. c# 枚举返回字符串操作
  3. 微信小程序TabBar的使用
  4. Grunt学习笔记【6】---- grunt-contrib-requirejs插件详解
  5. php总结4——数组的定义及函数、冒泡排序
  6. 【题解】CJOI2019 登峰造鸡境 (Prufer序列+斯特林数)
  7. 推荐20个非常有帮助的web前端开发教程
  8. Linux PPTP拨号
  9. PAT 天梯赛 L2-025. 分而治之 【图】
  10. 堆中的路径 【Heap】