Po prostu próbuję przekonwertować plik .shp do formatu geoJSON, używając:
ogr2ogr -f geoJSON output.json input.shp
Po wykonaniu polecenia nic nie wydaje się błędne. Oto fragment pliku output.json
{
"type": "FeatureCollection",
"features": [
{ "type": "Feature",
"properties": { "ID_0": 86, "ISO": "DEU", "NAME_0": "Germany", "ID_1": 1, "NAME_1": "Baden-Württemberg", "NL_NAME_1": null, "VARNAME_1": null, "TYPE_1": "Land", "ENGTYPE_1": "State" },
"geometry": { "type": "MultiPolygon", "coordinates": [ [ [ [ 8.708400940398242, 47.715581894910606 ], [ 8.713716147005524, 47.701734382960055 ],
...
Ale kiedy próbuję użyć pliku de JSON w d3 (http://d3js.org/) do narysowania wielokątów SVG, dane wyjściowe są po prostu błędne. Ponieważ pliki shp są poprawnie wyświetlane w QGIS, myślę, że musi być coś nie tak ze sposobem, w jaki korzystam ogr2ogr
. Otrzymany plik SVG nie jest całkowicie błędny, ale wydaje się, że jest jakiś szczegół, którego nie mogę znaleźć. Wygląda na to, że został odwrócony do góry nogami i w jakiś sposób zniekształcony na dwie oddzielne części.
Oto javaScript, którego użyłem do wygenerowania pliku svg:
//dimensions
var w = 2000;
var h = 2000;
var svg = d3.select("#chart").append("svg")
.attr("width", w)
.attr("height", h);
d3.json(
"http://localhost:8888/data/data.json",
function (json) {
var path = d3.geo.path();
svg.append("g")
.attr("class", "black")
.selectAll("path")
.data(json.features)
.enter()
.append("path")
.attr("d", path);
Czy ktoś ma pojęcie, co tu poszło nie tak? Próbowałem także przekonwertować plik shp przy użyciu Qgis i myGeodata (http://converter.mygeodata.eu/vector). Ale żadne z nich nie działa tak, jak powinno.
Jestem bardzo nowy w całej tej kartografii. Byłbym bardzo szczęśliwy, gdyby uzyskać porady.
Dziękuję bardzo!