在下面介绍的功能中重复相同的操作。我想尽可能多地移动到物体上。一旦在对象中初始化正确的方法,也许可以直接从按钮开始?
HTML:
<div id="map" style="width: 500px; height: 400px;"></div>
<button onclick="drawPoly()">Draw This Poly</button>
<button onclick="newPoly()">Create New Poly</button>
<button onclick="restorePolys()">Restore Polys</button>
<button onclick="dropMarker()">Drop Marker</button>
JS:
var map;
var mapListener = null;
$(function() {
map = new google.maps.Map(document.getElementById('map'), {
center: new google.maps.LatLng(48.864715, 10.546875),
zoom: 4,
mapTypeId: google.maps.MapTypeId.ROADMAP
});
});
dropMarker = function() {
if ( !! mapListener) google.maps.event.removeListener(mapListener);
mapListener = google.maps.event.addListener(map, 'click', function(e) {
tools.createMarker(e.latLng);
});
}
drawPolyline = function() {
if ( !! mapListener) google.maps.event.removeListener(mapListener);
mapListener = google.maps.event.addListener(map, 'click', function(e) {
tools.addPoint(e.latLng);
});
}
newPolyline = function() {
if ( !! mapListener) google.maps.event.removeListener(mapListener);
tools.createPolyline();
mapListener = google.maps.event.addListener(map, 'click', function(e) {
tools.addPoint(e.latLng);
});
}
newPolygon = function() {
if ( !! mapListener) google.maps.event.removeListener(mapListener);
tools.createPolygon();
mapListener = google.maps.event.addListener(map, 'click', function(e) {
tools.addPoint(e.latLng);
});
}
var tools = {
polyMarkers: [],
polyLines: [],
polyLine: null,
// ...
// mapListener: null,
// tools: function(option) {
// if ( !! this.mapListener) google.maps.event.removeListener(this.mapListener);
// this.mapListener = google.maps.event.addListener(map, 'click', function(e) {
// option(e.latLng);
// });
// },
// and so on
编辑我得到了预期的功能,添加到工具中:
mapListener: null,
initFeature: function(type, aspect) {
if ( !! this.mapListener) google.maps.event.removeListener(this.mapListener);
if (aspect) this[aspect]();
this.mapListener = google.maps.event.addListener(map, 'click', function(e) {
tools[type](e.latLng);
});
},
称呼:
tools.initFeature(type, aspect);