d3水平条形图,背景,最大值100%

时间:2017-07-08 13:16:14

标签: d3.js

我有这个单一的水平条形图,我想进行以下调整:

  1. 显示条形图右侧的刻度值,而不是轴。
  2. 显示条形图比例的背景,而不是左轴和下轴。
  3. 当前版本: enter image description here

    我想去的地方:

    enter image description here

    JS

    var data = [
          {"yAxis":"score", "xAxis":"72"}
        ];          
        // set the dimensions and margins of the graph
        var margin = {top: 20, right: 20, bottom: 30, left: 80},
        width = 960 - margin.left - margin.right,
        height = 500 - margin.top - margin.bottom;          
        // set the ranges
        var y = d3.scaleBand()
        .range([height, 0])
        .padding(0.4);
        var x = d3.scaleLinear()
        .range([0, width]);          
        var svg = d3.select(".barChartContainer").append("svg")          
        .attr("preserveAspectRatio", "xMinYMin meet")
        .attr("viewBox", "0 0 960 500")
        .append("g")
        .attr("transform",
        "translate(" + margin.left + "," + margin.top + ")");        
        // Scale the range of the data in the domains
        x.domain([0, d3.max(data, function(d){ return d.xAxis; })])
        y.domain(data.map(function(d) { return d.yAxis; }));        
        //y.domain([0, d3.max(data, function(d) { return d.prereqs; })]);
        // append the rectangles for the bar chart
        svg.selectAll(".bar")
        .data(data)
        .enter().append("rect")
        .attr("class", "bar")          
        .attr("y", function(d) { return y(d.yAxis); })
        .attr("height", y.bandwidth())
        .transition()
        .duration(1000)
        .delay(function(d, i) {
        return i * 100
        })
        .attr("width", function(d) {return x(d.xAxis); } );
        // add the x Axis
        svg.append("g")
        .attr("transform", "translate(0," + height + ")")
        .call(d3.axisBottom(x).tickValues(d3.range(x.domain()[0], x.domain()[1] + 1, 1))
        .tickFormat(d3.format("d"))
        );
        svg.append("g")
        .attr("class", "yAxis")
        .call(d3.axisLeft(y));
    

    我从codepen中获取了这些代码并且我一直在努力调整它,但它已经破坏了所以我停止了并且希望你可以提供帮助。

    感谢。

1 个答案:

答案 0 :(得分:2)

要显示条形图的背景,只需复制您的选择并为矩形选择100%的值,采用浅灰色填充:

var backgroundBar = svg.selectAll(null)
    .data(data)
    .enter()
    .append("rect")
    //etc...
    .attr("width", function(d) {
        return x(100);
    });

当然,您必须更改x比例的范围:

var x = d3.scaleLinear()
    .domain([0, 100]);

然后,放下两个轴并使用文本选择打印标签。

最后,对值使用另一个文本选择:

var values = svg.selectAll(null)
    .data(data)
    .enter()
    .append("text")
    //etc...
    .text(function(d) {
        return +d.xAxis
    })

如果需要,可以补间文字:

.attrTween("text", function(d) {
    var self = this
    var i = d3.interpolateNumber(0, +d.xAxis);
    return function(t) {
        return d3.select(self).text(~~i(t));
    }
});

结果如下:



var data = [{
  "yAxis": "score",
  "xAxis": "72"
}];

var margin = {
    top: 20,
    right: 20,
    bottom: 30,
    left: 80
  },
  width = 500 - margin.left - margin.right,
  height = 200 - margin.top - margin.bottom;

var y = d3.scaleBand()
  .range([height, 0])
  .padding(0.4);

var x = d3.scaleLinear()
  .range([0, width])
  .domain([0, 100]);

var svg = d3.select("body").append("svg")
  .attr("width", 500)
  .attr("height", 200)
  .append("g")
  .attr("transform",
    "translate(" + margin.left + "," + margin.top + ")");

y.domain(data.map(function(d) {
  return d.yAxis;
}));

var backgroundBar = svg.selectAll(null)
  .data(data)
  .enter()
  .append("rect")
  .attr("fill", "lightgray")
  .attr("y", function(d) {
    return y(d.yAxis);
  })
  .attr("height", y.bandwidth())
  .attr("width", function(d) {
    return x(100);
  });

var bar = svg.selectAll(null)
  .data(data)
  .enter()
  .append("rect")
  .attr("class", "bar")
  .attr("y", function(d) {
    return y(d.yAxis);
  })
  .attr("height", y.bandwidth())
  .transition()
  .duration(2000)
  .delay(function(d, i) {
    return i * 100
  })
  .attr("width", function(d) {
    return x(d.xAxis);
  });

var labels = svg.selectAll(null)
  .data(data)
  .enter()
  .append("text")
  .attr("y", function(d) {
    return y(d.yAxis) + y.bandwidth() / 2;
  })
  .attr("x", -10)
  .attr("text-anchor", "end")
  .text(function(d) {
    return d.yAxis
  });

var values = svg.selectAll(null)
  .data(data)
  .enter()
  .append("text")
  .attr("y", function(d) {
    return y(d.yAxis) + y.bandwidth() / 2;
  })
  .attr("x", 10)
  .text(function(d) {
    return +d.xAxis
  })
  .transition()
  .duration(2000)
  .delay(function(d, i) {
    return i * 100
  })
  .attr("x", function(d) {
    return x(d.xAxis) + 10;
  })
  .attrTween("text", function(d) {
    var self = this
    var i = d3.interpolateNumber(0, +d.xAxis);
    return function(t) {
      return d3.select(self).text(~~i(t));
    }
  });

<script src="https://d3js.org/d3.v4.min.js"></script>
&#13;
&#13;
&#13;