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

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