|
@@ -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) {
|
|
|
- }
|
|
|
}
|