OpenStreetMapを使用する上で、Leafletがとても扱いやすかったため、
簡単に使い方をまとめておきます。
Leafletとは
https://leafletjs.com/
Web地図のJavaScriptライブラリです。
簡単にWeb地図を表示することができます。
公式ドキュメントが丁寧で読み易いです。
地図を表示する
data:image/s3,"s3://crabby-images/86f84/86f8492c76f4970f7e5ae583758537b60a20188f" alt="地図表示"
map_display.html
<!doctype html>
<html lang="ja">
<head>
<meta charset="utf-8">
<title>地図表示</title>
<link rel="stylesheet" href="http://cdn.leafletjs.com/leaflet-0.7.3/leaflet.css" />
<script src="http://cdn.leafletjs.com/leaflet-0.7.3/leaflet.js"></script>
<script src="http://code.jquery.com/jquery-latest.js"></script>
<script type="text/javascript" src=“map_display.js"></script>
<link rel="stylesheet" type="text/css" href="common.css">
</head>
<body>
<div class="container">
<div id="map"></div>
</div>
</body>
common.css
#map {
width: 500px;
height: 500px;
}
map_display.js
var map = L.map('map').setView([36.575,135.984], 5); // 日本を中心に設定
var tileLayer = L.tileLayer('https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png',{
attribution: '© <a href="http://osm.org/copyright">OpenStreetMap</a> contributors, <a href="http://creativecommons.org/licenses/by-sa/2.0/">CC-BY-SA</a>',
maxZoom: 19
});
tileLayer.addTo(map);
マーカーを表示する
data:image/s3,"s3://crabby-images/5efa7/5efa7f1a926e602f9d9e6dec0c0d2760c88e6e5f" alt="マーカー表示"
map_display.js
var map = L.map('map').setView([36.575,135.984], 5); // 日本を中心に設定
var tileLayer = L.tileLayer('https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png',{
attribution: '© <a href="http://osm.org/copyright">OpenStreetMap</a> contributors, <a href="http://creativecommons.org/licenses/by-sa/2.0/">CC-BY-SA</a>',
maxZoom: 19
});
tileLayer.addTo(map);
// 追加部分
L.marker([35.69, 139.69]).addTo(map); // 東京の緯度,経度を指定してマーカーを立てる
また、GeoJSON形式でマーカーを設定することもできます。
単にマーカーを立てるだけなら上の手法の方が楽ですが、
この後紹介するポップアップ機能などを付けたい時にはこちらの方が便利です。
map_display.js
// ここから
var map = L.map('map').setView([36.575,135.984], 5); // 日本を中心に設定
var tileLayer = L.tileLayer('https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png',{
attribution: '© <a href="http://osm.org/copyright">OpenStreetMap</a> contributors, <a href="http://creativecommons.org/licenses/by-sa/2.0/">CC-BY-SA</a>',
maxZoom: 19
});
tileLayer.addTo(map);
// ここまで変更無し
// GeoJSON形式でマーカーを設定する
var geojsonFeature = [{
"type": "Feature",
"geometry": {
"type": "Point",
"coordinates": [139.69, 35.69] // 経度,緯度の順になるので注意!
}
}];
// GeoJSON形式のマーカーをマップに追加する
L.geoJson(geojsonFeature).addTo(map);
マーカーにポップアップを付ける
data:image/s3,"s3://crabby-images/76985/769858e1f2339a52f36aabb6d41fde22568a36f2" alt="ポップアップ設定"
map_display.js
var map = L.map('map').setView([36.575,135.984], 5); // 日本を中心に設定
var tileLayer = L.tileLayer('https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png',{
attribution: '© <a href="http://osm.org/copyright">OpenStreetMap</a> contributors, <a href="http://creativecommons.org/licenses/by-sa/2.0/">CC-BY-SA</a>',
maxZoom: 19
});
tileLayer.addTo(map);
// GeoJSON形式でマーカーを設定する
var geojsonFeature = [{
"type": "Feature",
"geometry": {
"type": "Point",
"coordinates": [139.69, 35.69]
},
"properties": { // ポップアップを設定
"popupContent": "東京" // ポップアップで表示する内容
}
}];
// クリックしたらポップアップが出るように設定する
L.geoJson(geojsonFeature,
{
onEachFeature: function(feature, layer){
if (feature.properties && feature.properties.popupContent) {
layer.bindPopup(feature.properties.popupContent);
}
}
}).addTo(map);
マーカーを複数個設定する
data:image/s3,"s3://crabby-images/5b4d5/5b4d592067082965b09935dd4840c47a8c61863c" alt="複数個マーカー"
map_display.js
var map = L.map('map').setView([36.575,135.984], 5); // 日本を中心に設定
var geojsonFeature = []; // マーカー情報を格納する配列
var popupContents = ["東京", "大阪", "札幌", "那覇"]; // ポップアップで表示する内容
var lat = [35.69, 34.69, 43.06, 26.2125]; // 緯度
var lon = [139.69, 135.5, 141.35, 127.6811]; // 経度
var tileLayer = L.tileLayer('https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png',{
attribution: '© <a href="http://osm.org/copyright">OpenStreetMap</a> contributors, <a href="http://creativecommons.org/licenses/by-sa/2.0/">CC-BY-SA</a>',
maxZoom: 19
});
tileLayer.addTo(map);
// GeoJSON形式で複数個のマーカーを設定する
for (var i = 0; i < 4; i++){
geojsonFeature.push({ // 1つのマーカーの情報を格納する
"type": "Feature",
"properties": {
"popupContent": popupContents[i]
},
"geometry": {
"type": "Point",
"coordinates": [lon[i], lat[i]]
}
});
}
// クリックしたらポップアップが出るように設定する
L.geoJson(geojsonFeature,
{
onEachFeature: function(feature, layer){
if (feature.properties && feature.properties.popupContent) {
layer.bindPopup(feature.properties.popupContent);
}
}
}).addTo(map);
オリジナル画像のマーカーを出してみる
data:image/s3,"s3://crabby-images/fadcf/fadcf076fd47338bbbaca5ce1a065c7ca875b557" alt="オリジナル画像マーカー"
map_display.js
var map = L.map('map').setView([36.575,135.984], 5); // 日本を中心に設定
var geojsonFeature = []; // マーカー情報を格納する配列
var popupContents = ["東京", "大阪", "札幌", "那覇"]; // ポップアップで表示する内容
var lat = [35.69, 34.69, 43.06, 26.2125]; // 緯度
var lon = [139.69, 135.5, 141.35, 127.6811]; // 経度
var tileLayer = L.tileLayer('https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png',{
attribution: '© <a href="http://osm.org/copyright">OpenStreetMap</a> contributors, <a href="http://creativecommons.org/licenses/by-sa/2.0/">CC-BY-SA</a>',
maxZoom: 19
});
tileLayer.addTo(map);
// GeoJSON形式で複数個のマーカーを設定する
for (var i = 0; i < 4; i++){
geojsonFeature.push({ // 1つのマーカーの情報を格納する
"type": "Feature",
"properties": {
"popupContent": popupContents[i]
},
"geometry": {
"type": "Point",
"coordinates": [lon[i], lat[i]]
}
});
}
// クリックしたらポップアップが出るように設定する
L.geoJson(geojsonFeature,
{
onEachFeature: function(feature, layer){
if (feature.properties && feature.properties.popupContent) {
layer.bindPopup(feature.properties.popupContent);
}
},
// オリジナル画像を設定する
pointToLayer: function(feature, latlng){
var myIcon = L.icon({
iconUrl: 'marker-red.png', // 画像のURI
iconSize: [25, 41], // 画像のサイズ設定
iconAnchor: [12, 40], // 画像の位置設定
popupAnchor: [0, -40] // ポップアップの表示を開始する位置設定
});
return L.marker(latlng, {icon: myIcon}); // マーカーに画像情報を設定
}
}
}).addTo(map);
まとめ
簡単な概要はこの程度ですが、工夫すると、ポップアップに表示する内容をDBから取得して、動的にマーカーを必要な分だけ生成したりすることもできます。
仕組みが簡単なので、自由度が高くて使い易いです。