D3树的定位

时间:2013-09-20 12:27:34

标签: javascript html css svg d3.js

我想将根放在最上面,一次只显示一个级别的孩子。点击1级孩子后,应显示根和被点击的孩子及其子女。

以下是我尝试过的代码。我遇到的问题是当我点击node1时,我可以看到节点3显示,但是当我在节点1之后点击node2时,我只能看到节点5作为子节点而不是节点4和5.有人能指出我要去哪里错了

<html>
  <head>
     <style>

     </style>
     <script type="text/javascript" src="d3.v3.min.js?n=1"></script>
     <script type="text/javascript" src="jquery-2.0.3.min.js?n=1"></script>
  </head>
  <body>

   <svg width="400px" height="800px" xmlns="http://www.w3.org/2000/svg" version="1.1" id="tran">
  <desc>Example NewCoordSys - New user coordinate system</desc>
  <g class="root">
  <g fill="none" stroke="black" stroke-width="3">
    <!-- Draw the axes of the original coordinate system -->
    <line x1="0" y1="1.5" x2="400" y2="1.5" />
    <line x1="1.5" y1="0" x2="1.5" y2="150" />
  </g>
  <g>
    <text x="30" y="30" font-size="20" font-family="Verdana" >
     Level root
    </text>
  </g>
  </g>
  <!-- Establish a new coordinate system, which is
       shifted (i.e., translated) from the initial coordinate
       system by 50 user units along each axis. -->
  <g transform="translate(0,200)" class="level1">
    <g fill="none" stroke="red" stroke-width="3" >
      <!-- Draw lines of length 50 user units along 
           the axes of the new coordinate system -->
      <line x1="0" y1="0" x2="400" y2="0" stroke="red" />
      <line x1="0" y1="0" x2="0" y2="300" />
    </g>
    <text x="30" y="30" font-size="20" font-family="Verdana" >
      Level 1
    </text>
  </g>

   <g transform="translate(0,500)" class="level2">
    <g fill="none" stroke="blue" stroke-width="3" >
      <!-- Draw lines of length 50 user units along 
           the axes of the new coordinate system -->
      <line x1="0" y1="0" x2="400" y2="0" stroke="blue" />
      <line x1="0" y1="0" x2="0" y2="250" />
    </g>
    <text x="30" y="30" font-size="20" font-family="Verdana" >
      Level 2
    </text>
  </g>
</svg>
    <script>

    nodes = [ {"id":0, "start":10 , "stop":100, "total":90, "prev":[], "next":[1,2]},
              {"id":1, "start":30 , "stop":50, "total":20, "prev":[0], "next":[3]},
              {"id":2, "start":60 , "stop":80, "total":20, "prev":[0], "next":[4,5]},
              {"id":3, "start":90 , "stop":110, "total":20, "prev":[1], "next":[]},
              {"id":4, "start":120 , "stop":150, "total":30, "prev":[2], "next":[]},
              {"id":5, "start":160 , "stop":190, "total":30, "prev":[2], "next":[6]},
              {"id":6, "start":100 , "stop":130, "total":30, "prev":[5], "next":[]}]

    start_pos = 50;

    init();

    function init(){

       data_val = [];

       data_val.push(nodes[0]);

       svg =  d3.select(".root")

       svg.selectAll("rect")
          .data(data_val)
          .enter()
          .append("svg:rect")
       .attr("class","conodes_root")
         .attr("width",function(d){ return d.total;})
         .attr("height","30")
         .attr("x",function(d){ return d.start;})
         .attr("y",start_pos)
         .style("fill","blue")
         .style("opacity","0.5")
         .on("click",function(d){
             if(d.next.length != 0){
               start_pos = 100;
               child(d.next, start_pos);
             }
           });


        svg.append("svg:g")
          .selectAll("text")
          .data(data_val)
          .enter()
          .append("svg:text")
       .attr("class","conodes_root")
         .attr("x",function(d){ return d.total/2;})
         .attr("y",70)
         .text(function(d){ return d.id + " " + " (" + d.next.length + " ) "; });

    }

    function child(child_arr, start_pos){

       console.log(child_arr);

       child_arr_nodes = [];

       child_arr.forEach(function(d){

            child_arr_nodes.push(nodes[d]);

       })

       console.log(child_arr_nodes);

       svg_l1 =  d3.select(".level1")

       svg_l1.selectAll("rect")
          .data(child_arr_nodes)
          .enter()
          .append("svg:rect")
       .attr("class","conodes_child")
         .attr("width",function(d){ 
          console.log(d);
          return d.total;})
         .attr("height","30")
         .attr("x",function(d){ return d.start;})
         .attr("y",start_pos)
         .style("fill","blue")
         .style("opacity","0.5")
         .on("click",function(d){
               //if(d.next.length != 0){
               start_pos = 150
               child_l2(d.next, start_pos);
             //}
           })


        /*svg_l1.append("svg:g")
          .selectAll("text")
          .data(child_arr_nodes)
          .enter()
          .append("svg:text")
       .attr("class","conodes_child")
         .attr("x",function(d){ return d.total/2;})
         .attr("y",start_pos)
         .text(function(d){ return d.id + " " + " (" + d.next.length + " ) "; });*/



    }

    function child_l2(child_arr, start_pos){

       console.log(child_arr);

       child_arr_nodes = [];

       child_arr.forEach(function(d){
            child_arr_nodes.push(nodes[d]);
       })

       console.log(child_arr_nodes);

       svg_l2 =  d3.select(".level2")

       svg_l2.selectAll("rect")
          .data(child_arr_nodes)
          .enter()
          .append("svg:rect")
       .attr("class", function(d){ return "child" + d.id;})
         .attr("width",function(d){ 
          console.log(d);
          return d.total;})
         .attr("height","30")
         .attr("x",function(d){ return d.start;})
         .attr("y",start_pos)
         .style("fill","blue")
         .style("opacity","0.5")
         /*.on("click",function(d){
               //if(d.next.length != 0){
               start_pos = 150
               child_l2(d.next, start_pos);
             //}
           })*/


        /*svg_l1.append("svg:g")
          .selectAll("text")
          .data(child_arr_nodes)
          .enter()
          .append("svg:text")
       .attr("class","conodes_child")
         .attr("x",function(d){ return d.total/2;})
         .attr("y",start_pos)
         .text(function(d){ return d.id + " " + " (" + d.next.length + " ) "; });*/

    }

    </script>
  </body>
</html>

0 个答案:

没有答案