Skip welcome & menu and move to editor
Welcome to JS Bin
Load cached copy from
 
<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="utf-8">
        <script type="text/javascript" src="http://mbostock.github.com/d3/d3.js"></script>
        <style type="text/css">
            
            .axis path,
            .axis line {
                fill: none;
                stroke: black;
                shape-rendering: crispEdges;
            }
            
            .axis text {
                font-family: sans-serif;
                font-size: 11px;
            }
        </style>
    </head>
    <body>
        <script type="text/javascript">
            //Width and height
            var w = 500;
            var h = 300;
            var padding = 30;
            
            var now = d3.time.hour.utc(new Date);
            //Static dataset
            var dataset = [
                            [d3.time.hour.utc.offset(now, -5), 1, 10], 
                            [d3.time.hour.utc.offset(now, -4), 2, 20], 
                            [d3.time.hour.utc.offset(now, -3), 3, 30], 
                            [d3.time.hour.utc.offset(now, -2), 4, 40], 
                            [d3.time.hour.utc.offset(now, -1), 5, 50], 
                            [now, 6, 60],
                          ];
            
            //Create scale functions
            var xScale = d3.time.scale()
                                 .domain([d3.time.hour.utc.offset(now, -5), now])
                                 .range([padding, w - padding * 2]);
            var data_arr = [];
            for (row in dataset){
                for (col=1;col < dataset[row].length; col++){
                    data_arr.push(dataset[row][col]);
                }
            }
            var yScale = d3.scale.linear()
                                 .domain([0, d3.max(data_arr)])
                                 .range([h - padding, padding]);
            //Define X axis
            var xAxis = d3.svg.axis()
                              .scale(xScale)
                              .orient("bottom")
                              .ticks(5);
            //Define Y axis
            var yAxis = d3.svg.axis()
                              .scale(yScale)
                              .orient("left")
                              .ticks(5);
            //Create SVG element
            var svg = d3.select("body")
                        .append("svg")
                        .attr("width", w)
                        .attr("height", h);
            //Create circles
            svg.selectAll("circle")
               .data(dataset)
               .enter()
               .append("circle")
               .attr("cx", function(d) {
                    return xScale(d[0]);
               })
               .attr("cy", function(d) {
                    return yScale(d[1]);
               })
               .attr("r", 2);
            
            //Create X axis
            svg.append("g")
                .attr("class", "axis")
                .attr("transform", "translate(0," + (h - padding) + ")")
                .call(xAxis);
            
            //Create Y axis
            svg.append("g")
                .attr("class", "axis")
                .attr("transform", "translate(" + padding + ",0)")
                .call(yAxis);
        </script>
    </body>
</html>
Output 300px

You can jump to the latest bin by adding /latest to your URL

Dismiss x
public
Bin info
anonymouspro
0viewers