이번 포스팅에서는 Leaflet Draw 라이브러리를 사용해보겠습니다.
https://leaflet.github.io/Leaflet.draw/docs/examples/full.html
해당 사이트에 있는 리소스 파일이랑 소스를 설정합니다.
소스코드
<%@ page contentType="text/html; charset=utf-8" pageEncoding="utf-8" %>
<body>
<main role="main" class="inner cover">
<h1 class="cover-heading">LeafletJs Tutorial</h1>
<!-- <p class="lead">- openstreetmap</p> -->
<!-- <div id="map"></div> -->
<!-- <br> -->
<p class="lead">leaflet draw 예제</p>
<div id="map"></div>
</main>
</body>
<script>
let lon = "";
let lat = "";
let leafletMap = "";
let startMarker = "";
let finishMarker = "";
let contextMenuFlag = true;
let drawControl = "";
//apikey
const apiKey = $("#apiKey").val();
$(function(){
init();
});
function init(){
navigator.geolocation.getCurrentPosition(onGeoOk,onGeoError);
}
//현재 좌표값 가져오기
function onGeoOk(position){
lon = position.coords.latitude;
lat = position.coords.longitude;
console.log("You live in", lon, lat);
//wmts 가져오기
vworldWmts();
}
function onGeoError(){
alert("Can't find you. No weather for you.");
}
function vworldWmts(){
//leaflet 지도 띄우기 (EPSG : 4326)
leafletMap = L.map('map').setView([lon, lat], 15)
L.tileLayer("http://api.vworld.kr/req/wmts/1.0.0/"+apiKey+"/Base/{z}/{y}/{x}.png").addTo(leafletMap);
//해당 플래그가 true일때만 동작
//맵에 오른쪽마우스 클릭이벤트
leafletMap.on('contextmenu', rightMouseClick);
//layer 변경
changeLayer(leafletMap)
//leaflet 그리기
initLeafletDraw(leafletMap)
}
//layer 변경
function changeLayer(leafletMap){
vworld = L.tileLayer("http://api.vworld.kr/req/wmts/1.0.0/"+apiKey+"/Base/{z}/{y}/{x}.png", { maxZoom: 18}),
drawnItems = L.featureGroup().addTo(leafletMap);
//레이어 변경
L.control.layers({
'vworld' : vworld.addTo(leafletMap),
'osm': L.tileLayer("http://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png", {
attribution: 'osm'
}),
'google': L.tileLayer('http://www.google.cn/maps/vt?lyrs=s@189&gl=cn&x={x}&y={y}&z={z}', {
attribution: 'google'
})
}, { 'drawlayer': drawnItems }, { position: 'topleft', collapsed: false }).addTo(leafletMap);
}
//leaflet 그리기
function initLeafletDraw(leafletMap){
drawControl = new L.Control.Draw({
edit : false,
// edit: {
// featureGroup: drawnItems,
// poly: {
// allowIntersection: false,
// remove: false
// }
// },
draw: {
polygon: {
allowIntersection: false,
showArea: true
}
}
});
leafletMap.addControl(drawControl);
leafletMap.on(L.Draw.Event.CREATED, function (event) {
var layer = event.layer;
drawnItems.addLayer(layer);
});
}
//오른쪽 마우스 클릭
function rightMouseClick(e) {
const lon = e.latlng.lat;
const lat = e.latlng.lng;
const popDiv = "<div class='list-group'><a style='text-align: center;' href='javascript:void(0);' onclick='startBtnClicked("+lon+", "+lat+")' class='list-group-item list-group-item-action'>출발</a><a style='text-align: center;' href='javascript:void(0);' onclick='finishBtnClicked("+lon+", "+lat+")' class='list-group-item list-group-item-action'>도착</a></div>";
console.log("팝업 lon : " + lon, "lat : " + lat)
//contextMenuFlag가 true일때만 팝업 show
if(contextMenuFlag){
//오른쪽마우스 클릭이벤트
const popup = L.popup()
.setLatLng([lon, lat])
.setContent(popDiv)
.openOn(leafletMap);
}
}
//출발버튼 클릭
function startBtnClicked(lon, lat){
if(startMarker != ""){
startMarker.remove();
}
leafletMap.closePopup();
const startIcon = L.icon({
iconUrl: '/images/start-marker.png',
iconSize: [30, 30], // size of the icon
});
startMarker = new L.marker([lon, lat], {
draggable: true,
autoPan: false,
icon: startIcon
});
startMarker.addTo(leafletMap);
//마커 마우스 이벤트
markerMouseEvent(startMarker);
}
//도착버튼 클릭
function finishBtnClicked(lon, lat){
if(finishMarker != ""){
finishMarker.remove();
}
leafletMap.closePopup();
const finishIcon = L.icon({
iconUrl: '/images/finish-marker.png',
iconSize: [30, 30], // size of the icon
});
finishMarker = new L.marker([lon, lat], {
draggable: true,
autoPan: false,
icon: finishIcon
});
finishMarker.addTo(leafletMap);
//마커 마우스 이벤트
markerMouseEvent(finishMarker);
}
//마커 마우스 이벤트
function markerMouseEvent(marker){
marker.on('mouseover', function (e) {
marker.bindTooltip("끌어서 이동", {direction: 'top',noWrap: true, opacity: 0.9}).openTooltip();
//class명 추가
// marker._icon.classList.add("btn__close");
});
marker.on('mouseout', function (e) {
// marker._icon.classList.remove("btn__close");
});
marker.on('click', function (e) {
marker.remove();
});
}
</script>
'LeafletJs' 카테고리의 다른 글
[LeafletJs] Leaflet Draw Polygon 면적 재기 (0) | 2023.01.05 |
---|---|
[LeafletJs] Leaflet Draw Poly line 거리 측정 (0) | 2023.01.05 |
[leafletjs] 배경지도 레이어 변경 (0) | 2023.01.05 |
[leafletjs] wmts 배경지도에 오른쪽 마우스 클릭시 출발 도착 marker 찍기 (0) | 2023.01.03 |
[leafletjs] vworld wmts 배경지도 내위치 띄우기 (0) | 2023.01.03 |