- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试使用 d3 (此特定场景中的饼图)编写可重用的图形组件。我是 d3 的新手,在编写高度可重用的组件方面也相对缺乏经验。这是我到目前为止所拥有的,我已经通过将关键函数传递给 data
使用类似的代码显示了一个饼图,但当我尝试时,对象恒定性以某种方式失败(切片乱序)对可重用组件进行相同的操作。
我知道这段代码中还有更多关于可以为用户提供更多选项和更简洁的代码的问题。
function pieChart(){
var _pie ={};
var _width = 960,
_height = 600,
_margins = {top:30,left:30,right:30,bottom:30},
_x,_y,_data = [],
_color = d3.scale.category10(),
_svg,
_innerRadius=0,
_radius = Math.min(_width,_height)/2 - (_margins.top/2 + _margins.bottom/2),
_layout = d3.layout.pie(),
_key = function(d) { return d.data.key;},
_value= function(d) { return d.data.val;},
_bodyG,
_arc;
_pie.color = function(c){
if(!arguments.legnth) return _color;
_color = c;
return _pie;
}
_pie.value = function(v){
if(!arguments.legnth) return _value;
_value = v;
return _pie;
}
_pie.key = function(k){
if(!arguments.legnth) return _key;
_key= k;
return _pie;
}
_pie.width = function(w){
if(!arguments.length) return _width;
_width = w;
return _pie;
}
_pie.height= function(h){
if(!arguments.length) return _height;
_height= h;
return _pie;
}
_pie.margins = function(m){
if(!arguments.length) return _margins;
_margins = m;
return _pie;
}
_pie.color= function(c){
if(!arguments.length) return _color;
_color = c;
return _pie;
}
_pie.innerRadius= function(i){
if(!arguments.length) return _innerRadius;
_innerRadius = i;
return _pie;
}
_pie.outerRadius= function(i,recalculate){
recalculate = typeof recalculate !== 'undefined'? recalculate: false;
if(!arguments.length){
if(recalculate || !_radius)
_radius = Math.min(_width,_height)/2 - (_margins.top + _margins.bottom)/2;
return _radius;
}
_radius= i;
return _pie;
}
_pie.render= function(options){
if(!_svg){
_svg = d3.select("#pie-chart").append("svg")
.attr("height",_height)
.attr("width",_width)
.append("g")
.attr("transform","translate("+_width/2 + "," + _height/2 + ")");
}
if(options && options.layout) _layout= options.layout;
if(options && options.sort) _layout.sort(options.sort);
if(options && options.value) _layout.value(options.value);
else _layout.value(function(d){return d.val});
renderPie(_svg);
renderLines(_svg);
renderLabels(_svg);
}
_pie.layout = function(l){
if(!arguments.length) return _layout;
_layout = l;
return _pie;
}
_pie.data=function(d){
if(!arguments.length) return _data;
_data = d;
return _pie;
}
_pie.arc = function(a){
if(!arguments.length){
if(!_arc)
_arc= d3.svg.arc()
.outerRadius(_radius)
.innerRadius(_innerRadius);
return _arc;
}
_arc = a;
return _pie;
}
_pie.key = function(k){
if(!arguments.length || typeof k != 'function') return _key;
_key = k;
return _pie;
}
_pie.value= function(v){
if(!arguments.length || typeof v != 'function') return _value;
_value = v;
return _pie;
}
_pie._textPos= function(d){
var xc = _arc.centroid(d)[0];
var yc = _arc.centroid(d)[1];
var r = _radius -10;
var effectiveX = xc>0 ? _radius+50 : -_radius-50;
var effectiveY = yc>0 ? (r*yc)/Math.sqrt(xc*xc + yc*yc)+50 : (r*yc)/Math.sqrt(xc*xc + yc*yc)-20;
return "translate(" + effectiveX+ ","+effectiveY+")";
}
_pie.textPos = function(d){
if(!arguments.length) return _textPos;
_textPos = d;
return _pie;
}
_pie._arcIdentifier = function(d){
return "each-arc-"+_key(d).toString().replace(/ /g,"_");
}
_pie._line1x1 = function(d){
var xc = _arc.centroid(d)[0];
var yc = _arc.centroid(d)[1];
var r = _radius -10;
return (r*xc)/Math.sqrt(xc*xc + yc*yc);
}
_pie._line1x2 = function(d){
var xc = _arc.centroid(d)[0];
var yc = _arc.centroid(d)[1];
var r = _radius -10;
var xret= (r*xc)/Math.sqrt(xc*xc + yc*yc);
return xc>0 ? xret+50: xret-50;
}
_pie._line2x1 = function(d){
var xc = _arc.centroid(d)[0];
var yc = _arc.centroid(d)[1];
var r = _radius -10;
var xret= (r*xc)/Math.sqrt(xc*xc + yc*yc);
return xc>0 ? xret+50: xret-50;
}
_pie._line2x2 = function(d){
var xc = _arc.centroid(d)[0];
return xc>0 ? _radius+40: -_radius-40;
}
_pie._line1y1 = function(d){
var xc = _arc.centroid(d)[0];
var yc = _arc.centroid(d)[1];
var r = _radius -10;
return (r*yc)/Math.sqrt(xc*xc + yc*yc);
}
_pie._line1y2 = function(d){
var xc = _arc.centroid(d)[0];
var yc = _arc.centroid(d)[1];
var r = _radius -10;
return yc>0 ? (r*yc)/Math.sqrt(xc*xc + yc*yc)+50 : (r*yc)/Math.sqrt(xc*xc + yc*yc)-20;
}
_pie._line2y1 = function(d){
var xc = _arc.centroid(d)[0];
var yc = _arc.centroid(d)[1];
var r = _radius -10;
return yc>0 ? (r*yc)/Math.sqrt(xc*xc + yc*yc)+50 : (r*yc)/Math.sqrt(xc*xc + yc*yc)-20;
}
_pie._line2y2 = function(d){
var xc = _arc.centroid(d)[0];
var yc = _arc.centroid(d)[1];
var r = _radius -10;
return yc>0 ? (r*yc)/Math.sqrt(xc*xc + yc*yc)+50 : (r*yc)/Math.sqrt(xc*xc + yc*yc)-20;
}
_pie.line1x1 = function(d){
if(!arguments.length) return _line1x1;
_line1x1 = d;
return _pie;
}
_pie.line1x2 = function(d){
if(!arguments.length) return _line1x2;
_line1x2 = d;
return _pie;
}
_pie.line1y1 = function(d){
if(!arguments.length) return _line1y1;
_line1x1 = d;
return _pie;
}
_pie.line1y2 = function(d){
if(!arguments.length) return _line1y2;
_line1y2 = d;
return _pie;
}
_pie.line2x1 = function(d){
if(!arguments.length) return _line2x1;
_line2x1 = d;
return _pie;
}
_pie.line2x2 = function(d){
if(!arguments.length) return _line2x2;
_line2x2 = d;
return _pie;
}
_pie.line2y1 = function(d){
if(!arguments.length) return _line2y1;
_line2y1 = d;
return _pie;
}
_pie.line2y2 = function(d){
if(!arguments.length) return _line2y2;
_line2y2 = d;
return _pie;
}
function renderLabels(svg){
_bodyG.append("text")
.attr("transform",function(d){return _pie._textPos(d)})
.attr("dy", ".35em")
.style("text-anchor", function(d){return _pie.arc().centroid(d)[0]>0? "start":"end";})
.text(_pie.key());
}
function renderPie(svg){
_pie.arc();
_bodyG = svg.selectAll(".arc")
.data(_pie.layout()(_pie.data()),_pie.key()) //Worked perfectly before but now fails
.enter().append("g")
.order()
.attr("class","arc");
_bodyG.append("path")
.attr("d",_arc)
.attr("class",_pie._arcIdentifier)
.style("fill",function(d){return _pie.color()(_pie.value()(d));})
}
function renderLines(svg){
_bodyG.append("line")
.attr("stroke","black")
.attr("x1",_pie._line1x1)
.attr("x2",_pie._line1x2)
.attr("y1",_pie._line1y1)
.attr("y2",_pie._line1y2);
_bodyG.append("line")
.attr("stroke","black")
.attr("x1",_pie._line2x1)
.attr("x2",_pie._line2x2)
.attr("y1",_pie._line2y1)
.attr("y2",_pie._line2y2);
}
return _pie;
}
我正在寻找这样的输出:
最佳答案
[聊天中的澄清:问题不在于对象恒定性,而在于饼图的切片绘制顺序与数据中的顺序不同。]
问题是您要求饼图布局对数据进行排序:
_layout.sort(options.sort)
这会重新排列数据,因此切片以不同的顺序显示。要解决此问题,您可以关闭排序或在数据中提供一个键,您可以根据该键进行排序以获得所需的顺序。
关于javascript - 即使有关键功能,D3 也不保持对象恒定性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28209417/
我的应用程序包含两部分:网络部分和 GUI。它的工作方式有点像浏览器 - 用户从服务器请求一些信息,服务器发回一些代表某些 View 的数据,然后 GUI 显示它。 现在我已经将网络部分实现为一项服务
给定表达式字符串exp,编写程序检查exp中“{”、“}”、“(”、“)”、“[”、“]的对和顺序是否正确。 package main import ( "fmt" stack "gi
我想要一个简单的脚本在后台保持运行。目前看起来像这样: import keyboard while True: keyboard.wait('q') keyboard.send('ct
我维护着许多 RedHat Enterprise Linux(7 台和 8 台)服务器(>100 台),其中包含不同的应用程序。为了保持理智,我当然会使用 Ansible 等工具,更重要的是,公共(p
我有一个 winforms 应用程序,它在网络服务请求期间被锁定 我已经尝试使用 doEvents 来保持应用程序解锁,但它仍然不够响应, 我怎样才能绕过这个锁定,让应用程序始终响应? 最佳答案 最好
我正在努力在我的项目中获得并保持领先的 0。以下是当前相关的代码: Dim jobNum As String jobNum = Left(r1.Cells(1, 1), 6) r2.Cells(1
我正在尝试在我的 Canvas 中定位元素相对于我的背景。 窗口被重新调整大小,保持纵横比。 背景随着窗口大小而拉伸(stretch)。 问题是一旦重新调整窗口大小,元素位置就会不正确。如果窗口的大小
一直在玩弄 Hibernate 和 PostgreSQL,试图让它按预期工作。 但是由于某种原因,当我尝试将具有@OneToMany 关系的对象与集合中的多个项目保持一致时,除了第一个项目之外,所有项
我想将某些东西提交到 github 存储库,但我(显然)没有任何权利这样做。我对那个 repo 做了一个分支,提交了我的更改并提交了一个 pull-request。 现在,问题是过了一段时间其他人已经
这是一个初学者问题,我仍在考虑“在 OOP 中”,所以如果我错过了手册中的答案或者答案很明显,我深表歉意。 假设我们有一个抽象类型, abstract type My_Abstract_type en
我们正在开展的一些项目在 jQuery 1.4.2 或更早版本中有着深厚的根基,介于缺乏最新版本的性能优势(或语法糖)、使用现已弃用的方法的耻辱以及部署一个积极维护的库的 3 年以上旧版本,升级现在迫
我看到在FMDB 2.0中,作者为线程添加了FMDatabaseQueue。例子是: // First, make your queue. FMDatabaseQueue *queue = [FMDa
我在 NSScrollView 中有一个 NSTableView。 NSTableView 的内容是通过绑定(bind)到 NSArrayController 来提供的,而 NSArrayContro
我在 TreeView 上有一个节点,我手动填充该节点并希望保持排序。通过用户交互,TreeViewItem 上的标题可能会更改,它们应该移动到列表中的适当位置。 我遍历一个 foreach,创建多个
我从主 NSWindow 打开一个 NSWindow。 DropHereWindowController *dropHereWindowController = [[DropHereWindowCon
我需要放置一个 form 3 按钮,当我单击该按钮时,将其显示为按下,其他按钮向上,当我单击另一个按钮时,它应该为“向下”,其他按钮应为“向上” 最佳答案 所有按钮的属性“Groupindex”必须设
我有一个使用 AnyEvent::MQTT 订阅消息队列的 perl 脚本。 目前我想要它做的就是在收到消息时打印出来。我对 perl 完全陌生,所以我正在使用它附带的演示代码,其中包括将 STDIN
如何在 .NET 应用程序中保持 TreeView 控件的滚动位置?例如,我有一个树形 View 控件,并经历了一个向其添加各种节点的过程,并将它们固定在底部。在此过程中,我可以滚动浏览 TreeVi
我维护了大量的 vbscripts,用于在我的网络上执行各种启动脚本,并且有一些我在几乎所有脚本中使用的函数。 除了复制和粘贴之外,有没有人对我如何创建可重用 vbscript 代码库有建议。我并不反
我有一些关于 Azure 自托管的问题。 假设用户 Alex 在物理机 M 上设置了 Windows 自托管代理。当 Alex 注销且计算机进入休眠状态时,代理将脱机。现在,当 Bob 登录同一台计算
我是一名优秀的程序员,十分优秀!