2016-12-16 11 views
0

d3 jsを使用してZoomable TreeMapを構築しようとしています。私はサーバーからJSONオブジェクトの配列を取得し、それをtreeMapに渡し、ツリーマップに処理させる必要があります。しかし、そうすることで、私はそれをcsvファイルから読み取らないjsonオブジェクトを使用してツリーマップの入力を受け取ります。

を解析することはできませんよ。ここtremapのための私のコードです:

$rootScope.loadTreeMap = function(path_to_data,dom_element_to_append_to){ 

     var w = $(dom_element_to_append_to).width() - 80, 
      h = 800 - 180, 
      x = d3.scale.linear().range([0, w]), 
      y = d3.scale.linear().range([0, h]), 
      color = d3.scale.category20c(), 
      root, 
      node; 
      console.log("W" + w); 
      console.log("h " + h); 

     var treemap = d3.layout.treemap() 
      .round(false) 
      .size([w, h]) 
      .sticky(true) 
      .value(function(d) { return d.size; }); 

     var svg = d3.select(dom_element_to_append_to).append("div") 
      .attr("class", "chart") 
      .style("width", w + "px") 
      .style("height", h + "px") 
      .append("svg:svg") 
      .attr("width", w) 
      .attr("height", h) 
      .append("svg:g") 
      .attr("transform", "translate(.5,.5)"); 

     d3.json(path_to_data, function(data) { 

      node = root = data; 

      var nodes = treemap.nodes(root) 
       .filter(function(d) { return !d.children; }); 

      var cell = svg.selectAll("g") 
       .data(nodes) 
      .enter().append("svg:g") 
       .attr("class", "cell") 
       .attr("transform", function(d) { return "translate(" + d.x + "," + d.y + ")"; }) 
       .on("click", function(d) { return zoom(node == d.parent ? root : d.parent); }); 

      cell.append("svg:rect") 
       .attr("width", function(d) { return d.dx - 1; }) 
       .attr("height", function(d) { return d.dy - 1; }) 
       .style("fill", function(d) { return color(d.parent.name); }); 

      cell.append("svg:text") 
       .attr("x", function(d) { return d.dx/2; }) 
       .attr("y", function(d) { return d.dy/2; }) 
       .attr("dy", ".35em") 
       .attr("text-anchor", "middle") 
       .text(function(d) { return d.name; }) 
       .style("opacity", function(d) { d.w = this.getComputedTextLength(); return d.dx > d.w ? 1 : 0; }); 

      d3.select(window).on("click", function() { zoom(root); }); 

      d3.select("select").on("change", function() { 
      treemap.value(this.value == "size" ? size : count).nodes(root); 
      zoom(node); 
      }); 
     }); 

     function size(d) { 
      return d.size; 
     } 

     function count(d) { 
      return 1; 
     } 

     function zoom(d) { 
      var kx = w/d.dx, ky = h/d.dy; 
      x.domain([d.x, d.x + d.dx]); 
      y.domain([d.y, d.y + d.dy]); 

      var t = svg.selectAll("g.cell").transition() 
       .duration(d3.event.altKey ? 7500 : 750) 
       .attr("transform", function(d) { return "translate(" + x(d.x) + "," + y(d.y) + ")"; }); 

      t.select("rect") 
       .attr("width", function(d) { return kx * d.dx - 1; }) 
       .attr("height", function(d) { return ky * d.dy - 1; }) 

      t.select("text") 
       .attr("x", function(d) { return kx * d.dx/2; }) 
       .attr("y", function(d) { return ky * d.dy/2; }) 
       .style("opacity", function(d) { return kx * d.dx > d.w ? 1 : 0; }); 

      node = d; 
      d3.event.stopPropagation(); 
     } 

    } 

`

私が保存されたCSVファイルからデータをロードする場合、基本的にそれが正常に動作しています私のシステムでは、しかし、私はサーバーからオブジェクトの配列を読んで、それにグラフを構築する。私はこれを解決するには、単に削除考え出し

d3.json(path_to_data, function(data) { 
      /*console.log("data"); 
      console.log(data); 
      console.log("data"); 
      data = JSON.parse(inputData); 
      console.log(data);*/ 
      node = root = data; 

      var nodes = treemap.nodes(root) 
       .filter(function(d) { return !d.children; }); 

      var cell = svg.selectAll("g") 
       .data(nodes) 
      .enter().append("svg:g") 
       .attr("class", "cell") 
       .attr("transform", function(d) { return "translate(" + d.x + "," + d.y + ")"; }) 
       .on("click", function(d) { return zoom(node == d.parent ? root : d.parent); }); 

      cell.append("svg:rect") 
       .attr("width", function(d) { return d.dx - 1; }) 
       .attr("height", function(d) { return d.dy - 1; }) 
       .style("fill", function(d) { return color(d.parent.name); }); 

      cell.append("svg:text") 
       .attr("x", function(d) { return d.dx/2; }) 
       .attr("y", function(d) { return d.dy/2; }) 
       .attr("dy", ".35em") 
       .attr("text-anchor", "middle") 
       .text(function(d) { return d.name; }) 
       .style("opacity", function(d) { d.w = this.getComputedTextLength(); return d.dx > d.w ? 1 : 0; }); 

      d3.select(window).on("click", function() { zoom(root); }); 

      d3.select("select").on("change", function() { 
      treemap.value(this.value == "size" ? size : count).nodes(root); 
      zoom(node); 
      }); 
     }); 

しかし、私は

node = root = inputdata ; here input data is array of json objects fetched from server 
var nodes = treemap.nodes(root).filter(function(d) { return !d.children; }); 
var cell = svg.selectAll("g") 

答えて

0

のような別の何かをしたい:

は基本的にここにファイルから読み込み、JSONオブジェクトを解析し、私の機能ですd3.csv関数(関数の本体のみでグラフが生成するような関数の本体を削除しないでください)と、グラフタイプの必要に応じて独自の変数を渡してJSONオブジェクトを渡します。これは、データがd3.csvまたはd3.jsonによって取得されるほぼすべてのグラフで動作します。ここでは作業コード

$rootScope.loadTreeMap = function(path_to_data,dom_element_to_append_to){ 

    var w = $(dom_element_to_append_to).width() - 80, 
     h = 800 - 180, 
     x = d3.scale.linear().range([0, w]), 
     y = d3.scale.linear().range([0, h]), 
     color = d3.scale.category20c(), 
     root, 
     node; 
     console.log("W" + w); 
     console.log("h " + h); 

    var treemap = d3.layout.treemap() 
     .round(false) 
     .size([w, h]) 
     .sticky(true) 
     .value(function(d) { return d.size; }); 

    var svg = d3.select(dom_element_to_append_to).append("div") 
     .attr("class", "chart") 
     .style("width", w + "px") 
     .style("height", h + "px") 
     .append("svg:svg") 
     .attr("width", w) 
     .attr("height", h) 
     .append("svg:g") 
     .attr("transform", "translate(.5,.5)"); 

    /* d3.json(path_to_data, function(data) {*/ 
     remove the above line and insert your own JSON object variable like 
     data = inputData(your own JSON variable) 

     node = root = data; 

     var nodes = treemap.nodes(root) 
      .filter(function(d) { return !d.children; }); 

     var cell = svg.selectAll("g") 
      .data(nodes) 
     .enter().append("svg:g") 
      .attr("class", "cell") 
      .attr("transform", function(d) { return "translate(" + d.x + "," + d.y + ")"; }) 
      .on("click", function(d) { return zoom(node == d.parent ? root : d.parent); }); 

     cell.append("svg:rect") 
      .attr("width", function(d) { return d.dx - 1; }) 
      .attr("height", function(d) { return d.dy - 1; }) 
      .style("fill", function(d) { return color(d.parent.name); }); 

     cell.append("svg:text") 
      .attr("x", function(d) { return d.dx/2; }) 
      .attr("y", function(d) { return d.dy/2; }) 
      .attr("dy", ".35em") 
      .attr("text-anchor", "middle") 
      .text(function(d) { return d.name; }) 
      .style("opacity", function(d) { d.w = this.getComputedTextLength(); return d.dx > d.w ? 1 : 0; }); 

     d3.select(window).on("click", function() { zoom(root); }); 

     d3.select("select").on("change", function() { 
     treemap.value(this.value == "size" ? size : count).nodes(root); 
     zoom(node); 
     }); 
    }); 

    function size(d) { 
     return d.size; 
    } 

    function count(d) { 
     return 1; 
    } 

    function zoom(d) { 
     var kx = w/d.dx, ky = h/d.dy; 
     x.domain([d.x, d.x + d.dx]); 
     y.domain([d.y, d.y + d.dy]); 

     var t = svg.selectAll("g.cell").transition() 
      .duration(d3.event.altKey ? 7500 : 750) 
      .attr("transform", function(d) { return "translate(" + x(d.x) + "," + y(d.y) + ")"; }); 

     t.select("rect") 
      .attr("width", function(d) { return kx * d.dx - 1; }) 
      .attr("height", function(d) { return ky * d.dy - 1; }) 

     t.select("text") 
      .attr("x", function(d) { return kx * d.dx/2; }) 
      .attr("y", function(d) { return ky * d.dy/2; }) 
      .style("opacity", function(d) { return kx * d.dx > d.w ? 1 : 0; }); 

     node = d; 
     d3.event.stopPropagation(); 
    } 

} 
関連する問題