チュートリアル14
提供: svg2wiki
目次 |
チュートリアル14 WebApp Layer geoJSON
動的にベクトルデータが生成・配信されているサービスをSVGMap.jsに結合します。ここではUSGS Hazards Programが配信している、世界の地震発生状況データ(GeoJSON版)を結合してみます。基本的にはチュートリアル6との違いはありません。
- 実際の動作は、こちらをクリック。
- ソースコードのディレクトリ
geojson1.html
- チュートリアル6と特に違いはありません。
Container.svg
- チュートリアル6と特に違いはありません。
geoJsonExample2.svg
- ドキュメントルート要素(svg要素)の、data-controller属性で、このレイヤーを操作するwebAppを指定しています。
data-controller="geoJsonExample1.html#exec=appearOnLayerLoadexec=appearOnLayerLoadは、レイヤが表示状態になるとwebAppのウィンドが出現する設定です。(詳しくはこちら)
- defs要素でマーカー(POIのアイコン)を定義しています
- マーカーの色はマグニチュードに応じて変化させるためここでは未定義にしてあります
<?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="geoJsonExample2.html#exec=appearOnLayerLoad" property="name,address,phone,url"> <defs> <g id="p0"> <circle cx="0" cy="0" r="10" 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を持ち、
dataPathsで設定した いくつかのgeoJsonデータを選択できるようになっています。 loadJSON(url): await fetchを使ってGeoJsonデータを非同期読み込み- SVGMap GISライブラリ(svgMapGIStool)の
drawGeoJson関数を使用し、geoJsonをSVGMapコンテンツ(のDOM)への変換をしています。- なお、自力でgeoJsonをSVGMapコンテンツのDOMに変換することももちろん可能ですが、チュートリアル6ではライブラリを使っています。
- 引数については解説書#drawGeoJsonを参照
<!doctype html>
<html>
<head>
<meta charset="utf-8"/>
<title>SVGMapのwebAppレイヤーで、geoJsonを描画するサンプル</title>
</head>
<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>