Merge branch 'master' of github.com:jMonkeyEngine/jmonkeyengine
This commit is contained in:
commit
71472bbf90
6
.gitignore
vendored
6
.gitignore
vendored
@ -72,3 +72,9 @@
|
|||||||
/jme3-android-native/OpenALSoft.zip
|
/jme3-android-native/OpenALSoft.zip
|
||||||
/jme3-android-native/stb_image/
|
/jme3-android-native/stb_image/
|
||||||
/jme3-bullet-native-android/build/
|
/jme3-bullet-native-android/build/
|
||||||
|
/sdk/nbproject/private/
|
||||||
|
/sdk/nbproject/private/
|
||||||
|
/sdk/jme3-scenecomposer/nbproject/private/
|
||||||
|
/sdk/jme3-core/nbproject/private/
|
||||||
|
/.nb-gradle/profiles/private/
|
||||||
|
/build/tmp/mergedJavadoc/
|
||||||
|
@ -32,50 +32,37 @@
|
|||||||
package com.jme3.gde.core.sceneexplorer.nodes;
|
package com.jme3.gde.core.sceneexplorer.nodes;
|
||||||
|
|
||||||
import com.jme3.gde.core.icons.IconList;
|
import com.jme3.gde.core.icons.IconList;
|
||||||
import com.jme3.gde.core.properties.SceneExplorerProperty;
|
|
||||||
import com.jme3.gde.core.properties.ScenePropertyChangeListener;
|
import com.jme3.gde.core.properties.ScenePropertyChangeListener;
|
||||||
import com.jme3.gde.core.scene.SceneApplication;
|
import com.jme3.gde.core.scene.SceneApplication;
|
||||||
import com.jme3.gde.core.util.DynamicLookup;
|
|
||||||
import com.jme3.gde.core.util.PropertyUtils;
|
|
||||||
import com.jme3.scene.Spatial;
|
import com.jme3.scene.Spatial;
|
||||||
import com.jme3.scene.control.Control;
|
import com.jme3.scene.control.Control;
|
||||||
import java.awt.Image;
|
import java.awt.Image;
|
||||||
import java.beans.PropertyDescriptor;
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.lang.reflect.Field;
|
|
||||||
import java.util.concurrent.Callable;
|
import java.util.concurrent.Callable;
|
||||||
import java.util.concurrent.ExecutionException;
|
import java.util.concurrent.ExecutionException;
|
||||||
import javax.swing.Action;
|
import javax.swing.Action;
|
||||||
import org.openide.actions.DeleteAction;
|
import org.openide.actions.DeleteAction;
|
||||||
import org.openide.loaders.DataObject;
|
import org.openide.loaders.DataObject;
|
||||||
import org.openide.nodes.AbstractNode;
|
|
||||||
import org.openide.nodes.Children;
|
|
||||||
import org.openide.nodes.Sheet;
|
import org.openide.nodes.Sheet;
|
||||||
import org.openide.util.Exceptions;
|
import org.openide.util.Exceptions;
|
||||||
import org.openide.util.actions.SystemAction;
|
import org.openide.util.actions.SystemAction;
|
||||||
import org.openide.util.lookup.InstanceContent;
|
|
||||||
import org.openide.util.lookup.ProxyLookup;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* @author normenhansen
|
* @author normenhansen
|
||||||
*/
|
*/
|
||||||
public class JmeGenericControl extends AbstractNode implements ScenePropertyChangeListener {
|
public class JmeGenericControl extends AbstractSceneExplorerNode {
|
||||||
|
|
||||||
private Control control;
|
private final Control control;
|
||||||
private static Image smallImage = IconList.wheel.getImage();
|
private static final Image smallImage = IconList.wheel.getImage();
|
||||||
private DataObject dobject;
|
|
||||||
private InstanceContent lookupContents;
|
|
||||||
|
|
||||||
public JmeGenericControl(Control control, DataObject dataObject) {
|
public JmeGenericControl(Control control, DataObject dataObject) {
|
||||||
//TODO: lookup content! (control etc)
|
//TODO: lookup content! (control etc)
|
||||||
super(Children.LEAF, new ProxyLookup(dataObject.getLookup(), new DynamicLookup(new InstanceContent())));
|
super(dataObject);
|
||||||
lookupContents = getLookup().lookup(DynamicLookup.class).getInstanceContent();
|
|
||||||
this.control = control;
|
this.control = control;
|
||||||
this.dobject = dataObject;
|
addToLookup(this);
|
||||||
lookupContents.add(this);
|
addToLookup(control);
|
||||||
lookupContents.add(control);
|
setName(control.getClass().getSimpleName());
|
||||||
setName(control.getClass().getName());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -92,20 +79,37 @@ public class JmeGenericControl extends AbstractNode implements ScenePropertyChan
|
|||||||
protected Sheet createSheet() {
|
protected Sheet createSheet() {
|
||||||
//TODO: multithreading..
|
//TODO: multithreading..
|
||||||
Sheet sheet = Sheet.createDefault();
|
Sheet sheet = Sheet.createDefault();
|
||||||
Sheet.Set set = Sheet.createPropertiesSet();
|
|
||||||
set.setDisplayName("Control");
|
|
||||||
set.setName(Control.class.getName());
|
|
||||||
if (control == null) {
|
if (control == null) {
|
||||||
return sheet;
|
return sheet;
|
||||||
}
|
}
|
||||||
|
putSheetSets(sheet, control.getClass(), false);
|
||||||
createFields(control.getClass(), set, control);
|
|
||||||
|
|
||||||
sheet.put(set);
|
|
||||||
return sheet;
|
return sheet;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Append one Sheet.Set of fields per class,
|
||||||
|
* recursively to the root class of the hierarchie.
|
||||||
|
*
|
||||||
|
* @param sheet Sheet where to put.
|
||||||
|
* @param c current class to start add.
|
||||||
|
* @param hidden sheet for c is hidden (parent are hidden = true)
|
||||||
|
*/
|
||||||
|
protected void putSheetSets(Sheet sheet, Class c, boolean hidden) {
|
||||||
|
Sheet.Set set = Sheet.createPropertiesSet();
|
||||||
|
set.setDisplayName(String.format("%s - %s", c.getSimpleName(), c.getPackage().getName()));
|
||||||
|
set.setName(c.getName());
|
||||||
|
set.setHidden(hidden);
|
||||||
|
createFields(c, set, control);
|
||||||
|
|
||||||
|
Class parent = c.getSuperclass();
|
||||||
|
if (parent != null && !parent.equals(Object.class)) {
|
||||||
|
putSheetSets(sheet, parent, true);
|
||||||
|
}
|
||||||
|
sheet.put(set);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Action[] getActions(boolean context) {
|
public Action[] getActions(boolean context) {
|
||||||
return new SystemAction[]{
|
return new SystemAction[]{
|
||||||
@ -140,46 +144,7 @@ public class JmeGenericControl extends AbstractNode implements ScenePropertyChan
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
protected Property makeProperty(Object obj, Class returntype, String method, String name) {
|
public Class getExplorerObjectClass() {
|
||||||
Property prop = null;
|
return control.getClass();
|
||||||
try {
|
|
||||||
prop = new SceneExplorerProperty(control.getClass().cast(obj), returntype, method, null);
|
|
||||||
prop.setName(name);
|
|
||||||
} catch (NoSuchMethodException ex) {
|
|
||||||
Exceptions.printStackTrace(ex);
|
|
||||||
}
|
|
||||||
return prop;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected Property makeProperty(Object obj, Class returntype, String method, String setter, String name) {
|
|
||||||
Property prop = null;
|
|
||||||
try {
|
|
||||||
// if (readOnly) {
|
|
||||||
// prop = new SceneExplorerProperty(control.getClass().cast(obj), returntype, method, null);
|
|
||||||
// } else {
|
|
||||||
prop = new SceneExplorerProperty(control.getClass().cast(obj), returntype, method, setter, this);
|
|
||||||
// }
|
|
||||||
prop.setName(name);
|
|
||||||
|
|
||||||
} catch (NoSuchMethodException ex) {
|
|
||||||
Exceptions.printStackTrace(ex);
|
|
||||||
}
|
|
||||||
return prop;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected void createFields(Class c, Sheet.Set set, Object obj) throws SecurityException {
|
|
||||||
for (Field field : c.getDeclaredFields()) {
|
|
||||||
PropertyDescriptor prop = PropertyUtils.getPropertyDescriptor(c, field);
|
|
||||||
if (prop != null) {
|
|
||||||
set.put(makeProperty(obj, prop.getPropertyType(), prop.getReadMethod().getName(), prop.getWriteMethod().getName(), prop.getDisplayName()));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void propertyChange(String type, String name, Object oldValue, Object newValue) {
|
|
||||||
if (type.equals("PROP_USER_CHANGE")) {
|
|
||||||
dobject.setModified(true);
|
|
||||||
}
|
|
||||||
// throw new UnsupportedOperationException("Not supported yet.");
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -155,7 +155,9 @@ public class JmeGeometry extends JmeSpatial implements MaterialChangeListener {
|
|||||||
|
|
||||||
public void run() {
|
public void run() {
|
||||||
try {
|
try {
|
||||||
SceneExplorerTopComponent.findInstance().swapMaterialChangeListener(JmeGeometry.this, ((Material) before).getAssetName(), ((Material) after).getAssetName());
|
String beforeName = (before == null)? null : ((Material) before).getAssetName();
|
||||||
|
String afterName = (after == null)? null : ((Material) after).getAssetName();
|
||||||
|
SceneExplorerTopComponent.findInstance().swapMaterialChangeListener(JmeGeometry.this, beforeName, afterName);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
Exceptions.printStackTrace(e);
|
Exceptions.printStackTrace(e);
|
||||||
}
|
}
|
||||||
|
@ -64,6 +64,11 @@ public class PropertyUtils {
|
|||||||
if (name.length() > 0) {
|
if (name.length() > 0) {
|
||||||
name = Character.toLowerCase(name.charAt(0)) + name.substring(1);
|
name = Character.toLowerCase(name.charAt(0)) + name.substring(1);
|
||||||
}
|
}
|
||||||
|
} else if (name.startsWith("is")) {
|
||||||
|
name = name.substring(2);
|
||||||
|
if (name.length() > 0) {
|
||||||
|
name = Character.toLowerCase(name.charAt(0)) + name.substring(1);
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user