我正在尝试使用 d3.js 制作 Choropleth,但我一开始就被卡住了。我找到了一个 Shapefile 并从中生成了 GeoJSON 和 TopoJson 文件,就像这里一样。该地图使用阿尔伯斯-西伯利亚投影。我对这个投影的发现:
投影:Albers 等积圆锥
- 单位:米
- 球体:克拉索夫斯基
- 中央经线:105
- 标准并行 1:52
- 标准并行 2:64
- 参考纬度:0
- 假东:18500000
- 伪北:0
PROJ.4: +proj=aea +lat_1=52 +lat_2=64 +lat_0=0 +lon_0=105 +x_0=18500000 +y_0=0 +ellps=krass +units=m +towgs84=28,-130,-95 ,0,0,0,0 +no_defs
地图信息:“阿尔伯斯-西伯利亚”,9、1001、7、105、0、64、52、18500000、0。
所以我终于得到了这段代码,它什么也没做(甚至冻结),怎么了?
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>Choropleth</title>
<script type="text/javascript" src="d3/d3.v3.js"></script>
<script type="text/javascript" src="d3/queue.v1.min.js"></script>
<script type="text/javascript" src="d3/topojson.v0.min.js"></script>
</head>
<body>
<h1>My Choropleth</h1>
<script type="text/javascript">
var width = 960,
height = 500;
var svg = d3.select("body").append("svg")
.attr("width", width)
.attr("height", height);
var pr = d3.geo.albers()
.center([105,0])
.parallels([52, 64])
.scale(1000);
var path = d3.geo.path().projection(pr);
d3.json("map_rus_topo.json", function(error, map) {
svg.append("path")
.datum(topojson.object(map, map.objects.map_rus))
.attr("d", path);
});
</script>
</body>
您可以在此处
找到所有 JSON 文件。
还有一个问题:如何在我的TopoJson 文件中引用region字段的值。