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