В настоящее время я изменяю следующий пример, чтобы создать диаграмму горизонтальных относительных стеков. Следующий пример - пример «одиночной» таблицы стека.D3 Multicolumn Relative Stack Chart
Вот моя версия, однако я получаю значение NaN X и Width, и я ищу, чтобы выяснить, почему. Спасибо.
В SVG структура представлена ниже для каждого из: -
г [г [прямоугольник, прямоугольник, прямоугольник]], г [г [прямоугольник, прямоугольник, прямоугольник]]
Здесь мой код: http://jsfiddle.net/scottietom/7c3vb4e9/
var dataset = [
[
[{x: 0,y: 100}],[{x: 0,y: 30}],[{x: 0,y: 50}]],
[[{x: 0,y: 100}],[{x: 0,y: 30}],[{x: 0,y: 50}]]
];
//Set up stack method
var stack = d3.layout.stack();
//Data, stacked
for (i=0; i<dataset.length; i++) {
stack(dataset[i]);
}
//Set up scales
var xScale = d3.scale.linear()
.domain([0, d3.max(dataset, function (d) {
return d3.max(d, function (d) {
return d.y0 + d.y;
});
})])
.range([0, w]);
//Easy colors accessible via a 10-step ordinal scale
var colors = d3.scale.category10();
//or make your own colour palet
var color = d3.scale.ordinal()
.range(["#1459D9", "#148DD9", "#87ceeb", "#daa520"]);
//Create SVG element
var svg = d3.select(".pathanalysis_diagram")
.append("svg")
.attr("width", w + margin.left + margin.right)
.attr("height", h + margin.top + margin.bottom)
.append("g")
.attr("transform", "translate(" + margin.left + "," + margin.top + ")");
// Add a group for each row of data
var groups = svg.selectAll("g")
.data(dataset)
.enter()
.append("g")
.style("fill", function (d, i) {
return color(i);
});
// Add a rect for each data value
var rects = groups.selectAll("rect")
.data(function (d) {
return d;
})
.enter()
.append("rect")
.attr("x", function (d) {
return xScale(d.y0);
})
.attr("y", 50)
.attr("height", 50)
.attr("width", function (d) {
return xScale(d.y);
});
В скрипке расположены три прямоугольника. Так в чем вопрос? – ee2Dev
Я хочу преобразовать этот код, чтобы принять несколько строк, а код под ссылкой - моя попытка. – Tom
Я считаю, что что-то не так с тем, как я складываю свои данные, которые затем упоминаются в линейном масштабе – Tom