com.google.gwt.maps.client.drawinglib.DrawingManager Maven / Gradle / Ivy
package com.google.gwt.maps.client.drawinglib;
/*
* #%L
* GWT Maps API V3 - Core API
* %%
* Copyright (C) 2011 - 2012 GWT Maps API V3
* %%
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
* #L%
*/
import com.google.gwt.core.client.JavaScriptObject;
import com.google.gwt.event.shared.HandlerRegistration;
import com.google.gwt.maps.client.MapImpl;
import com.google.gwt.maps.client.MapWidget;
import com.google.gwt.maps.client.events.MapEventType;
import com.google.gwt.maps.client.events.MapHandlerRegistration;
import com.google.gwt.maps.client.events.overlaycomplete.OverlayCompleteEventFormatter;
import com.google.gwt.maps.client.events.overlaycomplete.OverlayCompleteMapHandler;
import com.google.gwt.maps.client.events.overlaycomplete.circle.CircleCompleteEventFormatter;
import com.google.gwt.maps.client.events.overlaycomplete.circle.CircleCompleteMapHandler;
import com.google.gwt.maps.client.events.overlaycomplete.marker.MarkerCompleteEventFormatter;
import com.google.gwt.maps.client.events.overlaycomplete.marker.MarkerCompleteMapHandler;
import com.google.gwt.maps.client.events.overlaycomplete.polygon.PolygonCompleteEventFormatter;
import com.google.gwt.maps.client.events.overlaycomplete.polygon.PolygonCompleteMapHandler;
import com.google.gwt.maps.client.events.overlaycomplete.polyline.PolylineCompleteEventFormatter;
import com.google.gwt.maps.client.events.overlaycomplete.polyline.PolylineCompleteMapHandler;
import com.google.gwt.maps.client.events.overlaycomplete.rectangle.RectangleCompleteEventFormatter;
import com.google.gwt.maps.client.events.overlaycomplete.rectangle.RectangleCompleteMapHandler;
import com.google.gwt.maps.client.mvc.MVCObject;
/**
* Allows users to draw markers, polygons, polylines, rectangles, and circles on the map. The DrawingManager's drawing
* mode defines the type of overlay that will be created by the user. Adds a control to the map, allowing the user to
* switch drawing mode. This class extends MVCObject.
*
* See DrawingManager
* API Doc
*/
public class DrawingManager extends MVCObject {
/**
* use newInstance();
*/
protected DrawingManager() {
}
/**
* Creates a DrawingManager that allows users to draw overlays on the map, and switch between the type of overlay to
* be drawn with a drawing control.
*
* @param options
*/
public static final DrawingManager newInstance(DrawingManagerOptions options) {
return createJso(options).cast();
}
private static native JavaScriptObject createJso(DrawingManagerOptions options) /*-{
return new $wnd.google.maps.drawing.DrawingManager(options);
}-*/;
/**
* Returns the DrawingManager's drawing mode.
*/
public final OverlayType getDrawingMode() {
String type = getDrawingModeImpl();
if (type == null) {
return null;
} else {
return OverlayType.fromValue(type);
}
}
private final native String getDrawingModeImpl() /*-{
return this.getDrawingMode();
}-*/;
/**
* Changes the DrawingManager's drawing mode, which defines the type of overlay to be added on the map. Accepted
* values are MARKER, POLYGON, POLYLINE, RECTANGLE, CIRCLE, or null. A drawing mode of null means that the user can
* interact with the map as normal, and clicks do not draw anything.
*
* @param drawingMode
*/
public final void setDrawingMode(OverlayType drawingMode) {
String value = (drawingMode != null) ? drawingMode.value() : null;
setDrawingModeImpl(value);
}
private final native void setDrawingModeImpl(String drawingMode) /*-{
this.setDrawingMode(drawingMode);
}-*/;
/**
* Attaches the DrawingManager object to the specified Map.
*
* @param mapWidget
*/
public final void setMap(MapWidget mapWidget) {
MapImpl value = (mapWidget != null) ? mapWidget.getJso() : null;
setMapImpl(value);
}
private final native void setMapImpl(MapImpl map) /*-{
this.setMap(map);
}-*/;
/**
* Returns the Map to which the DrawingManager is attached, which is the Map on which the overlays created will be
* placed.
*/
public final MapWidget getMap() {
return MapWidget.newInstance(getMapImpl());
}
private final native MapImpl getMapImpl() /*-{
return this.getMap();
}-*/;
/**
* This event is fired when the user has finished drawing a circle.
*
* @param handler
*/
public final HandlerRegistration addCircleCompleteHandler(CircleCompleteMapHandler handler) {
return MapHandlerRegistration.addHandlerDrawing(this, MapEventType.CIRCLECOMPLETE, handler,
new CircleCompleteEventFormatter());
}
/**
* This event is fired when the user has finished drawing a marker.
*
* @param handler
*/
public final HandlerRegistration addMarkerCompleteHandler(MarkerCompleteMapHandler handler) {
return MapHandlerRegistration.addHandlerDrawing(this, MapEventType.MARKERCOMPLETE, handler,
new MarkerCompleteEventFormatter());
}
/**
* This event is fired when the user has finished drawing an overlay of any type.
*
* @param handler
*/
public final HandlerRegistration addOverlayCompleteHandler(OverlayCompleteMapHandler handler) {
return MapHandlerRegistration.addHandler(this, MapEventType.OVERLAYCOMPLETE, handler,
new OverlayCompleteEventFormatter());
}
/**
* This event is fired when the user has finished drawing a polygon.
*
* @param handler
*/
public final HandlerRegistration addPolygonCompleteHandler(PolygonCompleteMapHandler handler) {
return MapHandlerRegistration.addHandlerDrawing(this, MapEventType.POLYGONCOMPLETE, handler,
new PolygonCompleteEventFormatter());
}
/**
* This event is fired when the user has finished drawing a polyline.
*
* @param handler
*/
public final HandlerRegistration addPolylineCompleteHandler(PolylineCompleteMapHandler handler) {
return MapHandlerRegistration.addHandlerDrawing(this, MapEventType.POLYLINECOMPLETE, handler,
new PolylineCompleteEventFormatter());
}
/**
* This event is fired when the user has finished drawing a rectangle.
*
* @param handler
*/
public final HandlerRegistration addRectangleCompleteHandler(RectangleCompleteMapHandler handler) {
return MapHandlerRegistration.addHandlerDrawing(this, MapEventType.RECTANGLECOMPLETE, handler,
new RectangleCompleteEventFormatter());
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy