使用d3.js和topoJSON创建非洲地图

时间:2016-12-19 22:23:38

标签: javascript d3.js maps topojson

我想使用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>

1 个答案:

答案 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()正确投影。