Skip to content

Latest commit

 

History

History
127 lines (96 loc) · 3.47 KB

README.md

File metadata and controls

127 lines (96 loc) · 3.47 KB

JapanCityGeoJson

47都道府県の県・市・町・村・郡・区の形を作るためのGeoJsonデータ、TopoJsonデータです。

国土数値情報 (JPGIS2.1(GML)準拠及びSHAPE形式データ) 国土交通省

国土交通省国土政策局GISHP http://nlftp.mlit.go.jp/ksj/gml/datalist/KsjTmplt-N03.html

GeoJson http://geojson.org/

TopoJson https://github.com/mbostock/topojson

GeoJson and TopoJson作成コマンド

国土交通省のサイトからダウンロードした「47都道府県SHAPE形式」から「47都道府県GeoJson」を作成

ogr2ogr -f GeoJSON places.json N03-14_140401.shp

「47都道府県GeoJson」がどデカイので「県、市、町、村、郡、区単位のGeoJson」に分割

ruby split_geojson.rb

「GeoJson」からもっと軽量な「TopoJson」に変換

./geojson_to_topojson.sh

サンプル 例:GoogleMapAPIv3

GoogleMapAPIv3はGeoJsonデータに対応しているので富山県氷見市を表示してみます。

ローカルに設置したGeoJsonを追加

var data = {<-- GeoJson -->};
var mapOptions = {
    zoom: 9,
    center: new google.maps.LatLng(36.786897, 136.892720)
};
var map = new google.maps.Map(document.getElementById("canvas"), mapOptions);
map.data.addGeoJson(data);
map.data.setStyle({fillColor: 'green'});

Screencast

サーバーに設置したGeoJsonを読込

var mapOptions = {
    zoom: 9,
    center: new google.maps.LatLng(36.786897, 136.892720)
};
var map = new google.maps.Map(document.getElementById("canvas"), mapOptions);
map.data.loadGeoJson('http://geojson.niiyz.com/geojson/富山県/氷見市.json');
map.data.setStyle({fillColor: 'green'});

その他の市町村の例

map.data.loadGeoJson('http://geojson.niiyz.com/geojson/神奈川県/神奈川県.json');

map.data.loadGeoJson('http://geojson.niiyz.com/geojson/神奈川県/横浜市.json');

map.data.loadGeoJson('http://geojson.niiyz.com/geojson/神奈川県/横浜市金沢区.json');
map.data.loadGeoJson('http://geojson.niiyz.com/geojson/神奈川県/横浜市旭区.json');

郡全域

map.data.loadGeoJson('http://geojson.niiyz.com/geojson/高知県/高岡郡.json');

町・村

map.data.loadGeoJson('http://geojson.niiyz.com/geojson/高知県/高岡郡中土佐.json');

市町村郡区シェイプ確認デモ(GoogleMap)

http://geojson.niiyz.com/

サンプル 例: D3.js

TopoJsonをD3.jsで使用してみます。

<style>
    .氷見市 { fill: red;}
</style>
<script src="http://d3js.org/d3.v3.min.js"></script>
<script src="http://d3js.org/topojson.v1.min.js"></script>
<script>
var width = 800, height = 500;
var svg = d3.select("body").append("svg")
    .attr("width", width)
    .attr("height", height);

d3.json("topojson/富山県/富山県.topojson", function(error, json) {

  var toyama = topojson.feature(json, json.objects["富山県"]);
  var bounds = d3.geo.bounds(toyama);
  var centerX = d3.sum(bounds, function(d) {return d[0];}) / 2,
      centerY = d3.sum(bounds, function(d) {return d[1];}) / 2;
  var projection = d3.geo.mercator()
    .scale(10000)
    .center([centerX, centerY]);

  svg.selectAll("path")
      .data(toyama.features).enter().append("path")
      .attr("d", d3.geo.path().projection(projection))
      .attr("class", function(d) { return d.id; });
});
</script>

Screencast