Я хочу обновить Treemap динамически с новыми данными. Я прочитал это article, но я не запускаю его. Так что это мой код:D3.js обновить Treemap динамически
function buildTreemap(jVals){
//$("#treemap").empty();
var data = jQuery.parseJSON(jVals);
var margin = {top: 40, right: 10, bottom: 10, left: 10},
width = 760 - margin.left - margin.right,
height = 500 - margin.top - margin.bottom;
var treemap = d3.layout.treemap()
.size([width, height])
.sticky(true)
.sort(function(a,b) { return a.anzahl - b.anzahl; })
.round(true)
.value(function(d) { return Math.log(d.anzahl); });
var div = d3.select("#treemap").append("div")
.style("position", "relative")
.style("width", (width + margin.left + margin.right) + "px")
.style("height", (height + margin.top + margin.bottom) + "px")
.style("left", margin.left + "px")
.style("top", margin.top + "px")
.attr("id", "first");
var node = div.datum(data).selectAll(".node")
.data(treemap.nodes)
.enter().append("div")
.attr("class", "node")
.style("left", function(d) { return d.x + "px"; })
.style("top", function(d) { return d.y + "px"; })
.style("width", function(d) { return Math.max(0, d.dx - 1) + "px"; })
.style("height", function(d) { return Math.max(0, d.dy - 1) + "px"; })
.style("background", function(d) { return d.color ? d.color : "#ffffff";})
.text(function(d) { return d.children ? "blue" : d.keytable + "(" + d.anzahl + "-" + Math.max(0, d.dx) + "-" + Math.max(0, d.dy) + ")"; })
;
};
С другой Js-функции я вызываю buildTreemap() с новыми данными. Теперь я хочу, чтобы treemap перерисовывался с помощью Transition/Duration.
Может ли кто-нибудь помочь мне, пожалуйста. Большого спасибо ...
Update: Я добавил это:
d3.selectAll("input").on("change", function change() {
var value = this.value === "count"
? function() { return 1; }
: function(d) { return Math.log(d.anzahl); };
node
.data(treemap.value(value).nodes)
.transition()
.duration(1500)
.call(position);
});
и с этим кодом TreeMap перестраивает, если я нажимаю "изменить" -input. Но если я возьму этот код:
d3.selectAll("#search").on("keyup", function change() {
var value = function(d) { return Math.log(d.anzahl); };
node
.data(treemap.value(value).nodes)
.transition()
.duration(1500)
.call(position);
});
treemap остается и еще один treemap с новыми значениями данных открывается ниже моего первого. На клавиатуре запускается другая js-функция и отправляются новые данные в buildTreemap().
Вы видели [это] (http://bl.ocks.org/mbostock/4063582)? –
Да, но это только масштабирует размер div с теми же данными. Мне нужно перемасштабировать новые данные. – maker23
Принцип тот же. Он по-прежнему передает новые данные в макет treemap при изменении. –