Skip to content

Instantly share code, notes, and snippets.

@geraldo
Created January 16, 2019 16:08
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save geraldo/2a9ecdf31dedf154ab967e0e39268971 to your computer and use it in GitHub Desktop.
Save geraldo/2a9ecdf31dedf154ab967e0e39268971 to your computer and use it in GitHub Desktop.
geojson
license: mit
<!DOCTYPE html>
<head>
<meta charset="utf-8">
<script src="https://d3js.org/d3.v5.min.js"></script>
<style>
body { margin:0;position:fixed;top:0;right:0;bottom:0;left:0; }
</style>
</head>
<body>
<script>
var svg = d3.select("body").append("svg")
.attr("width", 960)
.attr("height", 500);
var files = ["mines.json", "mines_centroid.json"];
var promises = [];
files.forEach(function (url) {
promises.push(d3.json(url));
});
Promise.all(promises).then(function (val) {
drawMap(val[0], val[1]);
});
var projection = d3.geoMercator();
var geoPath = d3.geoPath()
.projection(projection);
var radius = d3.scaleLog();
function drawMap(mines, centroid) {
console.log("drawMap", mines.features, centroid.features);
projection.center([22.9696994071445, 40.8135651828386]);
projection.fitSize([960, 500], mines);
svg.append("g")
.selectAll("path")
.data(mines.features)
.enter()
.append("path")
.attr("d", geoPath)
.attr("stroke", "blue")
.attr("fill", "white")
.attr("class", "mines");
addCentroid(centroid);
}
function addCentroid(centroid) {
console.log(centroid);
var points = svg.selectAll("circle")
.data(centroid.features, function (d) {
return d;
})
.enter().append("circle")
.attr('r', function (d) {
return radius * 1.5
})
.attr('cx', function (d) {
return projection(d.geometry.coordinates)[0]
})
.attr('cy', function (d) {
return projection(d.geometry.coordinates)[1]
})
.attr("class", "centroid")
.attr("id", function (d) {
return d.properties.ID
})
}
</script>
</body>
Display the source blob
Display the rendered blob
Raw
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Display the source blob
Display the rendered blob
Raw
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment