D3js堆栈图X轴定制

时间:2014-10-08 04:57:53

标签: json d3.js graph

我按照这个例子d3js example。 然后按照此Image]![changes: Now stack is only 2 colours

中的说明自定义此图表

我的JSON数据是:

{"test": [
            {"date":"1/5/2014","allocated":"14.14","unallocated":"7.14"},
            {"date":"1/6/2014","allocated":"10.38","unallocated":"1.14"},
            {"date":"1/7/2014","allocated":"1.43","unallocated":"3.14"},
            {"date":"1/8/2014","allocated":"12","unallocated":"6.14"},
            {"date":"1/9/2014","allocated":"13.34","unallocated":"4.44"},
            {"date":"1/10/2014","allocated":"6.34","unallocated":"1.14"},
            {"date":"1/11/2014","allocated":"8.34","unallocated":"2.14"},
            {"date":"1/12/2014","allocated":"6.88","unallocated":"4.14"},
            {"date":"1/13/2014","allocated":"23.34","unallocated":"2.14"},
            {"date":"1/14/2014","allocated":"3.34","unallocated":"0.14"}
]}

和Index.html代码是:

    <!DOCTYPE html>
<html>
  <head>
    <title>Bar Graph</title>
    <script type="text/javascript" src="http://mbostock.github.com/d3/d3.js?1.29.1"></script>
    <script type="text/javascript" src="http://mbostock.github.com/d3/d3.layout.js?1.29.1"></script>
    <script type="text/javascript" src="http://mbostock.github.com/d3/d3.time.js?1.29.1"></script>
    <script type="text/javascript" src="http://mbostock.github.com/d3/d3.csv.js?1.29.1"></script>

svg {
  width: 550px;
  height: 500px;
  border: solid 1px #ccc;
  font: 10px sans-serif;
  shape-rendering: crispEdges;
}

    </style>
  </head>
  <body>
    <script type="text/javascript">

var w = 550,
    h = 500,
    p = [20, 30, 30, 20],
    x = d3.scale.ordinal().rangeRoundBands([0, w - p[1] - p[3]]),
    y = d3.scale.linear().range([0, h - p[0] - p[2]]),
    z = d3.scale.ordinal().range(["lightpink", "lightblue"]),

    parse = d3.time.format("%m/%d/%Y").parse,
    format = d3.time.format("%a");

var svg = d3.select("body").append("svg:svg")
    .attr("width", w)
    .attr("height", h)
  .append("svg:g")
    .attr("transform", "translate(" + p[3] + "," + (h - p[2]) + ")");
var t

d3.json("test.json", function(test) {
  // Transpose the data into layers by cause.
  var causes = d3.layout.stack()(["allocated", "unallocated"].map(function(cause) {

    return test.test.map(function(d) {
      // var temp = _.each(test, function(record){
        date = parse(d.date);
        array = [date]
        // console.log(array)

        var week = d3.time.format("%U");

        var nest = d3.nest()
            .key(function(d) { return week(new Date(array)); })
            .entries(array);
        // console.log(nest)
        disp = [nest]
        console.log(nest)


      return {x: array[0], y: +d[cause]};
    });
  }));

  // Compute the x-domain (by date) and y-domain (by top).
  x.domain(causes[0].map(function(d) { return d.x; }));
  y.domain([0, d3.max(causes[causes.length - 1], function(d) { return d.y0 + d.y; })]);

  // Add a group for each cause.
  var cause = svg.selectAll("g.cause")
      .data(causes)
    .enter().append("svg:g")
      .attr("class", "cause")
      .style("fill", function(d, i) { return z(i); })
      .style("stroke", function(d, i) { return d3.rgb(z(i)).darker(); });

  // Add a rect for each date.
  var rect = cause.selectAll("rect")
      .data(Object)
    .enter().append("svg:rect")
      .attr("x", function(d) { return x(d.x); })
      .attr("y", function(d) { return -y(d.y0) - y(d.y); })
      .attr("height", function(d) { return y(d.y); })
      .attr("width", x.rangeBand());

  // Add a label per date.
  var label = svg.selectAll("text")
      .data(x.domain())
    .enter().append("svg:text")
      .attr("x", function(d) { return x(d) + x.rangeBand() / 2; })
      .attr("y", 6)
      .attr("text-anchor", "middle")
      .attr("dy", ".71em")
      .text(format);

  // Add y-axis rules.
  var rule = svg.selectAll("g.rule")
      .data(y.ticks(5))
    .enter().append("svg:g")
      .attr("class", "rule")
      .attr("transform", function(d) { return "translate(0," + -y(d) + ")"; });

  rule.append("svg:line")
      .attr("x2", w - p[1] - p[3])
      .style("stroke", function(d) { return d ? "#fff" : "#000"; })
      .style("stroke-opacity", function(d) { return d ? .7 : null; });

  rule.append("svg:text")
      .attr("x", w - p[1] - p[3] + 6)
      .attr("dy", ".35em")
      .text(d3.format(",d"));
});

    </script>
    <tr>
      <!-- <td>Previous</td> -->
      <td>Next</td>
    </tr>
  </body>
</html>

现在在X轴上,代码显示给定JSON数据中的所有行。 我的需求是我想一次只显示一周的数据。意味着我在JSON中有多行,我设法将天数嵌套到一周内。

请帮我现在用给定的代码自定义X轴。我试图在X轴上调用嵌套数组的值,但它没有给出正确的输出。 提前谢谢

1 个答案:

答案 0 :(得分:0)

因为您需要将groupBy添加到 JSON 数据。

您可以尝试这种简单的方法来实现:

var groupedByWeek = _.groupBy(data, function(item) {
        var dateMoment = moment(item.day,"DD/MM/YYYY");
        return dateMoment.week();

将天数转换为一周!