.DS_Store
# use-d3-v3-to-build-interactive-charts-with-javascript
#chartArea {
width: 500px;
height: 400px;
background-color: #CCC;
}
.dot {
fill: teal;
fill-opacity: 0.7;
stroke: black;
}
.active {
fill: magenta;
fill-opacity: 0.5;
stroke-width: 3px;
}
.axis path, .axis line {
fill: none;
stroke: #000;
stroke-width: 1px;
shape-rendering: crispEdges;
}
<!DOCTYPE html>
<html>
<head>
<title>D3 - Data Driven Documents</title>
<script src="https://cdnjs.cloudflare.com/ajax/libs/d3/3.5.16/d3.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/underscore.js/1.8.3/underscore.js"></script>
<link rel="stylesheet" href="app.css">
</head>
<body>
<div id="chartArea"></div>
<script src="script.js"></script>
</body>
</html>
var dataset = _.map(_.range(25), function (i) {
return {
x: Math.round(Math.random() * 100),
y: Math.round(Math.random() * 100),
r: Math.round(5 + Math.random() * 10)
};
});
var margin = {top: 20, right: 20, bottom: 60, left: 60};
var w = 500 - margin.left - margin.right,
h = 400 - margin.top - margin.bottom;
var svg = d3.select('#chartArea').append('svg')
.attr('width', w + margin.left + margin.right)
.attr('height', h + margin.top + margin.bottom)
.append('g')
.attr('transform', 'translate(' + margin.left + ', ' + margin.top + ')');
var xScale = d3.scale.linear()
.domain([0, 100])
.range([0, w]);
var xAxis = d3.svg.axis()
.scale(xScale)
.orient('bottom')
.ticks(5)
.innerTickSize(6)
.outerTickSize(12)
.tickPadding(12);
svg.append('g')
.attr('class', 'x axis')
.attr('transform', 'translate(0, '+ (h + 0) + ')')
.call(xAxis);
var yScale = d3.scale.linear()
.domain([0, 100])
.range([h, 0]);
var yAxis = d3.svg.axis()
.scale(yScale)
.orient('left');
svg.append('g')
.attr('class', 'y axis')
.attr('transform', 'translate(0, 0)')
.call(yAxis);
svg.selectAll('circle')
.data(dataset)
.enter()
.append('circle')
.attr('class', 'dot')
.attr('cx', function (d) {
return xScale(d.x);
})
.attr('cy', function (d) {
return yScale(d.y);
})
.attr('r', function (d) {
return d.r;
})
.on('mouseover', function (d) {
d3.select(this).classed('active', true);
})
.on('mouseout', function (d) {
d3.select(this).classed('active', false);
})
.on('mousedown', function (d) {
d3.select(this).attr('r', d.r * 2);
})
.on('mouseup', function (d) {
d3.select(this).attr('r', d.r);
});