チュートリアル6
提供: svg2wiki
(版間での差分)
細 (→geoJsonExample1.svg) |
(→geoJsonExample1.svg) |
||
49行: | 49行: | ||
</svg> | </svg> | ||
+ | </pre> | ||
+ | |||
+ | |||
+ | ==geoJsonExample1.html== | ||
+ | *geoJsonExample1.svgに紐付けられ、そのDOMをコントロールできるwebApp | ||
+ | *このアプリでは簡単なUIを持ち、いくつかのgeoJsonデータを選択できるようになっています。 | ||
+ | *svgMapGIStoolのdrawGeoJson関数を使用し、geoJsonをSVGMapコンテンツ(のDOM)への変換をしています。 | ||
+ | **なお、自力でgeoJsonをSVGMapコンテンツのDOMに変換することももちろん可能です。 | ||
+ | |||
+ | <pre> | ||
+ | <!doctype html> | ||
+ | <html> | ||
+ | <head> | ||
+ | <meta charset="utf-8"/> | ||
+ | <title>SVGMapのwebAppレイヤーで、geoJsonを描画するサンプル</title> | ||
+ | </head> | ||
+ | |||
+ | <style> | ||
+ | /* 奇数行のスタイル */ | ||
+ | table tr:nth-child(odd){ | ||
+ | background-color:#c0c0ff; | ||
+ | } | ||
+ | |||
+ | /* 偶数行のスタイル */ | ||
+ | table tr:nth-child(even){ | ||
+ | background-color:#e0e0e0; | ||
+ | } | ||
+ | </style> | ||
+ | |||
+ | <script> | ||
+ | var dataPaths = { | ||
+ | "A34b-180316.geojson":"世界遺産構成資産範囲ポリゴン(代表点)", | ||
+ | "A34a-180316.geojson":"世界遺産構成資産範囲ポリゴンデータ", | ||
+ | "A34d-180316.geojson":"世界遺産構成資産範囲ライン(代表点)", | ||
+ | "A34c-180316.geojson":"世界遺産構成資産範囲ラインデータ", | ||
+ | "A34e-180316.geojson":"世界遺産構成資産", | ||
+ | "A34f-180316.geojson":"世界遺産緩衝地帯ポリゴンデータ", | ||
+ | "A34g-180316.geojson":"世界遺産緩衝地帯ポリゴン(代表点)", | ||
+ | "C28-20_Airport.geojson":"空港データ空港", | ||
+ | "C28-20_AirportReferencePoint.geojson":"空港データ標点", | ||
+ | "C28-20_SurveyContent.geojson":"空港データ調査内容", | ||
+ | "C28-20_TerminalBuilding.geojson":"空港データターミナルビル", | ||
+ | "N02-20_RailroadSection.geojson":"鉄道データ鉄道", | ||
+ | "N02-20_Station.geojson":"鉄道データ駅" | ||
+ | }; | ||
+ | |||
+ | addEventListener("load", function(){ | ||
+ | buildDataSelect(); | ||
+ | changeData(); | ||
+ | }); | ||
+ | |||
+ | function changeData(){ | ||
+ | var path = dataSelect.options[dataSelect.selectedIndex].value; | ||
+ | loadAndDrawGeoJson(path); | ||
+ | } | ||
+ | |||
+ | async function loadAndDrawGeoJson(dataPath){ | ||
+ | var gjs = await loadJSON(dataPath); | ||
+ | var parentElm = svgImage.getElementById("mapContents"); | ||
+ | removeChildren(parentElm); | ||
+ | svgMapGIStool.drawGeoJson(gjs, layerID, "orange", 2, "orange", "p0", "poi", "", parentElm); | ||
+ | svgMap.refreshScreen(); | ||
+ | } | ||
+ | |||
+ | function buildDataSelect(){ | ||
+ | var first=true; | ||
+ | for ( var dataPath in dataPaths){ | ||
+ | dataSelect.insertAdjacentHTML('beforeend', '<option value="' + dataPath +'" >'+dataPaths[dataPath]+'</option>'); | ||
+ | } | ||
+ | } | ||
+ | |||
+ | async function loadJSON(url){ | ||
+ | var dt = getDateStr(new Date(),10); | ||
+ | var response = await fetch(url+"?time="+dt); // 常に最新のデータを得るには何かダミーのクエリパートを付けるBad Tips.. | ||
+ | // https://stackoverflow.com/questions/37204296/cache-invalidation-using-the-query-string-bad-practice | ||
+ | // https://stackoverflow.com/questions/9692665/cache-busting-via-params | ||
+ | var json = await response.json(); | ||
+ | return ( json ); | ||
+ | } | ||
+ | |||
+ | function getDateStr(dateData , tStep){ | ||
+ | var mind = tStep * Math.floor( dateData.getUTCMinutes() / tStep ) ; | ||
+ | var ans = dateData.getUTCFullYear()+ pad(dateData.getUTCMonth() + 1) + pad(dateData.getUTCDate()) + pad(dateData.getUTCHours()) + pad(mind); | ||
+ | return ( ans ); | ||
+ | } | ||
+ | function pad( inp ){ | ||
+ | return ( ("0"+inp).slice(-2)); | ||
+ | } | ||
+ | |||
+ | function removeChildren(element){ | ||
+ | while (element.firstChild) element.removeChild(element.firstChild); | ||
+ | } | ||
+ | |||
+ | </script> | ||
+ | <body> | ||
+ | <h3>area layer</h3> | ||
+ | <p>geoJsonの可視化</p> | ||
+ | <select id="dataSelect" onchange="changeData()"></select> | ||
+ | </body> | ||
+ | </html> | ||
</pre> | </pre> |
2022年2月4日 (金) 04:48時点における版
目次 |
チュートリアル6 WebApp Layer geoJSON
実際の動作は、こちらをクリック。
geojson1.html
Container.svg
- 特に変わったところはありません。GeoJsonを表示する主題レイヤと、背景地図(OpenStreetMap)を読み込んでいます。
<?xml version="1.0" encoding="UTF-8"?> <svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" viewBox="122.9800817, -45.398095, 21.97626, 21.0533039" > <globalCoordinateSystem srsName="http://purl.org/crs/84" transform="matrix(1,0,0,-1,0,0)" /> <!-- OpenStretMap背景地図を表示状態として読み込む --> <animation xlink:href="../tutorial5/dynamicOSM_r11.svg" x="-3000" y="-3000" width="6000" height="6000" title="Japan Coastline" class="basemap" visibility="visible"/> <!-- 各種GeoJsonデータ(Point Feature)を表示状態として読み込む --> <animation xlink:href="geoJsonExample1.svg" x="-3000" y="-3000" width="6000" height="6000" title="GeoJson Layer" class="poi clickable" visibility="visible" opacity="0.7"/> </svg>
geoJsonExample1.svg
- ドキュメントルート要素(svg要素)の、data-controller属性で、このレイヤーを操作するwebAppを指定しています。
data-controller="geoJsonExample1.html#exec=appearOnLayerLoad
exec=appearOnLayerLoad
は、レイヤが表示状態になるとwebAppのウィンドが出現する設定です。(詳しくはこちら)
<?xml version="1.0" encoding="UTF-8"?> <svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:go="http://purl.org/svgmap/profile" viewBox="12375.0 -4500.0 2250.0 2250.0" go:dataArea="12375.0 -4500.0 2250.0 2250.0" data-controller="geoJsonExample1.html#exec=appearOnLayerLoad" property="name,address,phone,url" > <defs> <g id="p0"> <circle cx="0" cy="0" r="10" fill="blue" stroke="none"/> </g> </defs> <globalCoordinateSystem srsName="http://purl.org/crs/84" transform="matrix(100.0,0.0,0.0,-100.0,0.0,0.0)" /> <g id="mapContents"></g> </svg>
geoJsonExample1.html
- geoJsonExample1.svgに紐付けられ、そのDOMをコントロールできるwebApp
- このアプリでは簡単なUIを持ち、いくつかのgeoJsonデータを選択できるようになっています。
- svgMapGIStoolのdrawGeoJson関数を使用し、geoJsonをSVGMapコンテンツ(のDOM)への変換をしています。
- なお、自力でgeoJsonをSVGMapコンテンツのDOMに変換することももちろん可能です。
<!doctype html> <html> <head> <meta charset="utf-8"/> <title>SVGMapのwebAppレイヤーで、geoJsonを描画するサンプル</title> </head> <style> /* 奇数行のスタイル */ table tr:nth-child(odd){ background-color:#c0c0ff; } /* 偶数行のスタイル */ table tr:nth-child(even){ background-color:#e0e0e0; } </style> <script> var dataPaths = { "A34b-180316.geojson":"世界遺産構成資産範囲ポリゴン(代表点)", "A34a-180316.geojson":"世界遺産構成資産範囲ポリゴンデータ", "A34d-180316.geojson":"世界遺産構成資産範囲ライン(代表点)", "A34c-180316.geojson":"世界遺産構成資産範囲ラインデータ", "A34e-180316.geojson":"世界遺産構成資産", "A34f-180316.geojson":"世界遺産緩衝地帯ポリゴンデータ", "A34g-180316.geojson":"世界遺産緩衝地帯ポリゴン(代表点)", "C28-20_Airport.geojson":"空港データ空港", "C28-20_AirportReferencePoint.geojson":"空港データ標点", "C28-20_SurveyContent.geojson":"空港データ調査内容", "C28-20_TerminalBuilding.geojson":"空港データターミナルビル", "N02-20_RailroadSection.geojson":"鉄道データ鉄道", "N02-20_Station.geojson":"鉄道データ駅" }; addEventListener("load", function(){ buildDataSelect(); changeData(); }); function changeData(){ var path = dataSelect.options[dataSelect.selectedIndex].value; loadAndDrawGeoJson(path); } async function loadAndDrawGeoJson(dataPath){ var gjs = await loadJSON(dataPath); var parentElm = svgImage.getElementById("mapContents"); removeChildren(parentElm); svgMapGIStool.drawGeoJson(gjs, layerID, "orange", 2, "orange", "p0", "poi", "", parentElm); svgMap.refreshScreen(); } function buildDataSelect(){ var first=true; for ( var dataPath in dataPaths){ dataSelect.insertAdjacentHTML('beforeend', '<option value="' + dataPath +'" >'+dataPaths[dataPath]+'</option>'); } } async function loadJSON(url){ var dt = getDateStr(new Date(),10); var response = await fetch(url+"?time="+dt); // 常に最新のデータを得るには何かダミーのクエリパートを付けるBad Tips.. // https://stackoverflow.com/questions/37204296/cache-invalidation-using-the-query-string-bad-practice // https://stackoverflow.com/questions/9692665/cache-busting-via-params var json = await response.json(); return ( json ); } function getDateStr(dateData , tStep){ var mind = tStep * Math.floor( dateData.getUTCMinutes() / tStep ) ; var ans = dateData.getUTCFullYear()+ pad(dateData.getUTCMonth() + 1) + pad(dateData.getUTCDate()) + pad(dateData.getUTCHours()) + pad(mind); return ( ans ); } function pad( inp ){ return ( ("0"+inp).slice(-2)); } function removeChildren(element){ while (element.firstChild) element.removeChild(element.firstChild); } </script> <body> <h3>area layer</h3> <p>geoJsonの可視化</p> <select id="dataSelect" onchange="changeData()"></select> </body> </html>