leaflet:popup
差分
このページの2つのバージョン間の差分を表示します。
| 両方とも前のリビジョン前のリビジョン次のリビジョン | 前のリビジョン | ||
| leaflet:popup [2018/09/11 11:24] – 管理者 | leaflet:popup [2018/09/11 11:29] (現在) – [備考] 管理者 | ||
|---|---|---|---|
| 行 1: | 行 1: | ||
| + | [[: | ||
| + | ====== Leaflet 外部からポップアップを開く ====== | ||
| + | Leaflet 1系を使用してマーカのポップアップを外部からオープンします。 | ||
| + | |||
| + | 注意:「Leaflet勉強のための試作プログラムなので間違っている可能性があります」「DokuWikiは個別にヘッダを編集できないので通常とは少し違う構造になっています」 | ||
| + | |||
| + | ===== デモ ===== | ||
| + | 地図下部のリンクをクリックするとポップアップが開きます。 | ||
| + | |||
| + | < | ||
| + | <div id=" | ||
| + | |||
| + | <p> | ||
| + | <a href="# | ||
| + | <a href="# | ||
| + | <a href="# | ||
| + | </p> | ||
| + | |||
| + | <script src=" | ||
| + | |||
| + | < | ||
| + | /* 外部CSSの読み込み用 */ | ||
| + | function cssLoad(cssFile){ | ||
| + | if(document.all){ | ||
| + | document.createStyleSheet(cssFile); | ||
| + | }else{ | ||
| + | var link = document.createElement(" | ||
| + | link.rel = " | ||
| + | link.href = cssFile; | ||
| + | link.type = " | ||
| + | document.getElementsByTagName(' | ||
| + | } | ||
| + | } | ||
| + | cssLoad(" | ||
| + | |||
| + | function addOnload(evtFunc){ | ||
| + | if(window.addEventListener) { | ||
| + | window.addEventListener(' | ||
| + | } else if(window.attachEvent){ //IE用 | ||
| + | window.attachEvent(' | ||
| + | } else { | ||
| + | // | ||
| + | } | ||
| + | } | ||
| + | |||
| + | var markers=[]; // | ||
| + | var mymap; | ||
| + | addOnload(function(){ | ||
| + | mymap = L.map(' | ||
| + | |||
| + | L.tileLayer(' | ||
| + | maxZoom: 18, | ||
| + | attribution: | ||
| + | }).addTo(mymap); | ||
| + | |||
| + | markers[0]=L.marker([35.6896, | ||
| + | markers[1]=L.marker([35.6050, | ||
| + | markers[2]=L.marker([35.8572, | ||
| + | |||
| + | mymap.setView([35.6896, | ||
| + | |||
| + | }); | ||
| + | |||
| + | // | ||
| + | function popupOn(id){ | ||
| + | //var latlng=markers[id].getLatLng(); | ||
| + | // | ||
| + | markers[id].openPopup(); | ||
| + | } | ||
| + | </ | ||
| + | </ | ||
| + | |||
| + | |||
| + | < | ||
| + | <script async src="// | ||
| + | <!-- respon_0 --> | ||
| + | <ins class=" | ||
| + | | ||
| + | | ||
| + | | ||
| + | | ||
| + | < | ||
| + | (adsbygoogle = window.adsbygoogle || []).push({}); | ||
| + | </ | ||
| + | </ | ||
| + | |||
| + | |||
| + | ---- | ||
| + | ===== ソースコード ===== | ||
| + | <code javascript> | ||
| + | <div id=" | ||
| + | |||
| + | |||
| + | <!-- 外部からポップアップを開くためのリンク --> | ||
| + | <p> | ||
| + | <a href="# | ||
| + | <a href="# | ||
| + | <a href="# | ||
| + | </p> | ||
| + | |||
| + | |||
| + | <script src=" | ||
| + | < | ||
| + | function cssLoad(cssFile){ | ||
| + | if(document.all){ | ||
| + | document.createStyleSheet(cssFile); | ||
| + | }else{ | ||
| + | var link = document.createElement(" | ||
| + | link.rel = " | ||
| + | link.href = cssFile; | ||
| + | link.type = " | ||
| + | document.getElementsByTagName(' | ||
| + | } | ||
| + | } | ||
| + | cssLoad(" | ||
| + | function addOnload(evtFunc){ | ||
| + | if(window.addEventListener) { | ||
| + | window.addEventListener(' | ||
| + | } else if(window.attachEvent){ //IE用 | ||
| + | window.attachEvent(' | ||
| + | } else { | ||
| + | // | ||
| + | } | ||
| + | } | ||
| + | |||
| + | |||
| + | // | ||
| + | var markers=[]; | ||
| + | |||
| + | |||
| + | var mymap; | ||
| + | addOnload(function(){ | ||
| + | mymap = L.map(' | ||
| + | L.tileLayer(' | ||
| + | maxZoom: 18, | ||
| + | attribution: | ||
| + | }).addTo(mymap); | ||
| + | |||
| + | |||
| + | // | ||
| + | markers[0]=L.marker([35.6896, | ||
| + | markers[1]=L.marker([35.6050, | ||
| + | markers[2]=L.marker([35.8572, | ||
| + | |||
| + | | ||
| + | mymap.setView([35.6896, | ||
| + | }); | ||
| + | |||
| + | |||
| + | // | ||
| + | function popupOn(id){ | ||
| + | markers[id].openPopup(); | ||
| + | } | ||
| + | |||
| + | |||
| + | </ | ||
| + | </ | ||
| + | |||
| + | ---- | ||
| + | ===== 備考 ===== | ||
| + | 基本的な部分は[[leaflet: | ||
| + | |||
| + | マーカー情報をマップ外から使用するためのグローバル変数を用意。 | ||
| + | <code javascript> | ||
| + | var markers=[]; | ||
| + | </ | ||
| + | |||
| + | マーカーの設定を上記で準備したグローバル変数に登録。 | ||
| + | <code javascript> | ||
| + | markers[0]=L.marker([35.6896, | ||
| + | markers[1]=L.marker([35.6050, | ||
| + | markers[2]=L.marker([35.8572, | ||
| + | </ | ||
| + | |||
| + | マップ外からポップアップを開くためのJavaScript関数。'' | ||
| + | <code javascript> | ||
| + | function popupOn(id){ | ||
| + | markers[id].openPopup(); | ||
| + | } | ||
| + | </ | ||
| + | |||
| + | HTMLにポップアップを開くためのリンクを設置。popupOn()の数字はmarkers[]の配列番号と連動しています。 | ||
| + | <code html> | ||
| + | <a href="# | ||
| + | <a href="# | ||
| + | <a href="# | ||
| + | </ | ||
| + | |||
| + | |||
| + | < | ||
| + | <script async src="// | ||
| + | <!-- respon_0 --> | ||
| + | <ins class=" | ||
| + | | ||
| + | | ||
| + | | ||
| + | | ||
| + | < | ||
| + | (adsbygoogle = window.adsbygoogle || []).push({}); | ||
| + | </ | ||
| + | </ | ||
| + | |||
| + | |||
| + | ---- | ||
| + | ===== おまけ ===== | ||
| + | マーカーをセンターに表示したい場合はfunction popupOn()を下記のようにします。(注意:マップが小さくポップアップが画面外にはみ出る場合はpanToとopenPopupの順番が動作に影響します。下記の順番ではポップアップが画面外に出てもマーカーがセンターに来ます。逆にpanTo→openPopupの順にするとポップアップが表示領域にできるだけ収まるように表示されます) | ||
| + | <code javascript> | ||
| + | function popupOn(id){ | ||
| + | var latlng=markers[id].getLatLng(); | ||
| + | |||
| + | markers[id].openPopup(); | ||
| + | // | ||
| + | mymap.panTo(latlng); | ||
| + | } | ||
| + | </ | ||
| + | |||
| + | |||
