SDK :
- Fixed a NPE in the select tool when user was selectiong nothing git-svn-id: https://jmonkeyengine.googlecode.com/svn/trunk@7871 75d07b2b-3a1a-0410-a2c5-0572b91ccdca
This commit is contained in:
parent
89e18f9b85
commit
66badd193a
@ -1,44 +1,35 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2009-2010 jMonkeyEngine
|
* Copyright (c) 2009-2010 jMonkeyEngine All rights reserved. <p/>
|
||||||
* All rights reserved.
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions are met:
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* * Redistributions of source code must retain the above copyright notice,
|
||||||
* modification, are permitted provided that the following conditions are
|
* this list of conditions and the following disclaimer. <p/> * Redistributions
|
||||||
* met:
|
* in binary form must reproduce the above copyright notice, this list of
|
||||||
*
|
* conditions and the following disclaimer in the documentation and/or other
|
||||||
* * Redistributions of source code must retain the above copyright
|
* materials provided with the distribution. <p/> * Neither the name of
|
||||||
* notice, this list of conditions and the following disclaimer.
|
* 'jMonkeyEngine' nor the names of its contributors may be used to endorse or
|
||||||
*
|
* promote products derived from this software without specific prior written
|
||||||
* * Redistributions in binary form must reproduce the above copyright
|
* permission. <p/> THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND
|
||||||
* notice, this list of conditions and the following disclaimer in the
|
* CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT
|
||||||
* documentation and/or other materials provided with the distribution.
|
* NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
|
||||||
*
|
* PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
|
||||||
* * Neither the name of 'jMonkeyEngine' nor the names of its contributors
|
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||||
* may be used to endorse or promote products derived from this software
|
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||||
* without specific prior written permission.
|
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
|
||||||
*
|
* OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
|
||||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
|
||||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
|
* OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
|
||||||
* TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
|
|
||||||
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
|
||||||
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
|
||||||
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
|
||||||
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
|
||||||
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
|
||||||
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
|
||||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
*/
|
*/
|
||||||
package com.jme3.gde.scenecomposer;
|
package com.jme3.gde.scenecomposer;
|
||||||
|
|
||||||
import com.jme3.collision.CollisionResult;
|
|
||||||
import com.jme3.collision.CollisionResults;
|
|
||||||
import com.jme3.gde.core.scene.SceneApplication;
|
import com.jme3.gde.core.scene.SceneApplication;
|
||||||
import com.jme3.gde.core.scene.controller.AbstractCameraController;
|
import com.jme3.gde.core.scene.controller.AbstractCameraController;
|
||||||
import com.jme3.gde.core.sceneexplorer.nodes.JmeNode;
|
import com.jme3.gde.core.sceneexplorer.nodes.JmeNode;
|
||||||
|
import com.jme3.gde.core.sceneviewer.SceneViewerTopComponent;
|
||||||
import com.jme3.input.KeyInput;
|
import com.jme3.input.KeyInput;
|
||||||
import com.jme3.input.event.KeyInputEvent;
|
import com.jme3.input.event.KeyInputEvent;
|
||||||
import com.jme3.math.Ray;
|
|
||||||
import com.jme3.math.Vector2f;
|
import com.jme3.math.Vector2f;
|
||||||
import com.jme3.math.Vector3f;
|
import com.jme3.math.Vector3f;
|
||||||
import com.jme3.renderer.Camera;
|
import com.jme3.renderer.Camera;
|
||||||
@ -68,55 +59,60 @@ public class ComposerCameraController extends AbstractCameraController {
|
|||||||
public void setToolController(SceneComposerToolController toolController) {
|
public void setToolController(SceneComposerToolController toolController) {
|
||||||
this.toolController = toolController;
|
this.toolController = toolController;
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean isToolUsesCameraControls() {
|
public boolean isToolUsesCameraControls() {
|
||||||
return !toolController.isOverrideCameraControl();
|
return !toolController.isOverrideCameraControl();
|
||||||
}
|
}
|
||||||
|
|
||||||
public Camera getCamera() {
|
public Camera getCamera() {
|
||||||
return cam;
|
return cam;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onKeyEvent(KeyInputEvent kie) {
|
public void onKeyEvent(KeyInputEvent kie) {
|
||||||
|
//don't forget the super call
|
||||||
|
super.onKeyEvent(kie);
|
||||||
if (kie.isPressed()) {
|
if (kie.isPressed()) {
|
||||||
if ( KeyInput.KEY_LSHIFT == kie.getKeyCode() ) {
|
if (KeyInput.KEY_LSHIFT == kie.getKeyCode()) {
|
||||||
forceCameraControls = true;
|
forceCameraControls = true;
|
||||||
}
|
}
|
||||||
} else if (kie.isReleased()){
|
} else if (kie.isReleased()) {
|
||||||
if ( KeyInput.KEY_LSHIFT == kie.getKeyCode() ) {
|
if (KeyInput.KEY_LSHIFT == kie.getKeyCode()) {
|
||||||
forceCameraControls = false;
|
forceCameraControls = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void checkClick(int button, boolean pressed) {
|
public void checkClick(int button, boolean pressed) {
|
||||||
if (button == 0) {
|
if (button == 0) {
|
||||||
if (isEditButtonEnabled() && !forceCameraControls) {
|
if (isEditButtonEnabled() && !forceCameraControls) {
|
||||||
toolController.doEditToolActivatedPrimary(new Vector2f(mouseX,mouseY), pressed, cam);
|
toolController.doEditToolActivatedPrimary(new Vector2f(mouseX, mouseY), pressed, cam);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (button == 1) {
|
if (button == 1) {
|
||||||
if (isEditButtonEnabled() && !forceCameraControls) {
|
if (isEditButtonEnabled() && !forceCameraControls) {
|
||||||
toolController.doEditToolActivatedSecondary(new Vector2f(mouseX,mouseY), pressed, cam);
|
toolController.doEditToolActivatedSecondary(new Vector2f(mouseX, mouseY), pressed, cam);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void checkDragged(int button, boolean pressed) {
|
protected void checkDragged(int button, boolean pressed) {
|
||||||
if (button == 0)
|
if (button == 0) {
|
||||||
toolController.doEditToolDraggedPrimary(new Vector2f(mouseX, mouseY), pressed, cam);
|
toolController.doEditToolDraggedPrimary(new Vector2f(mouseX, mouseY), pressed, cam);
|
||||||
else if (button == 1)
|
} else if (button == 1) {
|
||||||
toolController.doEditToolDraggedSecondary(new Vector2f(mouseX, mouseY), pressed, cam);
|
toolController.doEditToolDraggedSecondary(new Vector2f(mouseX, mouseY), pressed, cam);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void checkMoved() {
|
protected void checkMoved() {
|
||||||
toolController.doEditToolMoved(new Vector2f(mouseX, mouseY), cam);
|
toolController.doEditToolMoved(new Vector2f(mouseX, mouseY), cam);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onAnalog(String string, float f1, float f) {
|
public void onAnalog(String string, float f1, float f) {
|
||||||
if ("MouseAxisX".equals(string)) {
|
if ("MouseAxisX".equals(string)) {
|
||||||
@ -169,6 +165,4 @@ public class ComposerCameraController extends AbstractCameraController {
|
|||||||
zoomCamera(-.1f);
|
zoomCamera(-.1f);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1,17 +1,15 @@
|
|||||||
/*
|
/*
|
||||||
* To change this template, choose Tools | Templates
|
* To change this template, choose Tools | Templates and open the template in
|
||||||
* and open the template in the editor.
|
* the editor.
|
||||||
*/
|
*/
|
||||||
package com.jme3.gde.scenecomposer.tools;
|
package com.jme3.gde.scenecomposer.tools;
|
||||||
|
|
||||||
import com.jme3.gde.core.scene.SceneApplication;
|
import com.jme3.gde.core.scene.SceneApplication;
|
||||||
import com.jme3.gde.core.sceneexplorer.nodes.JmeNode;
|
import com.jme3.gde.core.sceneexplorer.nodes.JmeNode;
|
||||||
import com.jme3.gde.scenecomposer.SceneEditTool;
|
import com.jme3.gde.scenecomposer.SceneEditTool;
|
||||||
import com.jme3.math.Quaternion;
|
|
||||||
import com.jme3.math.Vector2f;
|
import com.jme3.math.Vector2f;
|
||||||
import com.jme3.math.Vector3f;
|
import com.jme3.math.Vector3f;
|
||||||
import com.jme3.scene.Spatial;
|
import com.jme3.scene.Spatial;
|
||||||
import java.util.concurrent.Callable;
|
|
||||||
import org.openide.loaders.DataObject;
|
import org.openide.loaders.DataObject;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -22,15 +20,15 @@ public class SelectTool extends SceneEditTool {
|
|||||||
|
|
||||||
protected Spatial selected;
|
protected Spatial selected;
|
||||||
private boolean wasDragging = false;
|
private boolean wasDragging = false;
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void actionPrimary(Vector2f screenCoord, boolean pressed, final JmeNode rootNode, DataObject dataObject) {
|
public void actionPrimary(Vector2f screenCoord, boolean pressed, final JmeNode rootNode, DataObject dataObject) {
|
||||||
if (!pressed && !wasDragging) {
|
if (!pressed && !wasDragging) {
|
||||||
// mouse released and wasn't dragging, select a new spatial
|
// mouse released and wasn't dragging, select a new spatial
|
||||||
final Spatial result = pickWorldSpatial(getCamera(), screenCoord, rootNode);
|
final Spatial result = pickWorldSpatial(getCamera(), screenCoord, rootNode);
|
||||||
|
|
||||||
java.awt.EventQueue.invokeLater(new Runnable() {
|
java.awt.EventQueue.invokeLater(new Runnable() {
|
||||||
|
|
||||||
public void run() {
|
public void run() {
|
||||||
if (result != null) {
|
if (result != null) {
|
||||||
SceneApplication.getApplication().setCurrentFileNode(rootNode.getChild(result));
|
SceneApplication.getApplication().setCurrentFileNode(rootNode.getChild(result));
|
||||||
@ -44,9 +42,8 @@ public class SelectTool extends SceneEditTool {
|
|||||||
replaceSelectionShape(result);
|
replaceSelectionShape(result);
|
||||||
updateToolsTransformation(selectedSpatial);
|
updateToolsTransformation(selectedSpatial);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!pressed) {
|
if (!pressed) {
|
||||||
wasDragging = false;
|
wasDragging = false;
|
||||||
}
|
}
|
||||||
@ -56,7 +53,9 @@ public class SelectTool extends SceneEditTool {
|
|||||||
public void actionSecondary(final Vector2f screenCoord, boolean pressed, final JmeNode rootNode, DataObject dataObject) {
|
public void actionSecondary(final Vector2f screenCoord, boolean pressed, final JmeNode rootNode, DataObject dataObject) {
|
||||||
if (!pressed && !wasDragging) {
|
if (!pressed && !wasDragging) {
|
||||||
final Vector3f result = pickWorldLocation(getCamera(), screenCoord, rootNode);
|
final Vector3f result = pickWorldLocation(getCamera(), screenCoord, rootNode);
|
||||||
toolController.doSetCursorLocation(result);
|
if (result != null) {
|
||||||
|
toolController.doSetCursorLocation(result);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if (!pressed) {
|
if (!pressed) {
|
||||||
wasDragging = false;
|
wasDragging = false;
|
||||||
@ -65,7 +64,6 @@ public class SelectTool extends SceneEditTool {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void mouseMoved(Vector2f screenCoord) {
|
public void mouseMoved(Vector2f screenCoord) {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -77,5 +75,4 @@ public class SelectTool extends SceneEditTool {
|
|||||||
public void draggedSecondary(Vector2f screenCoord, boolean pressed, JmeNode rootNode, DataObject currentDataObject) {
|
public void draggedSecondary(Vector2f screenCoord, boolean pressed, JmeNode rootNode, DataObject currentDataObject) {
|
||||||
wasDragging = pressed;
|
wasDragging = pressed;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user