摘要:官網(wǎng)效果腳本地圖中心點昆明地圖縮放層級縮放禁止雙擊放大版權(quán)切片圖層地址繪制區(qū)域單擊移動清除雙擊移除事件保存方便后面刪除請入名稱鍵盤事件鍵拖動
leaflet官網(wǎng):http://leafletjs.com/
效果:
腳本:
var map = L.map("map", { center: [25.1026993454,102.9312515259], // 地圖中心點(昆明) zoom: 16, // 地圖縮放層級 zoomControl: false, // 縮放 doubleClickZoom: false, // 禁止雙擊放大 attributionControl: false // 版權(quán) }); var kmgLayer = L.tileLayer.wms("wms切片圖層地址", { layers: "airport:kmg", format: "image/jpeg", transparent: false }); map.addLayer(kmgLayer); // 繪制區(qū)域 var layerObj = {}; function drawPolygon() { var points = [], points_length = 0, polyline, polygon; // 單擊 var clickFlag, clickTimes = 1, isDrag = false; map.on("mousedown", function(e) { map.off("mousemove"); if(clickFlag) clearTimeout(clickFlag); clickFlag = setTimeout(function() { if(clickTimes==1 && !isDrag) { points.push([e.latlng.lat, e.latlng.lng]); points_length = points.length; // 移動 map.on("mousemove", function(e) { // 清除 if(polyline) map.removeLayer(polyline); if(polygon) map.removeLayer(polygon); // polyline points[points_length] = [e.latlng.lat, e.latlng.lng]; polyline = new L.Polyline(points); map.addLayer(polyline); // polygon polygon = new L.Polygon(points); map.addLayer(polygon); }); } }, 300); }); // 雙擊 map.on("dblclick", function() { if(points.length) { clickTimes = 2; // polyline polyline = new L.Polyline(points); map.addLayer(polyline); // polygon polygon = new L.Polygon(points); map.addLayer(polygon); // 移除事件 map.off("mousemove"); setTimeout(function() { clickTimes = 1; // 保存layer(方便后面刪除) var layerName = prompt("請入名稱"); if(layerName) { layerObj[layerName] = [polyline, polygon]; console.log(layerObj); } points = []; }, 300); } }); // 鍵盤事件 $(document).keyup(function(e) { if(e.keyCode == 27) {// esc鍵 if(points.length) { map.off("mousemove"); clickTimes = 1; map.removeLayer(polyline); map.removeLayer(polygon); points = []; } } }); // 拖動 map.on("movestart", function() { isDrag = true; }); map.on("moveend", function() { isDrag = false; }); } drawPolygon();
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/88286.html
摘要:實際中我們可能會用到不同的地圖,那么就對應到不同坐標系的轉(zhuǎn)換,比如說,你有一份的數(shù)據(jù)服務,你要展現(xiàn)在百度或者高德地圖上,這時候你就需要轉(zhuǎn)換了。 地圖坐標轉(zhuǎn)換 LBS,基于位置的服務(Location Based Service),近年來已經(jīng)無處不在,尤其是我們前端,相信或多或少都有接觸一些地圖API服務,比如高德、百度啊、谷歌啊~但是用的時候可能看到下面這些字眼:比如BD09、火星坐標...
入門 Leaflet 之小 Demo 寫在前面 ---- WebGIS 開發(fā)基礎之 Leaflet GIS 基本概念:GIS、Map、Layer、Feature、Geometry、Symbol、Data(Point、Polyline、Polygon)、Renderer、Scale、Project、Coordinates; GIS 開發(fā)概述:架構(gòu)模式、常用平臺和 SDK、二維三維 使用 Lea...
摘要:鼠標在地圖上拉框即可繪制相應的矩形。鼠標在地圖上單擊繪制量測區(qū)域,鼠標左鍵雙擊或右鍵單擊結(jié)束當前量測操作,并顯示本次量測結(jié)果。參數(shù)設為時,鼠標操作關閉的同時清除地圖上繪制的所有覆蓋物對象設為時,保留所繪制的覆蓋物對象。 高德地圖 Javascript API 入門(二) 鼠標工具插件 測量距離 JS map.plugin([AMap.MouseTool],function ()...
閱讀 1967·2021-11-22 15:29
閱讀 3266·2021-10-14 09:43
閱讀 1231·2021-10-08 10:22
閱讀 3354·2021-08-30 09:46
閱讀 1441·2019-08-30 15:55
閱讀 1936·2019-08-30 15:44
閱讀 859·2019-08-30 14:19
閱讀 1453·2019-08-30 13:13