{"id":3509,"date":"2014-12-16T09:48:24","date_gmt":"2014-12-16T00:48:24","guid":{"rendered":"http:\/\/blog.bitmeister.jp\/?p=3509"},"modified":"2014-12-16T09:48:24","modified_gmt":"2014-12-16T00:48:24","slug":"postgis%e3%81%a8geodjango%e3%82%92%e4%bd%bf%e3%81%a3%e3%81%a6leaflet%e3%81%a7geojson-tile-layer%e3%82%92%e8%a1%a8%e7%a4%ba%e3%81%97%e3%81%a6%e3%81%bf%e3%82%8b4-geodjango%e3%81%a7geojson","status":"publish","type":"post","link":"https:\/\/blog.bitmeister.jp\/?p=3509","title":{"rendered":"PostGIS\u3068GeoDjango\u3092\u4f7f\u3063\u3066Leaflet\u3067GeoJSON Tile Layer\u3092\u8868\u793a\u3057\u3066\u307f\u308b(4) \u2013 GeoDjango\u3067GeoJSON\u3092\u51fa\u529b\u3059\u308b &#8211;"},"content":{"rendered":"<p><a href=\"https:\/\/blog.bitmeister.jp\/?p=3475\">\u524d\u56de<\/a>\u3067\u7ba1\u7406\u753b\u9762\u307e\u3067\u3067\u304d\u307e\u3057\u305f\u3002\u3088\u3046\u3084\u304f\u30e1\u30a4\u30f3\u3068\u306a\u308b\u30d6\u30e9\u30a6\u30b6\u5074\u3068\u9023\u643a\u3059\u308b\u3068\u3053\u308d\u3092\u5b9f\u88c5\u3057\u305f\u3044\u3068\u601d\u3044\u307e\u3059\u3002\u3068\u3053\u308d\u3067Django\u3067GeoJSON\u3063\u3066\u3069\u3046\u3084\u308b\u3093\u3060\u308d\u3046\u304b\u3002\u305d\u3093\u306a\u3068\u3053\u308d\u304b\u3089\u4eca\u56de\u306f\u59cb\u307e\u308a\u307e\u3059\u3002<\/p>\n<p><!--more--><\/p>\n<h1>GeoJSON\u3068\u306f<\/h1>\n<p>\u305d\u3082\u305d\u3082GeoJSON\u3063\u3066\u306a\u3093\u306a\u306e\u3088\u3068\u3044\u3046\u8a71\u3067\u3059\u304c\u3001Wikipedia\u3055\u3093\u306b\u3088\u308b\u3068\u2026<\/p>\n<blockquote><p>GeoJSON\u306fJavaScript Object Notation\u3092\u7528\u3044\u3066\u7a7a\u9593\u30c7\u30fc\u30bf\u3092\u30a8\u30f3\u30b3\u30fc\u30c9\u3057\u975e\u7a7a\u9593\u5c5e\u6027\u3092\u95a2\u9023\u4ed8\u3051\u308b\u30d5\u30a1\u30a4\u30eb\u5f62\u5f0f\u3067\u3042\u308b\u3002 \u5c5e\u6027\u306b\u306f\u30dd\u30a4\u30f3\u30c8\uff08\u4f4f\u6240\u3084\u5ea7\u6a19\uff09\u3001\u30e9\u30a4\u30f3\uff08\u5404\u7a2e\u9053\u8def\u3084\u5883\u754c\u7dda\uff09\u3001 \u30dd\u30ea\u30b4\u30f3\uff08\u56fd\u3084\u5730\u57df\uff09\u306a\u3069\u304c\u542b\u307e\u308c\u308b\u3002 \u4ed6\u306eGIS\u30d5\u30a1\u30a4\u30eb\u5f62\u5f0f\u3068\u306e\u9055\u3044\u3068\u3057\u3066\u3001Open Geospatial Consortium\u3067\u306f\u306a\u304f\u4e16\u754c\u5404\u5730\u306e\u958b\u767a\u8005\u9054\u304c\u958b\u767a\u3057\u7ba1\u7406\u3057\u3066\u3044\u308b\u70b9\u3067\u7570\u306a\u308b\u3002<\/p><\/blockquote>\n<p>\u8981\u306f\u7a7a\u9593\u30c7\u30fc\u30bf\u3092\u6271\u3048\u308b\u3088\u3046\u306b\u3057\u305fJSON\u3067\u3059\u306d\u3001\u8a73\u7d30\u306f\u4ee5\u4e0b\u306b\u30d5\u30a9\u30fc\u30de\u30c3\u30c8\u304c\u5b9a\u7fa9\u3055\u308c\u3066\u3044\u307e\u3059\u3002<\/p>\n<p><a href=\"http:\/\/geojson.org\/geojson-spec.html\" target=\"_blank\">The GeoJSON Format Specification<\/a><\/p>\n<h1>GeoDjango\u3067GeoJSON\u3092\u51fa\u529b\u3059\u308b<\/h1>\n<h2>GeoDjango\u306e\u6a5f\u80fd\u3092\u8a66\u3059<\/h2>\n<p>GeoDjango\u306e\u30c9\u30ad\u30e5\u30e1\u30f3\u30c8\u3092\u8abf\u3079\u3066\u307f\u308b\u3068\u305d\u308c\u3063\u307d\u3044\u30e1\u30bd\u30c3\u30c9\u304c\u3042\u3063\u305f\u306e\u3067\u8a66\u3057\u3066\u307f\u307e\u3057\u305f\u3002<\/p>\n<pre class=\"brush: bash; gutter: false; title: ; notranslate\" title=\"\">\r\n$ python manage.py shell\r\nPython 2.7.6 (default, Mar 22 2014, 22:59:56)\r\nType &quot;copyright&quot;, &quot;credits&quot; or &quot;license&quot; for more information.\r\n\r\nIPython 2.3.1 -- An enhanced Interactive Python.\r\n?         -&gt; Introduction and overview of IPython's features.\r\n%quickref -&gt; Quick reference.\r\nhelp      -&gt; Python's own help system.\r\nobject?   -&gt; Details about 'object', use 'object??' for extra details.\r\n\r\nIn &#x5B;1]: from demo.models import Border\r\n\r\nIn &#x5B;2]: print(Border.objects.filter(id=73274).geojson()&#x5B;0].geojson)\r\n{&quot;type&quot;:&quot;Polygon&quot;,&quot;coordinates&quot;:&#x5B;&#x5B;&#x5B;123.75450033,24.06346143],&#x5B;123.75468433,24.06348943],&#x5B;123.75469133,24.06332543],&#x5B;123.75459233,24.06329143],&#x5B;123.75450033,24.06346143]]]}\r\n\r\nIn &#x5B;3]:\r\n<\/pre>\n<p>\u3042\u308c? \u5c5e\u6027(properties)\u304c\u51fa\u529b\u3055\u308c\u307e\u305b\u3093\u306d\u3002\u3069\u3046\u3082\u958b\u767a\u7248\u306b\u306f\u65b0\u3057\u3044API\u304c\u3042\u308b\u307f\u305f\u3044\u306a\u3093\u3067\u3059\u3051\u3069\u3001\u4eca\u306f\u30b3\u30ec\u3057\u304b\u51fa\u6765\u306a\u3044\u307f\u305f\u3044\u3067\u3059\u306d\u3002\u30dd\u30ea\u30b4\u30f3\u60c5\u5831\u306f\u30b3\u30ec\u3092\u4f7f\u3063\u3066\u5f8c\u306f\u81ea\u524d\u3067\u3069\u3046\u306b\u304b\u3059\u308b\u3057\u304b\u306a\u3044\u306e\u304b\u306a\u3068\u8003\u3048\u3066\u3044\u305f\u3093\u3067\u3059\u304c\u3001\u5ff5\u306e\u70ba\u30d7\u30e9\u30b0\u30a4\u30f3\u306a\u3044\u304b\u306a\u3068\u63a2\u3057\u3066\u307f\u305f\u3089django-geojson\u3068\u3044\u3046\u306e\u304c\u3042\u308b\u3058\u3083\u306a\u3044\u3067\u3059\u304b\u3002<\/p>\n<p><a href=\"https:\/\/pypi.python.org\/pypi\/django-geojson\" target=\"_blank\">django-geojson<\/a><\/p>\n<h2>django-geojson\u306e\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb<\/h2>\n<p>pip\u3067\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3002<\/p>\n<pre class=\"brush: bash; gutter: false; title: ; notranslate\" title=\"\">\r\n$ sudo pip install  django-geojson\r\nDownloading\/unpacking django-geojson\r\n  Downloading django-geojson-2.6.0.zip\r\n  Running setup.py (path:\/tmp\/pip_build_root\/django-geojson\/setup.py) egg_info for package django-geojson\r\n\r\nRequirement already satisfied (use --upgrade to upgrade): Django in \/usr\/local\/lib\/python2.7\/dist-packages (from django-geojson)\r\nRequirement already satisfied (use --upgrade to upgrade): six in \/usr\/lib\/python2.7\/dist-packages (from django-geojson)\r\nInstalling collected packages: django-geojson\r\n  Running setup.py install for django-geojson\r\n\r\nSuccessfully installed django-geojson\r\nCleaning up...\r\n<\/pre>\n<h2>django-geojson\u306e\u6709\u52b9\u5316<\/h2>\n<p>\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u8a2d\u5b9a\u3092\u7de8\u96c6\u3057\u3066\u30d7\u30e9\u30b0\u30a4\u30f3\u3092\u8ffd\u52a0\u3057\u307e\u3059\u3002<\/p>\n<pre class=\"brush: bash; gutter: false; title: ; notranslate\" title=\"\">\r\n$ vi geodjango\/settings.py\r\n<\/pre>\n<p>\u4ee5\u4e0b\u306e\u4e00\u884c\u3092INSTALLED_APPS\u306e\u672b\u5c3e\u306b\u8ffd\u52a0\u3057\u307e\u3059\u3002<\/p>\n<pre class=\"brush: python; gutter: false; title: ; notranslate\" title=\"\">\r\nINSTALLED_APPS = (\r\n    'django.contrib.gis', \r\n    'demo',               \r\n    'leaflet', \r\n    'djgeojson',\u3000# add\r\n)\r\n<\/pre>\n<p>\u3067\u306f\u3001\u8a66\u3057\u3066\u307f\u307e\u3057\u3087\u3046\u3002<\/p>\n<pre class=\"brush: bash; gutter: false; title: ; notranslate\" title=\"\">\r\n$ python manage.py shell\r\nPython 2.7.6 (default, Mar 22 2014, 22:59:56)\r\nType &quot;copyright&quot;, &quot;credits&quot; or &quot;license&quot; for more information.\r\n\r\nIPython 2.3.1 -- An enhanced Interactive Python.\r\n?         -&gt; Introduction and overview of IPython's features.\r\n%quickref -&gt; Quick reference.\r\nhelp      -&gt; Python's own help system.\r\nobject?   -&gt; Details about 'object', use 'object??' for extra details.\r\n\r\nIn &#x5B;1]: from demo.models import Border                                          \r\nIn &#x5B;2]: from djgeojson.serializers import Serializer as GeoJSONSerializer       \r\nIn &#x5B;3]: print(GeoJSONSerializer().serialize(Border.objects.filter(id=73274)))\r\n{&quot;crs&quot;: {&quot;type&quot;: &quot;link&quot;, &quot;properties&quot;: {&quot;href&quot;: &quot;http:\/\/spatialreference.org\/ref\/epsg\/4326\/&quot;, &quot;type&quot;: &quot;proj4&quot;}}, &quot;type&quot;: &quot;FeatureCollection&quot;, &quot;features&quot;: &#x5B;{&quot;geometry&quot;: {&quot;type&quot;: &quot;Polygon&quot;, &quot;coordinates&quot;: &#x5B;&#x5B;&#x5B;123.75450032600007, 24.063461431000064], &#x5B;123.75468432500007, 24.06348943100005], &#x5B;123.75469132500008, 24.063325431000067], &#x5B;123.75459232600008, 24.063291431000035], &#x5B;123.75450032600007, 24.063461431000064]]]}, &quot;type&quot;: &quot;Feature&quot;, &quot;properties&quot;: {&quot;n03_007&quot;: &quot;47381&quot;, &quot;n03_004&quot;: &quot;\\u7af9\\u5bcc\\u753a&quot;, &quot;n03_003&quot;: &quot;\\u516b\\u91cd\\u5c71\\u90e1&quot;, &quot;n03_002&quot;: &quot;&quot;, &quot;n03_001&quot;: &quot;\\u6c96\\u7e04\\u770c&quot;, &quot;model&quot;: &quot;demo.border&quot;}, &quot;id&quot;: 73274}]}\r\n\r\nIn &#x5B;4]:\r\n<\/pre>\n<p>\uff77\uff80\u2501(\uff9f\u2200\uff9f)\u2501!\u3000\u65e5\u672c\u8a9e\u304c\u6587\u5b57\u5316\u3051\u3057\u3066\u308b\u3051\u3069\u69cb\u9020\u306f\u554f\u984c\u306a\u3055\u305d\u3046\u306a\u306e\u3067\u30b3\u30ec\u3092\u4f7f\u3044\u307e\u3057\u3087\u3046\u3002<\/p>\n<h1>GeoDjango\u3067GeoJSON\u3092\u51fa\u529b\u3059\u308bWebAPI\u3092\u4f5c\u308b<\/h1>\n<p>\u305d\u308c\u3067\u306f\u3055\u3063\u305d\u304f\u3001\u30d6\u30e9\u30a6\u30b6\u5074\u306bGeoJSON\u3092\u8fd4\u3059WebAPI\u3092\u4f5c\u6210\u3057\u3066\u307f\u307e\u3057\u3087\u3046\u3002<\/p>\n<h2>\u30a2\u30d7\u30ea\u4f5c\u6210<\/h2>\n<p>demo\u306e\u307e\u307e\u3067\u3082\u3044\u3044\u3093\u3067\u3059\u304c\u3001\u6c17\u6301\u3061\u3092\u6539\u3081\u3066\u300capi\u300d\u3068\u3044\u3046\u540d\u524d\u3067\u30a2\u30d7\u30ea\u4f5c\u6210\u3057\u307e\u3059\u3002\u3059\u308b\u3068\u30a2\u30d7\u30ea\u540d\u306e\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u304c\u4f5c\u6210\u3055\u308c\u3001\u4f5c\u6210\u3057\u305f\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u914d\u4e0b\u306b\u6b21\u306e\u3088\u3046\u306a\u30d5\u30a1\u30a4\u30eb\u304c\u81ea\u52d5\u751f\u6210\u3055\u308c\u307e\u3059\u3002<\/p>\n<pre class=\"brush: bash; gutter: false; title: ; notranslate\" title=\"\">\r\n$ python manage.py startapp api\r\n<\/pre>\n<h2>URL\u30de\u30c3\u30d4\u30f3\u30b0\u3092\u5b9a\u7fa9<\/h2>\n<pre class=\"brush: bash; gutter: false; title: ; notranslate\" title=\"\">\r\nvi geodjango\/urls.py\r\n<\/pre>\n<pre class=\"brush: python; gutter: false; title: ; notranslate\" title=\"\">\r\nfrom django.conf.urls import patterns, include, url\r\nfrom django.contrib.gis import admin\r\nadmin.autodiscover()\r\n\r\nurlpatterns = patterns('',\r\n    url(r'^admin\/', include(admin.site.urls)),\r\n    url(r'^api\/', include('api.urls', namespace='api')), # add\r\n)\r\n<\/pre>\n<pre class=\"brush: bash; gutter: false; title: ; notranslate\" title=\"\">\r\nvi api\/urls.py\r\n<\/pre>\n<pre class=\"brush: python; gutter: false; title: ; notranslate\" title=\"\">\r\n# -*- coding: utf-8 -*-\r\nfrom django.conf.urls import patterns, url\r\nfrom djgeojson.views import GeoJSONLayerView\r\nfrom demo.models import Border\r\n\r\nurlpatterns = patterns('',\r\n    url(r'^v1\/borders.geojson$',GeoJSONLayerView.as_view(model=Border), name='borders'),\r\n)\r\n<\/pre>\n<p>\u306a\u304a\u3001\u901a\u5e38\u306fapi\/views.py\u306b\u95a2\u6570\u5b9a\u7fa9\u3059\u308b\u306e\u304c\u4e00\u822c\u7684\u306a\u3088\u3046\u3067\u3059\u304c\u3001\u4eca\u56de\u306fdjango-geojson\u306e\u30da\u30fc\u30b8\u306e\u30b5\u30f3\u30d7\u30eb\u306b\u5f93\u3044api\/urls.py\u3067GeoJSONLayerView\u3092\u76f4\u63a5\u547c\u3093\u3067\u3044\u307e\u3059\u3002\u3055\u3066\u3001\u3053\u308c\u3067\u300c\/api\/v1\/borders.geojson\u300d\u3078\u306e\u30a2\u30af\u30bb\u30b9\u3067<strong>\u5168\u767b\u9332\u30c7\u30fc\u30bf<\/strong>\u304cGeoJSON\u3067\u51fa\u529b\u3055\u308c\u308b\u3088\u3046\u306b\u306a\u308a\u307e\u3057\u305f\u3002<\/p>\n<h1>Django\u3067CORS\u3092\u7121\u52b9\u5316\u3059\u308b<\/h1>\n<p>Web-API\u306e\u30c6\u30b9\u30c8\u3067\u3044\u3064\u3082\u30cf\u30de\u308b\u306e\u304cCORS(Cross-Origin Resource Sharing)\u3067\u3059\u306d\u3002Django\u5074\u3067\u5168\u90e8\u914d\u7f6e\u3057\u3066\u304a\u3051\u3070\u89e3\u6c7a\u3059\u308b\u3093\u3067\u3057\u3087\u3046\u304c\u3001\u6700\u521d\u306e\u3046\u3061\u306f\u5206\u3051\u3066\u8a66\u3057\u304c\u3061\u3067\u3059\u3002\u3068\u308a\u3042\u3048\u305a\u4eca\u56de\u306f\u30d7\u30e9\u30b0\u30a4\u30f3\u3067\u56de\u907f\u3057\u307e\u3057\u3087\u3046\u3002<\/p>\n<h2>django-cors-headers\u306e\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb<\/h2>\n<p>pip\u3067\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3002<\/p>\n<pre class=\"brush: bash; gutter: false; title: ; notranslate\" title=\"\">\r\n$ sudo pip install django-cors-headers\r\nDownloading\/unpacking django-cors-headers\r\n  Downloading django-cors-headers-0.13.tar.gz\r\n  Running setup.py (path:\/tmp\/pip_build_root\/django-cors-headers\/setup.py) egg_info for package django-cors-headers\r\n\r\nInstalling collected packages: django-cors-headers\r\n  Running setup.py install for django-cors-headers\r\n\r\nSuccessfully installed django-cors-headers\r\nCleaning up...\r\n<\/pre>\n<h2>django-cors-headers\u306e\u6709\u52b9\u5316<\/h2>\n<p>\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u8a2d\u5b9a\u3092\u7de8\u96c6\u3057\u3066\u30d7\u30e9\u30b0\u30a4\u30f3\u3092\u8ffd\u52a0\u3057\u307e\u3059\u3002<\/p>\n<pre class=\"brush: bash; gutter: false; title: ; notranslate\" title=\"\">\r\n$ vi geodjango\/settings.py\r\n<\/pre>\n<pre class=\"brush: python; gutter: false; title: ; notranslate\" title=\"\">\r\nINSTALLED_APPS = (\r\n    'django.contrib.gis', \r\n    'demo',               \r\n    'leaflet', \r\n    'djgeojson',\r\n    'corsheaders',# add\r\n)\r\nMIDDLEWARE_CLASSES = (\r\n    'corsheaders.middleware.CorsMiddleware',     # add\r\n    'django.middleware.common.CommonMiddleware', # add\r\n)\r\nCORS_ORIGIN_ALLOW_ALL = True # add\r\n<\/pre>\n<p>\u3055\u3066\u3001\u3044\u3088\u3044\u3088\u3001\u30af\u30e9\u30a4\u30a2\u30f3\u30c8\u5074\u306e\u4f5c\u6210\u3067\u3059\u3002Django\u5074\u3067\u3084\u308b\u306e\u306f\u308f\u304b\u3089\u306a\u3044\u306e\u3067\u4eca\u56de\u306f\u5225\u306b\u4f5c\u308a\u307e\u3059\u3002<\/p>\n<h2>Leaflet\u3068jQuery\u306e\u30c0\u30a6\u30f3\u30ed\u30fc\u30c9<\/h2>\n<p>\u4ee5\u4e0b\u3001\u30b5\u30a4\u30c8\u304b\u3089Leaflet\u3068jQuery\u306e\u6700\u65b0\u7248\u3092\u30c0\u30a6\u30f3\u30ed\u30fc\u30c9\u3057\u3066\u4efb\u610f\u306e\u5834\u6240\u306b\u5c55\u958b\u3057\u307e\u3059\u3002<\/p>\n<p><a href=\"http:\/\/leafletjs.com\/\" target=\"_blank\">Leaflet<\/a><br \/>\n<a href=\"http:\/\/jquery.com\/\" target=\"_blank\">jQuery<\/a><\/p>\n<h2>\u521d\u3081\u3066\u306eLeaflet<\/h2>\n<p>\u30c0\u30a6\u30f3\u30ed\u30fc\u30c9\u3057\u305f\u30d5\u30a1\u30a4\u30eb\u3092\u3053\u3093\u306a\u5f62\u3067\u914d\u7f6e\u3057\u307e\u3059(\u304a\u597d\u307f\u3067\u3059\u304c)\u3002<\/p>\n<pre class=\"brush: bash; gutter: false; title: ; notranslate\" title=\"\">\r\n$ tree -c leaflet-demo\/\r\nleaflet-demo\/\r\n\u251c\u2500\u2500 index.html\r\n\u251c\u2500\u2500 js\r\n\u2502\u00a0\u00a0 \u251c\u2500\u2500 jquery-2.1.1.min.js\r\n\u2502\u00a0\u00a0 \u251c\u2500\u2500 leaflet.js\r\n\u2502\u00a0\u00a0 \u2514\u2500\u2500 leaflet-src.js\r\n\u251c\u2500\u2500 css\r\n\u2502\u00a0\u00a0 \u2514\u2500\u2500 leaflet.css\r\n\u2514\u2500\u2500 images\r\n    \u251c\u2500\u2500 layers-2x.png\r\n    \u251c\u2500\u2500 layers.png\r\n    \u251c\u2500\u2500 marker-icon-2x.png\r\n    \u251c\u2500\u2500 marker-icon.png\r\n    \u2514\u2500\u2500 marker-shadow.png\r\n<\/pre>\n<p>index.html\u3092\u3053\u3093\u306a\u5185\u5bb9\u3067\u66f8\u304d\u307e\u3057\u3087\u3046<\/p>\n<pre class=\"brush: xml; title: ; notranslate\" title=\"\">\r\n&lt;!DOCTYPE html&gt;\r\n&lt;html&gt;\r\n&lt;head lang=&quot;ja&quot;&gt;\r\n    &lt;meta charset=&quot;UTF-8&quot;&gt;\r\n    &lt;title&gt;Leaflet\u30c6\u30b9\u30c8&lt;\/title&gt;\r\n    &lt;meta name=&quot;viewport&quot; content=&quot;width=device-width, initial-scale=1.0&quot;&gt;\r\n    &lt;link rel=&quot;stylesheet&quot; href=&quot;css\/leaflet.css&quot; \/&gt;\r\n&lt;\/head&gt;\r\n&lt;body&gt;\r\n&lt;div id=&quot;map&quot; style=&quot;width: 960px; height: 600px&quot;&gt;&lt;\/div&gt;\r\n&lt;script src=&quot;js\/leaflet.js&quot;&gt;&lt;\/script&gt;\r\n&lt;script src=&quot;js\/jquery-2.1.1.min.js&quot;&gt;&lt;\/script&gt;\r\n&lt;script&gt;\r\n\r\n    var map = L.map('map');\r\n    L.tileLayer('https:\/\/{s}.tiles.mapbox.com\/v3\/{id}\/{z}\/{x}\/{y}.png', {\r\n        maxZoom: 30,\r\n        attribution: 'Map data &amp;copy; ' +\r\n        '&lt;a href=&quot;http:\/\/openstreetmap.org&quot;&gt;OpenStreetMap&lt;\/a&gt; contributors, ' +\r\n        '&lt;a href=&quot;http:\/\/creativecommons.org\/licenses\/by-sa\/2.0\/&quot;&gt;CC-BY-SA&lt;\/a&gt;, ' +\r\n        'Imagery \u00a9 &lt;a href=&quot;http:\/\/mapbox.com&quot;&gt;Mapbox&lt;\/a&gt;',\r\n        id: 'examples.map-i875mjb7'\r\n    }).addTo(map);\r\n    map.setView(&#x5B;35.85556, 139.65117], 15);\r\n&lt;\/script&gt;\r\n&lt;\/body&gt;\r\n&lt;\/html&gt;\r\n<\/pre>\n<p>\u305d\u308c\u3067\u306f\u30d6\u30e9\u30a6\u30b6\u3067\u958b\u3044\u3066\u307f\u307e\u3057\u3087\u3046\u3002<\/p>\n<p><a href=\"https:\/\/blog.bitmeister.jp\/wp-content\/uploads\/2014\/12\/Leaflet_1.png\" data-rel=\"lightbox-image-0\" data-rl_title=\"\" data-rl_caption=\"\" title=\"\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/blog.bitmeister.jp\/wp-content\/uploads\/2014\/12\/Leaflet_1-300x190.png\" alt=\"Leaflet_1\" width=\"300\" height=\"190\" class=\"alignnone size-medium wp-image-3519\" srcset=\"https:\/\/blog.bitmeister.jp\/wp-content\/uploads\/2014\/12\/Leaflet_1-300x190.png 300w, https:\/\/blog.bitmeister.jp\/wp-content\/uploads\/2014\/12\/Leaflet_1.png 986w\" sizes=\"auto, (max-width: 300px) 100vw, 300px\" \/><\/a><\/p>\n<p>\u306f\u3044\u3001\u5730\u56f3\u304c\u898b\u3048\u307e\u3059\u306d\u3002<\/p>\n<p>\u30d9\u30fc\u30b9\u306f\u3053\u308c\u3067OK\u3067\u3059\u306e\u3067\u3044\u3088\u3044\u3088\u3001GeoJSON\u3067\u30c7\u30fc\u30bf\u3092\u53d6\u5f97\u3057\u3066\u307f\u307e\u3057\u3087\u3046\u3002\u306a\u304a\u3001\u4e0b\u8a18\u30b3\u30fc\u30c9\u4e2d\u306e\u53d6\u5f97\u5148URL\u306eIP\u306f\u5404\u81ea\u306e\u74b0\u5883\u3067\u5909\u66f4\u3057\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n<pre class=\"brush: xml; title: ; notranslate\" title=\"\">\r\n&lt;!DOCTYPE html&gt;\r\n&lt;html&gt;\r\n&lt;head lang=&quot;ja&quot;&gt;\r\n    &lt;meta charset=&quot;UTF-8&quot;&gt;\r\n    &lt;title&gt;Leaflet\u30c6\u30b9\u30c8&lt;\/title&gt;\r\n    &lt;meta name=&quot;viewport&quot; content=&quot;width=device-width, initial-scale=1.0&quot;&gt;\r\n    &lt;link rel=&quot;stylesheet&quot; href=&quot;css\/leaflet.css&quot; \/&gt;\r\n&lt;\/head&gt;\r\n&lt;body&gt;\r\n&lt;div id=&quot;map&quot; style=&quot;width: 960px; height: 600px&quot;&gt;&lt;\/div&gt;\r\n&lt;script src=&quot;js\/leaflet.js&quot;&gt;&lt;\/script&gt;\r\n&lt;script src=&quot;js\/jquery-2.1.1.min.js&quot;&gt;&lt;\/script&gt;\r\n&lt;script&gt;\r\n\r\n    var map = L.map('map');\r\n    L.tileLayer('https:\/\/{s}.tiles.mapbox.com\/v3\/{id}\/{z}\/{x}\/{y}.png', {\r\n        maxZoom: 30,\r\n        attribution: 'Map data &amp;copy; ' +\r\n        '&lt;a href=&quot;http:\/\/openstreetmap.org&quot;&gt;OpenStreetMap&lt;\/a&gt; contributors, ' +\r\n        '&lt;a href=&quot;http:\/\/creativecommons.org\/licenses\/by-sa\/2.0\/&quot;&gt;CC-BY-SA&lt;\/a&gt;, ' +\r\n        'Imagery \u00a9 &lt;a href=&quot;http:\/\/mapbox.com&quot;&gt;Mapbox&lt;\/a&gt;',\r\n        id: 'examples.map-i875mjb7'\r\n    }).addTo(map);\r\n    map.setView(&#x5B;35.85556, 139.65117], 15);\r\n\r\n\u3000\u3000\u3000\/* GeoJSON\u30ec\u30a4\u30e4\u30fc\u3092\u8ffd\u52a0\u3057\u307e\u3059 *\/\r\n\u3000\u3000\u3000var layer = L.geoJson();\r\n\u3000\u3000\u3000map.addLayer(layer);\r\n\u3000\u3000\u3000$.getJSON(&quot;http:\/\/x.x.x.x:8000\/api\/v1\/borders.geojson&quot;, function (data) {\r\n   \u3000\u3000\u3000\u3000layer.addData(data);\r\n\u3000\u3000\u3000});\r\n&lt;\/script&gt;\r\n&lt;\/body&gt;\r\n&lt;\/html&gt;\r\n<\/pre>\n<p>\u305d\u308c\u3067\u306f\u30d6\u30e9\u30a6\u30b6\u3067\u958b\u3044\u3066\u307f\u307e\u3057\u3087\u3046\u3002\u3048\u3001\u3055\u3063\u304d\u3068\u5909\u308f\u3089\u306a\u3044\u3067\u3059\u3063\u3066\uff1f\u66ab\u304f\u304a\u5f85\u3061\u4e0b\u3055\u3044\u3002\u305d\u3046\u3067\u3059\u306d\u3001\u5927\u4f535\u5206\u4f4d\u3067\u3059\u304b\u306d\u3002\u30de\u30b7\u30f3\u304c\u60b2\u9cf4\u3092\u3042\u3052\u306a\u3051\u308c\u3070\u8868\u793a\u3055\u308c\u307e\u3059\u3002<\/p>\n<p><a href=\"https:\/\/blog.bitmeister.jp\/wp-content\/uploads\/2014\/12\/Leaflet_2.png\" data-rel=\"lightbox-image-1\" data-rl_title=\"\" data-rl_caption=\"\" title=\"\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/blog.bitmeister.jp\/wp-content\/uploads\/2014\/12\/Leaflet_2-300x193.png\" alt=\"Leaflet_2\" width=\"300\" height=\"193\" class=\"alignnone size-medium wp-image-3518\" srcset=\"https:\/\/blog.bitmeister.jp\/wp-content\/uploads\/2014\/12\/Leaflet_2-300x193.png 300w, https:\/\/blog.bitmeister.jp\/wp-content\/uploads\/2014\/12\/Leaflet_2.png 984w\" sizes=\"auto, (max-width: 300px) 100vw, 300px\" \/><\/a><\/p>\n<p>\u306f\u3044\uff77\uff80\u2501(\uff9f\u2200\uff9f)\u2501!\u3068\u3046\u3068\u3046\u3001\u3053\u3053\u307e\u3067\u6765\u307e\u3057\u305f\u3088\u3002\u3044\u3084\u30fc\u9577\u304b\u3063\u305f\u3002\u3082\u3046\u6ce3\u304d\u305f\u3044\u3002\u3048? \u306a\u3093\u3060\u304b\u91cd\u3044? \u305d\u308c\u306f\u8cb4\u65b9\u306ePC\u306e\u6027\u80fd\u304c\u60aa\u3044\u3093\u3058\u3083\u306a\u3044\u3067\u3059\u304b\u306d? \u6027\u80fd\u304c\u3044\u3044\u306e\u306b\u30e2\u30c3\u30b5\u30ea\u3057\u3066\u3044\u308b? \u305d\u308c\u306f\u3057\u3087\u3046\u304c\u306a\u3044\u3058\u3083\u306a\u3044\u3067\u3059\u304b\u3001\u5168\u4ef6\u30c7\u30fc\u30bf\u8fd4\u3059\u3093\u3067\u3059\u304b\u3089\u3002\u3060\u3063\u3066<strong>7\u4e07\u4ef6<\/strong>\u3042\u308a\u307e\u3059\u304b\u3089\u3002<br \/>\n\u3048? \u305d\u3093\u306a\u306e\u5b9f\u7528\u7684\u3058\u3083\u306a\u3044\u3067\u3059\u3063\u3066?\u3000\u3058\u3083\u3042Tile Layer\u306b\u3057\u3066\u307f\u3061\u3083\u3044\u307e\u3059\u304b? (\u3044\u3088\u3044\u3088\u6700\u7d42\u56de)<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u524d\u56de\u3067\u7ba1\u7406\u753b\u9762\u307e\u3067\u3067\u304d\u307e\u3057\u305f\u3002\u3088\u3046\u3084\u304f\u30e1\u30a4\u30f3\u3068\u306a\u308b\u30d6\u30e9\u30a6\u30b6\u5074\u3068\u9023\u643a\u3059\u308b\u3068\u3053\u308d\u3092\u5b9f\u88c5\u3057\u305f\u3044\u3068\u601d\u3044\u307e\u3059\u3002\u3068\u3053\u308d\u3067Django\u3067GeoJSON\u3063\u3066\u3069\u3046\u3084\u308b\u3093\u3060\u308d\u3046\u304b\u3002\u305d\u3093\u306a\u3068\u3053\u308d\u304b\u3089\u4eca\u56de\u306f\u59cb\u307e\u308a\u307e\u3059\u3002<\/p>\n","protected":false},"author":5,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[17],"tags":[109,80],"class_list":["post-3509","post","type-post","status-publish","format-standard","hentry","category-tech","tag-geo","tag-python"],"_links":{"self":[{"href":"https:\/\/blog.bitmeister.jp\/index.php?rest_route=\/wp\/v2\/posts\/3509","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/blog.bitmeister.jp\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/blog.bitmeister.jp\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/blog.bitmeister.jp\/index.php?rest_route=\/wp\/v2\/users\/5"}],"replies":[{"embeddable":true,"href":"https:\/\/blog.bitmeister.jp\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=3509"}],"version-history":[{"count":11,"href":"https:\/\/blog.bitmeister.jp\/index.php?rest_route=\/wp\/v2\/posts\/3509\/revisions"}],"predecessor-version":[{"id":3530,"href":"https:\/\/blog.bitmeister.jp\/index.php?rest_route=\/wp\/v2\/posts\/3509\/revisions\/3530"}],"wp:attachment":[{"href":"https:\/\/blog.bitmeister.jp\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=3509"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/blog.bitmeister.jp\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=3509"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/blog.bitmeister.jp\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=3509"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}