Как добавить легенду к многострочной диаграмме? Я пробовал, но у меня нет никакой легенды.d3.js добавление легенды в многострочную диаграмму серии
Блок здесь:
имеет недостаток, когда различные ряды сходятся к одной и той же точке, как ноль. Все ярлыки будут накладываться друг на друга. Вместо того, чтобы идти на эти этикетки, было бы полезно использовать традиционную легенду.
Я попытался добавить этот
var legend = svg.append("g")
.attr("class", "legend")
.attr("height", 100)
.attr("width", 100)
.attr('transform', 'translate(-20,50)');
legend.selectAll('rect')
.datum(function(d) { return {name: d.name, value: d.values[d.values.length - 1]}; })
.append("rect")
.attr("x", width)
.attr("y", function(d, i){ return i * 20;})
.attr("width", 10)
.attr("height", 10)
.style("fill", function(d) {
return color.domain(d3.keys(d[0]).filter(function(key) { return key !== "day"; }));
});
legend.selectAll('text')
.datum(function(d) { return {name: d.name, value: d.values[d.values.length - 1]}; })
.append("text")
.attr("x", width)
.attr("y", function(d, i){ return i * 20 + 9;})
.text(function(d) {
return d.name;
});
в конце кода, имена ключей (d.name) совпадают, как отформатирован мои данные, но он не отображается. В одном месте он показал все черные ящики справа от графика, так что означает, что я близко, но я что-то важное не хватаю
любого понимания оценило
Я добавил точку, и ваш код работал для меня. var legend = svg.selectAll ('. g') – theIrishUser