Próbuję zrobić Choropleth z d3.js, ale utknąłem na samym początku. Znalazłem plik Shapefile i wygenerowałem z niego pliki GeoJSON i TopoJson, podobnie jak here. Mapa wykorzystuje projekcję Albers-Syberia. Co znalazłem o tym projekcji:Mapa z d3.js i TopoJSON, Albers Syberia projekcja
projekcyjne: Albers Equal-Area stożkowa
- Units: Liczniki
- sferoidalna: Krasowskiego
- centralny południk: 105
- standard Parallel 1: 52
- Standardowa równoległa 2: 64
- Szerokość geograficzna: 0
- Fałsz Y: 18500000
- Fałsz X: 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 + jednostki = m + towgs84 = 28, -130, -95,0,0,0,0 + no_defs
MapInfo: "Albers-Siberia", 9, 1001, 7, 105, 0, 64, 52, 18500000, 0.
Więc dostałem ten kod w końcu i nic nie robi (a nawet freez), co jest nie tak?
<!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>
można znaleźć wszystkie pliki JSON here.
I jeszcze jedno pytanie: Jak mogę odnieść się do wartości pola region w mój plik TopoJson.
Co dokładnie dzieje się po uruchomieniu kodu? Czy otrzymujesz komunikat o błędzie, wyjście? –
Nie, brak błędów w konsoli. – KoGor
Rozmiar plików JSON może być problemem. Czy próbowałeś je uprościć lub po prostu trochę dłużej? –