/* 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.AddVertexWhileCreatingBehaviour;
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.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 es.axios.udig.ui.editingtools.internal.commands.DefaultEdittingToolsCommandFactory;
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.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 Gabriel Roldan (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());
}
/**
* Initialises 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 ) {
DefaultEdittingToolsCommandFactory commandFactory = new DefaultEdittingToolsCommandFactory();
acceptBehaviours.add(new SplitGeometryBehaviour(commandFactory));
acceptBehaviours.add(new RefreshLayersBehaviour());
}
/**
* Initialises 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());
}
/**
* Initialises 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 AddVertexWhileCreatingBehaviour());
// 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 AcceptOnDoubleClickBehaviour());
helper.done();
}
/**
* Initialises 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[]{Geometry.class,
LineString.class, MultiLineString.class}));
}
}