具有形状的散点图的不同着色
Different Colorization on Scatterplot with Shapes
我刚开始使用 d3.js 和 SVG 进行一个项目。
我以下面的例子作为参考http://bl.ocks.org/mbostock/3244058#data.csv。
我已经修改了代码以便从外部 JSON 文件获取数据,并且我希望根据特定值的范围为箭头设置 4 种不同的颜色(可以通过简单的 if 条件来实现我没有问题接着就,随即)。
到目前为止,我无法做到这一点。颜色似乎在 if 条件下发生了变化,但没有像预期的那样(例如,我给了黑色,它变得比以前更亮但不是黑色)。有什么建议么?到目前为止,我的代码是这样的:
var color_20c = d3.scale.category20c();
.......................
... SOME OTHER CODE ...
.......................
var session_data = [];
$.each( punchcard_data, function( playerIndex, player ) {
$.each( player.SessionData, function( sessionIndex, val ) {
var rotation;
var color_fill;
switch (val.direction) {
case "UP":
color_fill="#31a354" ;
rotation="";
break;
case "DOWN":
rotation="rotate(-180)";
break;
case "LEFT":
rotation="rotate(-90)";
break;
case "RIGHT":
rotation="rotate(90)";
break;
}
session_data.push({
x: val.time,
y:playerIndex,
direction:rotation,
color_fill:color_fill
});
});
});
然后我有
... Some other code ...
.style("fill", function(d) { return color_20c(d.color_fill); })
如有必要,我可以提供其余代码。
去掉色标直接上色即可解决问题。色标会将标量数字映射到颜色。例如:1对红色,2对黄色等。既然你已经知道了颜色,那么就不需要使用色标了。
我刚开始使用 d3.js 和 SVG 进行一个项目。 我以下面的例子作为参考http://bl.ocks.org/mbostock/3244058#data.csv。 我已经修改了代码以便从外部 JSON 文件获取数据,并且我希望根据特定值的范围为箭头设置 4 种不同的颜色(可以通过简单的 if 条件来实现我没有问题接着就,随即)。 到目前为止,我无法做到这一点。颜色似乎在 if 条件下发生了变化,但没有像预期的那样(例如,我给了黑色,它变得比以前更亮但不是黑色)。有什么建议么?到目前为止,我的代码是这样的:
var color_20c = d3.scale.category20c();
.......................
... SOME OTHER CODE ...
.......................
var session_data = [];
$.each( punchcard_data, function( playerIndex, player ) {
$.each( player.SessionData, function( sessionIndex, val ) {
var rotation;
var color_fill;
switch (val.direction) {
case "UP":
color_fill="#31a354" ;
rotation="";
break;
case "DOWN":
rotation="rotate(-180)";
break;
case "LEFT":
rotation="rotate(-90)";
break;
case "RIGHT":
rotation="rotate(90)";
break;
}
session_data.push({
x: val.time,
y:playerIndex,
direction:rotation,
color_fill:color_fill
});
});
});
然后我有
... Some other code ...
.style("fill", function(d) { return color_20c(d.color_fill); })
如有必要,我可以提供其余代码。
去掉色标直接上色即可解决问题。色标会将标量数字映射到颜色。例如:1对红色,2对黄色等。既然你已经知道了颜色,那么就不需要使用色标了。