我想使用d3.js和topoJSON创建非洲地图。我有那个数据源https://gist.githubusercontent.com/bricedev/3905007f1794b0cb0bcd/raw/ad5c995f6990f7c3c7fad5c6206bc6fd5462f1fb/africa.json
这是我的代码。我如何获得属性并创建正确的地图?请帮帮我错误在哪里?
<!DOCTYPE html>
<html>
<head>
<meta name="description" content="D3byEX 12.15" />
<meta charset="utf-8">
</head>
<body>
<script src="http://d3js.org/d3.v3.min.js"></script>
<script src="http://d3js.org/topojson.v1.min.js"></script>
<script>
var width = 1000, height = 728;
var svg = d3.select("body").append("svg")
.attr({ width: width, height: height });
var mainGroup = svg.append("g");
mainGroup.style({ stroke: "white", "stroke-width": "2px", "stroke-opacity": 0.0 });
var projection = d3.geo.mercator();
var path = d3.geo.path().projection(projection);
var url = 'https://gist.githubusercontent.com/bricedev/3905007f1794b0cb0bcd/raw/ad5c995f6990f7c3c7fad5c6206bc6fd5462f1fb/africa.json';
d3.json(url, function (error, africa) {
var countries = topojson.feature(africa, africa.objects.countries).features;
var neighbors = topojson.neighbors(africa.objects.countries.geometries);
var color = d3.scale.category20();
mainGroup.selectAll("path", "countries")
.data(countries)
.enter().append("path")
.attr("d", path)
.style("fill", function (d, i) {
return color(d.color = d3.max(neighbors[i],
function (n) { return countries[n].color; }) + 1 | 0);
});
mainGroup.selectAll("path")
.on("mouseover", function () {
console.log("mouseover");
d3.select(this).style("stroke-opacity", 1.0);
});
mainGroup.selectAll("path")
.on("mouseout", function () {
d3.select(this).style("stroke-opacity", 0.0);
});
});
</script>
答案 0 :(得分:2)
你的topojson不在WGS84中,也就是说lat / long坐标空间或未投影的数据。 D3.projection()需要WGS84。
你的topojson已被投射,我认为是Africa Lambert Conformal Conic投影。您无需使用投影在d3.js中显示此内容。为了在没有投影的情况下显示此数据,您可以将geoPath的投影定义为:
path = d3.geoPath().projection(null);
这是topojson在the block中投射数据的方式。
如果您需要缩放或翻译投影,那么d3.geoTransform可以为您提供帮助,请参阅this block。
或者,你可以重新投影你的topojson,使它使用纬度/经度对,并使用d3.projection()正确投影。