D3
OG
Old school D3 from simpler times
All examples
By author
By category
About
marreguin523
Full window
Github gist
MidtermHeatmap2
Built with
blockbuilder.org
<!DOCTYPE html> <meta charset="utf-8"> <style> .axis path, .axis line { fill: none; stroke: black; shape-rendering: crispEdges; } .axis text { font-family: sans-serif; font-size: 11px; } </style> <div class="heatmap"></div> <script src="//d3js.org/d3.v3.min.js"></script> <script> var itemSize = 8, cellSize = itemSize - 1, margin = {top: 20, right: 90, bottom: 30, left: 50}; var width = 960 - margin.left - margin.right, height = 600 - margin.top - margin.bottom; var x = d3.scale.linear().range([0, width]), y = d3.scale.linear().range([height, 0]), z = d3.scale.linear().range(["white", "steelblue"]); var xStep = 864e5, yStep = 100; var svg = d3.select("body").append("svg") .attr("width", width + margin.left + margin.right) .attr("height", height + margin.top + margin.bottom) .append("g") .attr("transform", "translate(" + margin.left + "," + margin.top + ")"); d3.csv("MidtermData (1).csv", function ( error, data ) { if (error) throw error; // var data = response.map(function( item ) { // var newItem = {}; // newItem.district = item.Neighborhood_District; // newItem.type = item.Unit_Type; // newItem.Number_of_Alarms = item.Number_of_Alarms; // return newItem; // }) data.forEach(function(d) { d.district = d.Neighborhood_District; d.type = d.Unit_Type; d.Number_of_Alarms = +d.Number_of_Alarms; }); x.domain(d3.extent(data, function(d) { return d.type; })); y.domain(d3.extent(data, function(d) { return d.district; })); z.domain([0, d3.max(data, function(d) { return d.Number_of_Alarms; })]); x.domain([x.domain()[0], +x.domain()[1] + xStep]); y.domain([y.domain()[0], y.domain()[1] + yStep]); var x_elements = d3.set(data.map(function( item ) { return item.type; } )).values(), y_elements = d3.set(data.map(function( item ) { return item.district; } )).values(); var xScale = d3.scale.ordinal() .domain(x_elements) .rangeBands([0, x_elements.length * itemSize]); var xAxis = d3.svg.axis() .scale(xScale) .tickFormat(function (d) { return d; }) .orient("top"); var yScale = d3.scale.ordinal() .domain(y_elements) .rangeBands([0, y_elements.length * itemSize]); var yAxis = d3.svg.axis() .scale(yScale) .tickFormat(function (d) { return d; }) .orient("left"); svg.selectAll(".tile") .data(data) .enter().append("rect") .attr("class", "tile") .attr("x", function(d) { return x(d.type); }) .attr("y", function(d) { return y(d.district + yStep); }) .attr("width", x(xStep) - x(0)) .attr("height", y(0) - y(yStep)) .style("fill", function(d) { return z(d.Number_of_Alarms); }); // var svg = d3.select('.heatmap') // .append("svg") // .attr("width", width + margin.left + margin.right) // .attr("height", height + margin.top + margin.bottom) // .append("g") // .attr("transform", "translate(" + margin.left + "," + margin.top + ")"); // var cells = svg.selectAll('rect') // .data(data) // .enter().append('g').append('rect') // .attr('class', 'cell') // .attr('width', cellSize) // .attr('height', cellSize) // .attr('y', function(d) { return yScale(d.district); }) // .attr('x', function(d) { return xScale(d.type); }) // .attr('fill', function(d) { return z(d.Number_of_Alarms); }); // svg.append("g") // .attr("class", "y axis") // .call(yAxis) // .selectAll('text') // .attr('font-weight', 'normal'); // svg.append("g") // .attr("class", "x axis") // .call(xAxis) // .selectAll('text') // .attr('font-weight', 'normal') // .style("text-anchor", "start") // .attr("dx", ".8em") // .attr("dy", ".5em") // .attr("transform", function (d) { // return "rotate(-65)"; // }); // Add a legend for the color values. var legend = svg.selectAll(".legend") .data(z.ticks(6).slice(1).reverse()) .enter().append("g") .attr("class", "legend") .attr("transform", function(d, i) { return "translate(" + (width + 20) + "," + (20 + i * 20) + ")"; }); legend.append("rect") .attr("width", 20) .attr("height", 20) .style("fill", z); legend.append("text") .attr("x", 26) .attr("y", 10) .attr("dy", ".35em") .text(String); svg.append("text") .attr("class", "label") .attr("x", width + 20) .attr("y", 10) .attr("dy", ".35em") .text("Incident Count"); // Add an x-axis with label. svg.append("g") .attr("class", "x axis") .attr("transform", "translate(0," + height + ")") .call(xAxis) .append("text") .attr("class", "label") .attr("x", width) .attr("y", -6) .attr("text-anchor", "end") .text("Unit Type"); // Add a y-axis with label. svg.append("g") .attr("class", "y axis") .call(yAxis) .append("text") .attr("class", "label") .attr("y", 6) .attr("dy", ".71em") .attr("text-anchor", "end") .attr("transform", "rotate(-90)") .text("District"); }); </script>
https://d3js.org/d3.v3.min.js