Mapbox 自分で作ったマーカーを地図に表示させる

Javascript

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のマーカーのようですね。
red_icons.png


できた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>

コメントを残す

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です