[英]Google Maps Draw — draw line or polygon by dragging
目前,您可以通過單擊來創建節點,從而在地圖上繪制多邊形或折線。 但是,如果您想要遵循河流或海岸線等功能,這可能既乏味又無懈可擊。
有沒有人知道可以通過單擊拖動鼠標,或單擊開始,然后拖動路徑,然后單擊停止來繪制路徑的方法?
我看過DrawingManager和MouseEvent,但我還沒有看到任何有希望的東西。
有沒有辦法根據click和mouseMove等事件連接繪圖?
這將允許更准確和快速的功能。
工作流程:
onmousedown
在地圖上設置的draggable
地圖上的-選項false
,創建一個Polyline
-instance並設置clickable
的的-選項Polyline
到false
觀察地圖的mousemove
-event,每次發生時將返回的LatLng
推送到Polyline
的路徑
onmouseup
刪除地圖的mousemove
-listener,並將地圖的draggable
-option設置為true
。 您的Polyline
已經完成
當您不想創建Polygon
,現在創建一個Polygon
-instance,將Polygon
的路徑設置為Polyline
的路徑並刪除Polyline
<edit>
:建議僅使用按下的鼠標按鈕進行繪制,否則地圖永遠不會被拖動。
演示: http : //jsfiddle.net/doktormolle/YsQdh/
代碼片段:(來自鏈接的jsfiddle)
function initialize() { var mapOptions = { zoom: 14, center: new google.maps.LatLng(52.5498783, 13.425209099999961), mapTypeId: google.maps.MapTypeId.ROADMAP }; map = new google.maps.Map(document.getElementById('map_canvas'), mapOptions); google.maps.event.addDomListener(map.getDiv(), 'mousedown', function(e) { //do it with the right mouse-button only if (e.button != 2) return; //the polygon poly = new google.maps.Polyline({ map: map, clickable: false }); //move-listener var move = google.maps.event.addListener(map, 'mousemove', function(e) { poly.getPath().push(e.latLng); }); //mouseup-listener google.maps.event.addListenerOnce(map, 'mouseup', function(e) { google.maps.event.removeListener(move); if (document.getElementById('overlay').value == 'Polygon') { var path = poly.getPath(); poly.setMap(null); poly = new google.maps.Polygon({ map: map, path: path }); } }); }); } google.maps.event.addDomListener(window, 'load', initialize);
html, body { height: 100%; margin: 0 } #map_canvas { height: 90%; }
<script src="https://maps.googleapis.com/maps/api/js"></script> Use the right mouse-button to draw an overlay <br/> <select id="overlay"> <option value="Polyline">Polyline</option> <option value="Polygon">Polygon</option> </select> <div id="map_canvas"></div>
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.