在D3中加载TopoJSON文件时的随机行

时间:2015-10-19 14:19:14

标签: d3.js shapefile topojson

我尝试使用D3.js显示意大利制图shapefile for example this one

我可以在MapShaper上加载Zip文件,查看地图,简化它并导出到TopoJSON。我可以在MapShaper中加载TopoJSON,它看起来还不错。

但是当我尝试使用D3.js显示它时,我得到了一堆意大利面条:

enter image description here

美丽,不是吗?

代码直接来自示例。投影中心,旋转和平行线应该是意大利的规范,但它并不重要:地图保持意大利面条状,可以选择任何投影。

width = 600
height = 1200

projection = d3.geo.albers()
    .center [0, 41]
    .rotate [347, 0]
    .parallels [35, 45]
    .scale 2000
    .translate [width / 2, height / 2]

path = d3.geo.path()
    .projection projection

svg = d3.select "body"
    .append "svg"
    .attr "width", width
    .attr "height", height

d3.json "Reg2011_ED50.json", (json) ->
    svg.append "path"
        .datum topojson.feature json, json.objects.Reg2011_ED50
        .attr "d", path

我做错了什么?

1 个答案:

答案 0 :(得分:4)

我找到了一个旧的邮件列表帖子,详细说明了如何导入这些确切的文件。

基本上我需要使用此命令将投影转换为标准投影:

ogr2ogr -t_srs EPSG:4326 converted.shp original.shp

我不明白为什么需要它:我认为.prj文件处理投影差异。显然不是。