* Added hack to allow loading of non-spec-compliant dotScene files from Blender 2.57

git-svn-id: https://jmonkeyengine.googlecode.com/svn/trunk@7521 75d07b2b-3a1a-0410-a2c5-0572b91ccdca
3.0
Sha..rd 14 years ago
parent e91fe8f541
commit 8b8e84ac6a
  1. 8
      engine/src/ogre/com/jme3/scene/plugins/ogre/SceneLoader.java

@ -163,8 +163,10 @@ public class SceneLoader extends DefaultHandler implements AssetLoader {
String lightType = parseString(attribs.getValue("type"), "point"); String lightType = parseString(attribs.getValue("type"), "point");
if(lightType.equals("point")) { if(lightType.equals("point")) {
light = new PointLight(); light = new PointLight();
} else if(lightType.equals("directional")) { } else if(lightType.equals("directional") || lightType.equals("sun")) {
light = new DirectionalLight(); light = new DirectionalLight();
// Assuming "normal" property is not provided
((DirectionalLight)light).setDirection(Vector3f.UNIT_Z);
} else if(lightType.equals("spotLight")) { } else if(lightType.equals("spotLight")) {
// TODO: SpotLight class. // TODO: SpotLight class.
logger.warning("No SpotLight class atm, using Pointlight instead."); logger.warning("No SpotLight class atm, using Pointlight instead.");
@ -284,7 +286,9 @@ public class SceneLoader extends DefaultHandler implements AssetLoader {
parseLight(attribs); parseLight(attribs);
} else if (qName.equals("colourDiffuse") || qName.equals("colorDiffuse")) { } else if (qName.equals("colourDiffuse") || qName.equals("colorDiffuse")) {
if (elementStack.peek().equals("light")){ if (elementStack.peek().equals("light")){
if (light != null){
light.setColor(parseColor(attribs)); light.setColor(parseColor(attribs));
}
}else{ }else{
assert elementStack.peek().equals("environment"); assert elementStack.peek().equals("environment");
} }
@ -309,6 +313,7 @@ public class SceneLoader extends DefaultHandler implements AssetLoader {
}else if (qName.equals("light")){ }else if (qName.equals("light")){
// apply the node's world transform on the light.. // apply the node's world transform on the light..
root.updateGeometricState(); root.updateGeometricState();
if (light != null){
if (light instanceof DirectionalLight){ if (light instanceof DirectionalLight){
DirectionalLight dl = (DirectionalLight) light; DirectionalLight dl = (DirectionalLight) light;
Quaternion q = node.getWorldRotation(); Quaternion q = node.getWorldRotation();
@ -320,6 +325,7 @@ public class SceneLoader extends DefaultHandler implements AssetLoader {
Vector3f pos = node.getWorldTranslation(); Vector3f pos = node.getWorldTranslation();
pl.setPosition(pos); pl.setPosition(pos);
} }
}
light = null; light = null;
} }
assert elementStack.peek().equals(qName); assert elementStack.peek().equals(qName);

Loading…
Cancel
Save