1 package net.systemeD.potlatch2.controller {
3 import net.systemeD.potlatch2.EditController;
4 import net.systemeD.halcyon.connection.*;
5 import net.systemeD.halcyon.WayUI;
7 public class DragWayNode extends ControllerState {
8 private var draggingNode:Node;
9 private var draggingIndex:int;
10 private var isDraggingStarted:Boolean = false;
11 private var isNew:Boolean = false;
13 private var downX:Number;
14 private var downY:Number;
15 private var originalLat:Number;
16 private var originalLon:Number;
17 private var dragstate:uint=NOT_MOVED;
18 private const NOT_DRAGGING:uint=0;
19 private const NOT_MOVED:uint=1;
20 private const DRAGGING:uint=2;
22 private var parentWay:Way;
23 private var initEvent:MouseEvent;
25 public function DragWayNode(way:Way, index:int, event:MouseEvent, newNode:Boolean) {
32 // the rest of the init will be done during enterState, because we need the controller to be initialised
35 private function addNode(selectedWay:Way,event:MouseEvent):int {
36 var ways:Array = editableLayer.findWaysAtPoint(event.stageX, event.stageY, selectedWay);
37 var lat:Number = controller.map.coord2lat(event.localY);
38 var lon:Number = controller.map.coord2lon(event.localX);
39 var undo:CompositeUndoableAction = new CompositeUndoableAction("Insert node");
40 var node:Node = selectedWay.connection.createNode({}, lat, lon, undo.push);
41 var index:int = selectedWay.insertNodeAtClosestPosition(node, true, undo.push);
42 for each (var w:Way in ways) { w.insertNodeAtClosestPosition(node, true, undo.push); }
43 MainUndoStack.getGlobalStack().addAction(undo);
48 override public function processMouseEvent(event:MouseEvent, entity:Entity):ControllerState {
50 if (event.type==MouseEvent.MOUSE_UP) {
51 if (dragstate==DRAGGING) {
52 // mouse-up while dragging, so end drag
53 return new SelectedWayNode(parentWay,draggingIndex);
54 } else if (event.shiftKey && !isNew) {
56 var way:Way = entity.connection.createWay({}, [entity],
57 MainUndoStack.getGlobalStack().addAction);
58 return new DrawWay(way, true, false);
59 } else if (event.shiftKey && isNew) {
60 return new SelectedWayNode(parentWay,draggingIndex);
63 dragstate=NOT_DRAGGING;
64 return SelectedWayNode.selectOrEdit(parentWay, draggingIndex);
67 } else if ( event.type == MouseEvent.MOUSE_MOVE) {
69 if (dragstate==NOT_DRAGGING) {
71 } else if (dragstate==NOT_MOVED && Math.abs(downX - event.localX) < 3 && Math.abs(downY - event.localY) < 3) {
83 override public function processKeyboardEvent(event:KeyboardEvent):ControllerState {
84 if (event.keyCode==27) {
85 draggingNode.setLatLon( originalLat, originalLon, MainUndoStack.getGlobalStack().addAction );
86 return new SelectedWayNode(parentWay,draggingIndex);
91 private function dragTo(event:MouseEvent):ControllerState {
92 draggingNode.setLatLon( controller.map.coord2lat(event.localY),
93 controller.map.coord2lon(event.localX),
94 MainUndoStack.getGlobalStack().addAction );
98 public function forceDragStart():void {
102 override public function get selectedWay():Way {
106 override public function enterState():void {
107 if (isNew && draggingIndex==-1) { draggingIndex=addNode(parentWay,initEvent); }
108 draggingNode = parentWay.getNode(draggingIndex);
109 originalLat = draggingNode.lat;
110 originalLon = draggingNode.lon;
112 editableLayer.setHighlightOnNodes(parentWay, { selectedway: true } );
113 editableLayer.limitWayDrawing(parentWay, draggingIndex);
114 editableLayer.setHighlight(draggingNode, { selected: true } );
115 editableLayer.protectWay(parentWay);
116 editableLayer.limitWayDrawing(parentWay, NaN, draggingIndex);
118 override public function exitState(newState:ControllerState):void {
119 editableLayer.unprotectWay(parentWay);
120 editableLayer.limitWayDrawing(parentWay);
121 editableLayer.setHighlightOnNodes(parentWay, { selectedway: false } );
122 editableLayer.setHighlight(draggingNode, { selected: false } );
124 override public function toString():String {
125 return "DragWayNode";