/* uDig-Spatial Operations plugins * http://b5m.gipuzkoa.net * (C) 2006, DiputaciĆ³n Foral de Gipuzkoa, OrdenaciĆ³n Territorial. * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; * version 2.1 of the License. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. */ package es.axios.udig.ui.editingtools.split; import java.util.List; import java.util.Set; import net.refractions.udig.project.ui.tool.IToolContext; import net.refractions.udig.tools.edit.AbstractEditTool; import net.refractions.udig.tools.edit.Activator; import net.refractions.udig.tools.edit.Behaviour; import net.refractions.udig.tools.edit.EditToolConfigurationHelper; import net.refractions.udig.tools.edit.EnablementBehaviour; import net.refractions.udig.tools.edit.activator.DrawCurrentGeomVerticesActivator; import net.refractions.udig.tools.edit.activator.DrawGeomsActivator; import net.refractions.udig.tools.edit.activator.EditStateListenerActivator; import net.refractions.udig.tools.edit.activator.ResetAllStateActivator; import net.refractions.udig.tools.edit.activator.SetSnapBehaviourCommandHandlerActivator; import net.refractions.udig.tools.edit.behaviour.AcceptOnDoubleClickBehaviour; import net.refractions.udig.tools.edit.behaviour.DefaultCancelBehaviour; import net.refractions.udig.tools.edit.behaviour.DrawCreateVertexSnapAreaBehaviour; import net.refractions.udig.tools.edit.behaviour.RefreshLayersBehaviour; import net.refractions.udig.tools.edit.behaviour.SetSnapSizeBehaviour; import net.refractions.udig.tools.edit.behaviour.StartEditingBehaviour; import net.refractions.udig.tools.edit.enablement.ValidToolDetectionActivator; import net.refractions.udig.tools.edit.support.ShapeType; import com.vividsolutions.jts.geom.Geometry; import com.vividsolutions.jts.geom.LineString; import com.vividsolutions.jts.geom.MultiLineString; import com.vividsolutions.jts.geom.MultiPolygon; import com.vividsolutions.jts.geom.Polygon; import es.axios.udig.ui.editingtools.internal.i18n.Messages; import es.axios.udig.ui.editingtools.internal.presentation.StatusBar; import es.axios.udig.ui.editingtools.split.internal.AddSplitVertexBehaviour; import es.axios.udig.ui.editingtools.split.internal.SplitGeometryBehaviour; /** * Splits one or more SimpleFeature using a {@link SplitGeometryBehaviour} to * accomplish the task once the user finished drawing the splitting line. * <p> * Users can use this tool to either: * <ul> * <li>Split one or more Simple Features using a line * <li>Split one polygon feature by creating a hole * </ul> * * @author Mauricio Pazos (www.axios.es) * @author Aritz Davila (www.axios.es) * @since 1.1.0 */ public class SplitTool extends AbstractEditTool { @Override public void setActive(final boolean active) { super.setActive(active); IToolContext context = getContext(); if (active && context.getMapLayers().size() > 0) { String message = Messages.SplitTool_draw_line_to_split; StatusBar.setStatusBarMessage(context, message); } else { StatusBar.setStatusBarMessage(context, "");//$NON-NLS-1$ } } /** * Initializes the list of Activators that are ran when the tool is * activated and deactivated. * * @param activators * an empty list. */ @Override protected void initActivators(Set<Activator> activators) { activators.add(new EditStateListenerActivator()); activators.add(new DrawGeomsActivator(DrawGeomsActivator.DrawType.LINE)); activators.add(new DrawCurrentGeomVerticesActivator()); activators.add(new ResetAllStateActivator()); activators.add(new SetSnapBehaviourCommandHandlerActivator()); } /** * Initializes the list of Behaviours to run when the current edit has been * accepted. Acceptance is signalled by a double click or the Enter key * * @param acceptBehaviours * an empty list */ @Override protected void initAcceptBehaviours(List<Behaviour> acceptBehaviours) { acceptBehaviours.add(new SplitGeometryBehaviour()); acceptBehaviours.add(new RefreshLayersBehaviour()); } /** * Initializes the behaviours that are ran when a cancel signal is received * (the ESC key). * * @param cancelBehaviours * an empty list */ @Override protected void initCancelBehaviours(List<Behaviour> cancelBehaviours) { cancelBehaviours.add(new DefaultCancelBehaviour()); } /** * Initializes the Event Behaviours that are run when an event occurs. Since * this can be complex a helper class is provided to build the complex * datastructure of Behaviours. * * @see EditToolConfigurationHelper * @param helper * a helper for constructing the complicated structure of * EventBehaviours. */ @Override protected void initEventBehaviours(EditToolConfigurationHelper helper) { helper.add(new DrawCreateVertexSnapAreaBehaviour()); helper.startMutualExclusiveList(); helper.add(new AddSplitVertexBehaviour()); // override so that editing will not be started if there are no // geometries on the // blackboard. helper.add(new StartEditingBehaviour(ShapeType.LINE)); helper.stopMutualExclusiveList(); helper.add(new SetSnapSizeBehaviour()); helper.add(new AcceptOnDoubleClickBehaviour()); helper.done(); } /** * Initializes the list of {@link EnablementBehaviour}s that are ran to * determine if the tool is enabled given an event. For example if the mouse * cursor is outside the valid bounds of a CRS for a layer an * EnablementBehaviour might signal that editing is illegal and provide a * message for the user indicating why. * * @param enablementBehaviours * an empty list */ @Override protected void initEnablementBehaviours(List<EnablementBehaviour> enablementBehaviours) { /* * enablementBehaviours.add(new WithinLegalLayerBoundsBehaviour()); */ enablementBehaviours.add(new ValidToolDetectionActivator(new Class[] { LineString.class, MultiLineString.class, MultiPolygon.class, Polygon.class})); } }