我正在使用d3创建一个图表,在y轴上有两个刻度,一个朝左,另一个朝向图的右边。
在左Y轴上我试图绘制收入与日期的关系,在右边我试图绘制点击次数与日期。
“收入”的最大值为1800美元,点击次数为4000。 蓝线是收入行,橙色线是点击次数。
有人可以帮助我如何让橙色线适合同一个y域?
我用于Revenue的代码是:
var y = d3.scale.linear()
.domain([min_y_value, max_y_value])
.range([height - margin, margin]);
var x = d3.time.scale()
.domain([start_date, end_date])
.range([0 + margin, width - margin]);
var color = d3.scale.category10().range();
var vis = d3.select("#chart")
.append("svg:svg")
.attr("width", width)
.attr("height", height);
var g = vis.append("svg:g")
.attr("transform", "translate("+margin+",0)");
var line = d3.svg.line()
.x(function(d,i) {
return x(get_date(d.date));
})
.y(function(d) {
return y(d[trend]);
});
for(var i = 0; i < report.length; i++) {
g.append("svg:path")
.attr("d", line(report[i]))
.attr("fill", "none")
.attr("stroke", color[i % 10])
.attr("id", "line-"+report[i][0]['offer_name'])
.attr("stroke-width", 2);
}
我用于点击的代码是
var trend1 = 'clicks';
var max_y1_value = max_min['max_'+trend1];
var min_y1_value = max_min['min_'+trend1];
var y1_range = max_y1_value - min_y1_value;
var y1_interval_value = Math.floor(y1_range/yticks);
max_y1_value = max_y_value + y_interval_value;
min_y1_value = (min_y_value - y_interval_value > 0)?(min_y_value - y_interval_value) : 0;
var y1 = d3.scale.linear().domain([min_y1_value, max_y1_value]).range([height - margin, margin]);
var x1 = d3.time.scale().domain([start_date, end_date]).range([0 + margin, width - margin]);
console.log('max_y_value : '+max_y_value+' min_y_value : '+min_y_value+' max_y1_value : '+max_y1_value+' min_y1_value : '+min_y1_value+' trend1: '+trend1);
var line1 = d3.svg.line()
.x(function(d,i) {
return x1(get_date(d.date));
})
.y(function(d) {
console.log(d[trend1]+' '+y1(d[trend1]));
return y1(d[trend1]);
});
for(var i = 0; i < report.length; i++) {
g.append("svg:path")
.attr("d", line1(report[i]))
.attr("fill", "none")
.attr("stroke", color[i + report.length % 10])
.attr("id", "line1-"+report[i][0]['offer_name'])
.attr("stroke-width", 2);
}
有人可以帮助我如何让橘子线适合同一个y域?
答案 0 :(得分:1)
您好像用其他系列中的值覆盖了max_y1_value
和min_y1_value
。例如,您首先定义max_y1_value
:
var max_y1_value = max_min['max_'+trend1];
然后你用另一个值替换:
max_y1_value = max_y_value + y_interval_value;
我建议使用d3.extent从数据中计算域名。