206 lines
		
	
	
		
			5.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
			
		
		
	
	
			206 lines
		
	
	
		
			5.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
| GMaps.prototype.drawPolyline = function(options) {
 | |
|   var path = [],
 | |
|       points = options.path;
 | |
| 
 | |
|   if (points.length) {
 | |
|     if (points[0][0] === undefined) {
 | |
|       path = points;
 | |
|     }
 | |
|     else {
 | |
|       for (var i = 0, latlng; latlng = points[i]; i++) {
 | |
|         path.push(new google.maps.LatLng(latlng[0], latlng[1]));
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   var polyline_options = {
 | |
|     map: this.map,
 | |
|     path: path,
 | |
|     strokeColor: options.strokeColor,
 | |
|     strokeOpacity: options.strokeOpacity,
 | |
|     strokeWeight: options.strokeWeight,
 | |
|     geodesic: options.geodesic,
 | |
|     clickable: true,
 | |
|     editable: false,
 | |
|     visible: true
 | |
|   };
 | |
| 
 | |
|   if (options.hasOwnProperty("clickable")) {
 | |
|     polyline_options.clickable = options.clickable;
 | |
|   }
 | |
| 
 | |
|   if (options.hasOwnProperty("editable")) {
 | |
|     polyline_options.editable = options.editable;
 | |
|   }
 | |
| 
 | |
|   if (options.hasOwnProperty("icons")) {
 | |
|     polyline_options.icons = options.icons;
 | |
|   }
 | |
| 
 | |
|   if (options.hasOwnProperty("zIndex")) {
 | |
|     polyline_options.zIndex = options.zIndex;
 | |
|   }
 | |
| 
 | |
|   var polyline = new google.maps.Polyline(polyline_options);
 | |
| 
 | |
|   var polyline_events = ['click', 'dblclick', 'mousedown', 'mousemove', 'mouseout', 'mouseover', 'mouseup', 'rightclick'];
 | |
| 
 | |
|   for (var ev = 0; ev < polyline_events.length; ev++) {
 | |
|     (function(object, name) {
 | |
|       if (options[name]) {
 | |
|         google.maps.event.addListener(object, name, function(e){
 | |
|           options[name].apply(this, [e]);
 | |
|         });
 | |
|       }
 | |
|     })(polyline, polyline_events[ev]);
 | |
|   }
 | |
| 
 | |
|   this.polylines.push(polyline);
 | |
| 
 | |
|   GMaps.fire('polyline_added', polyline, this);
 | |
| 
 | |
|   return polyline;
 | |
| };
 | |
| 
 | |
| GMaps.prototype.removePolyline = function(polyline) {
 | |
|   for (var i = 0; i < this.polylines.length; i++) {
 | |
|     if (this.polylines[i] === polyline) {
 | |
|       this.polylines[i].setMap(null);
 | |
|       this.polylines.splice(i, 1);
 | |
| 
 | |
|       GMaps.fire('polyline_removed', polyline, this);
 | |
| 
 | |
|       break;
 | |
|     }
 | |
|   }
 | |
| };
 | |
| 
 | |
| GMaps.prototype.removePolylines = function() {
 | |
|   for (var i = 0, item; item = this.polylines[i]; i++) {
 | |
|     item.setMap(null);
 | |
|   }
 | |
| 
 | |
|   this.polylines = [];
 | |
| };
 | |
| 
 | |
| GMaps.prototype.drawCircle = function(options) {
 | |
|   options =  extend_object({
 | |
|     map: this.map,
 | |
|     center: new google.maps.LatLng(options.lat, options.lng)
 | |
|   }, options);
 | |
| 
 | |
|   delete options.lat;
 | |
|   delete options.lng;
 | |
| 
 | |
|   var polygon = new google.maps.Circle(options),
 | |
|       polygon_events = ['click', 'dblclick', 'mousedown', 'mousemove', 'mouseout', 'mouseover', 'mouseup', 'rightclick'];
 | |
| 
 | |
|   for (var ev = 0; ev < polygon_events.length; ev++) {
 | |
|     (function(object, name) {
 | |
|       if (options[name]) {
 | |
|         google.maps.event.addListener(object, name, function(e){
 | |
|           options[name].apply(this, [e]);
 | |
|         });
 | |
|       }
 | |
|     })(polygon, polygon_events[ev]);
 | |
|   }
 | |
| 
 | |
|   this.polygons.push(polygon);
 | |
| 
 | |
|   return polygon;
 | |
| };
 | |
| 
 | |
| GMaps.prototype.drawRectangle = function(options) {
 | |
|   options = extend_object({
 | |
|     map: this.map
 | |
|   }, options);
 | |
| 
 | |
|   var latLngBounds = new google.maps.LatLngBounds(
 | |
|     new google.maps.LatLng(options.bounds[0][0], options.bounds[0][1]),
 | |
|     new google.maps.LatLng(options.bounds[1][0], options.bounds[1][1])
 | |
|   );
 | |
| 
 | |
|   options.bounds = latLngBounds;
 | |
| 
 | |
|   var polygon = new google.maps.Rectangle(options),
 | |
|       polygon_events = ['click', 'dblclick', 'mousedown', 'mousemove', 'mouseout', 'mouseover', 'mouseup', 'rightclick'];
 | |
| 
 | |
|   for (var ev = 0; ev < polygon_events.length; ev++) {
 | |
|     (function(object, name) {
 | |
|       if (options[name]) {
 | |
|         google.maps.event.addListener(object, name, function(e){
 | |
|           options[name].apply(this, [e]);
 | |
|         });
 | |
|       }
 | |
|     })(polygon, polygon_events[ev]);
 | |
|   }
 | |
| 
 | |
|   this.polygons.push(polygon);
 | |
| 
 | |
|   return polygon;
 | |
| };
 | |
| 
 | |
| GMaps.prototype.drawPolygon = function(options) {
 | |
|   var useGeoJSON = false;
 | |
| 
 | |
|   if(options.hasOwnProperty("useGeoJSON")) {
 | |
|     useGeoJSON = options.useGeoJSON;
 | |
|   }
 | |
| 
 | |
|   delete options.useGeoJSON;
 | |
| 
 | |
|   options = extend_object({
 | |
|     map: this.map
 | |
|   }, options);
 | |
| 
 | |
|   if (useGeoJSON == false) {
 | |
|     options.paths = [options.paths.slice(0)];
 | |
|   }
 | |
| 
 | |
|   if (options.paths.length > 0) {
 | |
|     if (options.paths[0].length > 0) {
 | |
|       options.paths = array_flat(array_map(options.paths, arrayToLatLng, useGeoJSON));
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   var polygon = new google.maps.Polygon(options),
 | |
|       polygon_events = ['click', 'dblclick', 'mousedown', 'mousemove', 'mouseout', 'mouseover', 'mouseup', 'rightclick'];
 | |
| 
 | |
|   for (var ev = 0; ev < polygon_events.length; ev++) {
 | |
|     (function(object, name) {
 | |
|       if (options[name]) {
 | |
|         google.maps.event.addListener(object, name, function(e){
 | |
|           options[name].apply(this, [e]);
 | |
|         });
 | |
|       }
 | |
|     })(polygon, polygon_events[ev]);
 | |
|   }
 | |
| 
 | |
|   this.polygons.push(polygon);
 | |
| 
 | |
|   GMaps.fire('polygon_added', polygon, this);
 | |
| 
 | |
|   return polygon;
 | |
| };
 | |
| 
 | |
| GMaps.prototype.removePolygon = function(polygon) {
 | |
|   for (var i = 0; i < this.polygons.length; i++) {
 | |
|     if (this.polygons[i] === polygon) {
 | |
|       this.polygons[i].setMap(null);
 | |
|       this.polygons.splice(i, 1);
 | |
| 
 | |
|       GMaps.fire('polygon_removed', polygon, this);
 | |
| 
 | |
|       break;
 | |
|     }
 | |
|   }
 | |
| };
 | |
| 
 | |
| GMaps.prototype.removePolygons = function() {
 | |
|   for (var i = 0, item; item = this.polygons[i]; i++) {
 | |
|     item.setMap(null);
 | |
|   }
 | |
| 
 | |
|   this.polygons = [];
 | |
| };
 |