Mapbox 自分で作ったマーカーを地図に表示させる
ふぅー Mapbox漬けな毎日を送っています。
Mapbox.jsからMapbox GL JSへの移行をやってます。
さて、Mapbox.js、つまり旧名?Leafletでは、素敵なマーカーがデフォルトでありましたね!
しかし、Mapbox GL JSから、素敵なマーカーはなくなりました(つД`)
代わりに、自分で作ってアップロードしないといけないのです。
しかも、色がコードで手早く変更できない!!!!( ゚Д゚)
世界って残酷…。
①
さて、まずはSVGのマーカーを作ります。
下記のサイトで、MAKI Iconsの素材をひょいひょいとやると、新しいアイコン素材ができます。
https://www.mapbox.com/maki-icons/editor/
こんな感じに設定すると、以前Mapbox.jsにあったLeafletのマーカーのようですね。
②
できたSVGのファイルを、Mapbox Studioにアップロードします。
これがわかりにくいポイントですね!
MapboxStudio マーカーを置く
でやってみたように、手順12の部分のように、①で作ったSVGのファイルをアップロードします。
③
これで、コードから呼び出せます。
ついでに、マーカーをクリックするとポップアップが出るようにしておきます。
<!DOCTYPE html> <html> <head> <meta charset='utf-8' /> <title></title> <meta name='viewport' content='initial-scale=1,maximum-scale=1,user-scalable=no' /> <script src='https://api.tiles.mapbox.com/mapbox-gl-js/v0.30.0/mapbox-gl.js'></script> <script src='https://api.mapbox.com/mapbox.js/v2.4.0/mapbox.js'></script> <link href='https://api.tiles.mapbox.com/mapbox-gl-js/v0.30.0/mapbox-gl.css' rel='stylesheet' /> <style> body { margin:0; padding:0; } #map { position:absolute; top:0; bottom:0; width:100%; } </style> </head> <body> <div id='map'></div> <script> mapboxgl.accessToken = 'pk.eyJ1Ijoib25saW5lY29uc3VsdGFudCIsImEiOiJ0NXNSdE1VIn0.48aKT-tYUwPSibdAXP_NAQ'; var map = new mapboxgl.Map({ container: 'map', style: 'mapbox://styles/onlineconsultant/ciy9s6wua002k2smu114nieuu', center: [139.632314, 35.45797], zoom: 13 }); map.on('style.load', function () { map.addSource("lunchspots", { "type": "geojson", "data": { "type": "FeatureCollection", "features": [{ "type": "Feature", "geometry": { "type": "Point", "coordinates": [139.632314, 35.45797] }, "properties": { "title": "Mapbox DC", "marker-symbol": "redcar" } }, { "type": "Feature", "geometry": { "type": "Point", "coordinates": [139.637147, 35.443327] }, "properties": { "title": "Mapbox SF",
“marker-symbol”: “redcar”,
"description": "うきー" } }] } }); map.addLayer({ "id": "lunchspots", "type": "symbol", "source": "lunchspots", "layout": { "icon-image": "{marker-symbol}-11", "text-field": "{title}", "text-font": ["Open Sans Semibold", "Arial Unicode MS Bold"], "text-offset": [0, 0.6], "text-anchor": "top" } }); }); map.on('click', function (e) { var features = map.queryRenderedFeatures(e.point, { layers: ['lunchspots'] }); if (!features.length) { return; } var feature = features[0]; // Populate the popup and set its coordinates // based on the feature found. var popup = new mapboxgl.Popup() .setLngLat(feature.geometry.coordinates) .setHTML(feature.properties.description) .addTo(map); }); </script> </body> </html>