码迷,mamicode.com
首页 > 其他好文 > 详细

[D3] 5 .rangeBands

时间:2015-06-03 23:17:45      阅读:236      评论:0      收藏:0      [点我收藏+]

标签:

# d3.max

```js
var xScale = d3.scale.ordinal()
.domain(dataset)
.rangeBands([0,w],0.3, 0.1);
```

技术分享



### use:

```js
.attr(‘width‘, xScale.rangeBand())
.attr(‘x‘, function(each_data, index){
return xScale(each_data);
})
```

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title></title>
    <script src="../bower_components/underscore/underscore-min.js"></script>
    <script src="../ventor/d3.min.js"></script>
    <style type="text/css">

        body
        {
            padding-top: 50px;
            padding-left: 100px;

        }

        #chartArea {
            width: 400px;
            height: 300px;
            background-color: #CCC;
        }

        .bar
        {
            display: inline-block;
            width: 20px;
            height: 75px; /* Gets overriden by D3-assigned height below */
            margin-right: 2px;
            fill: teal; /* SVG doesn‘t have background prop, use fill instead*/
            z-index:99;
        }

    </style>
</head>
<body>
<section id="chartArea"></section>
<script>
    var dataset = _.map(_.range(15), function(num) {
        return Math.random() * 50;
    }), //reandom generate 15 data from 1 to 50
            w = 400, h = 300;
    var svg = d3.select(#chartArea).append(svg)
            .attr(width, w)
            .attr(height, h); //svg deosn‘t need ‘px‘

    var yScale = d3.scale.linear()
            .domain([0, d3.max(dataset) * 1.1]) //d3.max(dataset), set the max val of database
            .range([0, h]);

    var xScale = d3.scale.ordinal()
            .domain(dataset)
            .rangeBands([0,w],0.3, 0.1);

    svg.selectAll(div)
            .data(dataset)
            .enter()
            .append(rect)// svg doesn‘t have div, use rect instead
            .attr(class, "bar")
            .attr(width, xScale.rangeBand())
            .attr(x, function(each_data, index){
                return xScale(each_data);
            })
            .attr(y, function(each_data){
                return h-yScale(each_data);
            })
            .attr(height, function(each_data, i){
                return yScale(each_data);
            });
</script>

<!--
    1. svg should use ‘fill‘ prop instead ‘background-color‘
    2. svg width & height no need ‘px‘
    3. attr(function(data_val, index){})
    4. create svg, d3.select(‘selector‘).append(‘svg‘).attr(‘width‘, xxx).attr(‘height‘, xx)
    5. svg should use ‘rect‘ instead of ‘div‘
    -->
</body>
</html>

 

[D3] 5 .rangeBands

标签:

原文地址:http://www.cnblogs.com/Answer1215/p/4550471.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!