You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
171 lines
4.5 KiB
171 lines
4.5 KiB
<!DOCTYPE html>
|
|
<html>
|
|
<head>
|
|
<meta charset="UTF-8">
|
|
<title>Selections</title>
|
|
<style>
|
|
.axis line,
|
|
.axis path {
|
|
stroke-width: 1;
|
|
fill: none;
|
|
stroke: #333;
|
|
shape-rendering: crispEdges;
|
|
}
|
|
</style>
|
|
</head>
|
|
<body>
|
|
<div id="viz-wrapper">
|
|
</div>
|
|
<script src="http://d3js.org/d3.v3.min.js" charset="utf-8"></script>
|
|
<script type="text/javascript">
|
|
|
|
// height and width of the svg
|
|
var height = 800,
|
|
width = 500;
|
|
|
|
var padding = 50;
|
|
|
|
var defaultCircleRadius = 2;
|
|
|
|
var zoom = d3.behavior.zoom()
|
|
.scaleExtent([1, 10])
|
|
.on("zoom", zoomed);
|
|
|
|
var svg = d3.select("#viz-wrapper")
|
|
.append('svg')
|
|
.attr('height', height + padding * 2 )
|
|
.attr('width', width + padding * 2)
|
|
.call(zoom);
|
|
|
|
var viz = svg.append('g')
|
|
.attr('id', 'viz')
|
|
.attr('transform',
|
|
'translate(' + padding + ',' + padding + ')');
|
|
|
|
var yScale = d3.scale.linear()
|
|
.range([height, 0]);
|
|
|
|
var xScale = d3.time.scale()
|
|
.range([0, width]);
|
|
|
|
var rScale = d3.scale.linear()
|
|
.range([5, 50]);
|
|
|
|
var xAxis = d3.svg.axis().scale(xScale)
|
|
.orient("bottom")
|
|
.ticks(20);
|
|
|
|
var yAxis = d3.svg.axis().scale(yScale)
|
|
.orient("left")
|
|
.ticks(20);
|
|
|
|
var parseTime = d3.time.format("%Y%m%d");
|
|
|
|
var solveForR = function(TMAX) {
|
|
// area of a circle
|
|
// Area = Pi * r * r
|
|
Area = Math.abs( TMAX );
|
|
r = Math.sqrt( Area / Math.PI);
|
|
return r
|
|
};
|
|
|
|
d3.csv('climate_data.csv', function(data) {
|
|
yDomain = d3.extent(data, function(element){
|
|
return parseInt(element.TMAX) * 1.1
|
|
});
|
|
|
|
xMin = d3.min(data, function(element) {
|
|
time = parseTime.parse(element.DATE);
|
|
time.setMonth(time.getMonth() - 1);
|
|
return time
|
|
});
|
|
|
|
xMax = d3.max(data, function(element) {
|
|
time = parseTime.parse(element.DATE);
|
|
time.setMonth(time.getMonth() + 1);
|
|
return time
|
|
});
|
|
|
|
rDomain = d3.extent(data, function(element){
|
|
return solveForR(parseInt(element.TMAX));
|
|
});
|
|
|
|
yScale.domain(yDomain);
|
|
rScale.domain(rDomain);
|
|
xScale.domain([xMin, xMax]);
|
|
|
|
// Add the X Axis
|
|
viz.append("g")
|
|
.attr("class", "x axis")
|
|
.attr("transform", "translate(0," + height + ")")
|
|
.call(xAxis)
|
|
.selectAll('text')
|
|
.attr("transform", function() {
|
|
return "rotate(-65)"
|
|
})
|
|
.style("text-anchor", "end")
|
|
.style('font-size', '10px')
|
|
.attr("dx", "-10px")
|
|
.attr("dy", "10px");
|
|
|
|
viz.append("g")
|
|
.attr("class", "y axis")
|
|
.call(yAxis);
|
|
|
|
dots = viz.selectAll('g.dots')
|
|
.data(data)
|
|
.enter()
|
|
.append('g')
|
|
.attr('class', 'dots');
|
|
|
|
dots.attr('transform', function(d) {
|
|
// get the x position
|
|
date = parseTime.parse(d.DATE);
|
|
x = xScale(date)
|
|
// get the y position
|
|
y = yScale(d.TMAX)
|
|
return 'translate(' + x + ',' + y + ')'
|
|
})
|
|
.style('stroke', '#00ffd2')
|
|
.style('fill', '#006bff');
|
|
|
|
dots.append('circle')
|
|
.attr('r', defaultCircleRadius);
|
|
|
|
dots.append('text')
|
|
.text(function(d) {
|
|
return d.TMAX
|
|
})
|
|
.style('display', 'none');
|
|
|
|
dots.on("mouseenter", function(d, i) {
|
|
dot = d3.select(this);
|
|
radius = solveForR( parseInt(d.TMAX) )
|
|
dot.select('text')
|
|
.style('display', 'block');
|
|
dot.select('circle')
|
|
.attr('r', rScale( radius ));
|
|
});
|
|
|
|
dots.on("mouseleave", function(d, i) {
|
|
dot = d3.select(this);
|
|
dot.select('text')
|
|
.style('display', 'none');
|
|
dot.select('circle')
|
|
.attr('r', defaultCircleRadius);
|
|
});
|
|
});
|
|
|
|
// var container = d3.select("#viz-wrapper")
|
|
// .select('svg');
|
|
|
|
function zoomed() {
|
|
debugger;
|
|
viz.attr("transform", "translate(" +
|
|
d3.event.translate + ")" +
|
|
"scale(" + d3.event.scale + ")");
|
|
};
|
|
|
|
</script>
|
|
</body>
|
|
</html> |