Browse Source

SDK : SceneComposer
- Added support for Axis X,Y,Z movement into the MoveManager

Maselbas 10 years ago
parent
commit
e02a36bf47
1 changed files with 38 additions and 25 deletions
  1. 38 25
      jme3-scenecomposer/src/com/jme3/gde/scenecomposer/tools/MoveTool.java

+ 38 - 25
jme3-scenecomposer/src/com/jme3/gde/scenecomposer/tools/MoveTool.java

@@ -27,7 +27,8 @@ import org.openide.util.Lookup;
  */
 public class MoveTool extends SceneEditTool {
 
-    private Vector3f pickedPlane;
+    private Vector3f pickedMarker;
+    private Vector3f constraintAxis; //used for one axis move
     private boolean wasDragging = false;
     private MoveManager moveManager;
 
@@ -46,15 +47,7 @@ public class MoveTool extends SceneEditTool {
 
     @Override
     public void actionPrimary(Vector2f screenCoord, boolean pressed, JmeNode rootNode, DataObject dataObject) {
-        if (!pressed) {
-            setDefaultAxisMarkerColors();
-            pickedPlane = null; // mouse released, reset selection
-            if (wasDragging) {
-                actionPerformed(moveManager.makeUndo());
-                wasDragging = false;
-            }
-            moveManager.reset();
-        }
+        onPrimary(screenCoord, pressed);
     }
 
     @Override
@@ -63,20 +56,35 @@ public class MoveTool extends SceneEditTool {
 
     @Override
     public void mouseMoved(Vector2f screenCoord, JmeNode rootNode, DataObject currentDataObject, JmeSpatial selectedSpatial) {
-        
-        if (pickedPlane == null) {
+
+        if (pickedMarker == null) {
             highlightAxisMarker(camera, screenCoord, axisPickType);
         } else {
-            pickedPlane = null;
+            pickedMarker = null;
             moveManager.reset();
         }
     }
 
     @Override
     public void draggedPrimary(Vector2f screenCoord, boolean pressed, JmeNode rootNode, DataObject currentDataObject) {
+        onPrimary(screenCoord, pressed);
+    }
+
+    @Override
+    public void draggedSecondary(Vector2f screenCoord, boolean pressed, JmeNode rootNode, DataObject currentDataObject) {
+    }
+
+    /**
+     * Called by ActionPrimary and draggedPrimay, improve user feedback
+     *
+     * @param screenCoord
+     * @param pressed
+     */
+    private void onPrimary(Vector2f screenCoord, boolean pressed) {
         if (!pressed) {
             setDefaultAxisMarkerColors();
-            pickedPlane = null; // mouse released, reset selection
+            pickedMarker = null; // mouse released, reset selection
+            constraintAxis = Vector3f.UNIT_XYZ; // no constraint
             if (wasDragging) {
                 actionPerformed(moveManager.makeUndo());
                 wasDragging = false;
@@ -89,29 +97,34 @@ public class MoveTool extends SceneEditTool {
             return;
         }
 
-        if (pickedPlane == null) {
-            pickedPlane = pickAxisMarker(camera, screenCoord, axisPickType);
-            if (pickedPlane == null) {
+        if (pickedMarker == null) {
+            pickedMarker = pickAxisMarker(camera, screenCoord, axisPickType);
+            if (pickedMarker == null) {
                 return;
             }
 
-            if (pickedPlane.equals(new Vector3f(1, 1, 0))) {
+            if (pickedMarker.equals(QUAD_XY)) {
                 moveManager.initiateMove(toolController.getSelectedSpatial(), MoveManager.XY, true);
-            } else if (pickedPlane.equals(new Vector3f(1, 0, 1))) {
+            } else if (pickedMarker.equals(QUAD_XZ)) {
                 moveManager.initiateMove(toolController.getSelectedSpatial(), MoveManager.XZ, true);
-            } else if (pickedPlane.equals(new Vector3f(0, 1, 1))) {
+            } else if (pickedMarker.equals(QUAD_YZ)) {
+                moveManager.initiateMove(toolController.getSelectedSpatial(), MoveManager.YZ, true);
+            } else if (pickedMarker.equals(ARROW_X)) {
+                moveManager.initiateMove(toolController.getSelectedSpatial(), MoveManager.XY, true);
+                constraintAxis = Vector3f.UNIT_X; // move only X
+            } else if (pickedMarker.equals(ARROW_Y)) {
                 moveManager.initiateMove(toolController.getSelectedSpatial(), MoveManager.YZ, true);
+                constraintAxis = Vector3f.UNIT_Y; // move only Y
+            } else if (pickedMarker.equals(ARROW_Z)) {
+                moveManager.initiateMove(toolController.getSelectedSpatial(), MoveManager.XZ, true);
+                constraintAxis = Vector3f.UNIT_Z; // move only Z
             }
         }
-        if (!moveManager.move(camera, screenCoord)) {
+        if (!moveManager.move(camera, screenCoord, constraintAxis, false)) {
             return;
         }
         updateToolsTransformation();
 
         wasDragging = true;
     }
-
-    @Override
-    public void draggedSecondary(Vector2f screenCoord, boolean pressed, JmeNode rootNode, DataObject currentDataObject) {
-    }
 }