@ -37,6 +37,7 @@ import java.util.LinkedHashMap;
import java.util.List ;
import java.util.List ;
import java.util.Map ;
import java.util.Map ;
import java.util.Map.Entry ;
import java.util.Map.Entry ;
import java.util.logging.Level ;
import java.util.logging.Logger ;
import java.util.logging.Logger ;
import com.jme3.asset.BlenderKey.FeaturesToLoad ;
import com.jme3.asset.BlenderKey.FeaturesToLoad ;
@ -106,18 +107,18 @@ public class MeshHelper extends AbstractBlenderHelper {
return copiedGeometries ;
return copiedGeometries ;
}
}
// reading mesh data
String name = structure . getName ( ) ;
String name = structure . getName ( ) ;
MeshContext meshContext = new MeshContext ( ) ;
MeshContext meshContext = new MeshContext ( ) ;
LOGGER . log ( Level . FINE , "Reading mesh: {0}." , name ) ;
// reading materials
LOGGER . fine ( "Loading materials." ) ;
MaterialHelper materialHelper = blenderContext . getHelper ( MaterialHelper . class ) ;
MaterialHelper materialHelper = blenderContext . getHelper ( MaterialHelper . class ) ;
MaterialContext [ ] materials = null ;
MaterialContext [ ] materials = null ;
if ( ( blenderContext . getBlenderKey ( ) . getFeaturesToLoad ( ) & FeaturesToLoad . MATERIALS ) ! = 0 ) {
if ( ( blenderContext . getBlenderKey ( ) . getFeaturesToLoad ( ) & FeaturesToLoad . MATERIALS ) ! = 0 ) {
materials = materialHelper . getMaterials ( structure , blenderContext ) ;
materials = materialHelper . getMaterials ( structure , blenderContext ) ;
}
}
// reading vertices and their colors
LOGGER . fine ( "Reading vertices and their colors." ) ;
Vector3f [ ] [ ] verticesAndNormals = this . getVerticesAndNormals ( structure , blenderContext ) ;
Vector3f [ ] [ ] verticesAndNormals = this . getVerticesAndNormals ( structure , blenderContext ) ;
List < byte [ ] > verticesColors = this . getVerticesColors ( structure , blenderContext ) ;
List < byte [ ] > verticesColors = this . getVerticesColors ( structure , blenderContext ) ;
@ -130,6 +131,7 @@ public class MeshHelper extends AbstractBlenderHelper {
}
}
if ( meshBuilder . isEmpty ( ) ) {
if ( meshBuilder . isEmpty ( ) ) {
LOGGER . fine ( "The geometry is empty." ) ;
geometries = new ArrayList < Geometry > ( 0 ) ;
geometries = new ArrayList < Geometry > ( 0 ) ;
blenderContext . addLoadedFeatures ( structure . getOldMemoryAddress ( ) , structure . getName ( ) , structure , geometries ) ;
blenderContext . addLoadedFeatures ( structure . getOldMemoryAddress ( ) , structure . getName ( ) , structure , geometries ) ;
blenderContext . setMeshContext ( structure . getOldMemoryAddress ( ) , meshContext ) ;
blenderContext . setMeshContext ( structure . getOldMemoryAddress ( ) , meshContext ) ;
@ -138,7 +140,7 @@ public class MeshHelper extends AbstractBlenderHelper {
meshContext . setVertexReferenceMap ( meshBuilder . getVertexReferenceMap ( ) ) ;
meshContext . setVertexReferenceMap ( meshBuilder . getVertexReferenceMap ( ) ) ;
// reading vertices groups (from the parent)
LOGGER . fine ( "Reading vertices groups (from the Object structure)." ) ;
Structure parent = blenderContext . peekParent ( ) ;
Structure parent = blenderContext . peekParent ( ) ;
Structure defbase = ( Structure ) parent . getFieldValue ( "defbase" ) ;
Structure defbase = ( Structure ) parent . getFieldValue ( "defbase" ) ;
List < Structure > defs = defbase . evaluateListBase ( blenderContext ) ;
List < Structure > defs = defbase . evaluateListBase ( blenderContext ) ;
@ -148,13 +150,11 @@ public class MeshHelper extends AbstractBlenderHelper {
verticesGroups [ defIndex + + ] = def . getFieldValue ( "name" ) . toString ( ) ;
verticesGroups [ defIndex + + ] = def . getFieldValue ( "name" ) . toString ( ) ;
}
}
// creating the result meshes
LOGGER . fine ( "Reading custom properties." ) ;
geometries = new ArrayList < Geometry > ( meshBuilder . getMeshesPartAmount ( ) ) ;
// reading custom properties
Properties properties = this . loadProperties ( structure , blenderContext ) ;
Properties properties = this . loadProperties ( structure , blenderContext ) ;
// generating meshes
LOGGER . fine ( "Generating meshes." ) ;
geometries = new ArrayList < Geometry > ( meshBuilder . getMeshesPartAmount ( ) ) ;
for ( Entry < Integer , List < Integer > > meshEntry : meshBuilder . getMeshesMap ( ) . entrySet ( ) ) {
for ( Entry < Integer , List < Integer > > meshEntry : meshBuilder . getMeshesMap ( ) . entrySet ( ) ) {
int materialIndex = meshEntry . getKey ( ) ;
int materialIndex = meshEntry . getKey ( ) ;
// key is the material index (or -1 if the material has no texture)
// key is the material index (or -1 if the material has no texture)
@ -177,34 +177,23 @@ public class MeshHelper extends AbstractBlenderHelper {
mesh . setBuffer ( Type . Index , 1 , indices ) ;
mesh . setBuffer ( Type . Index , 1 , indices ) ;
}
}
LOGGER . fine ( "Creating vertices buffer." ) ;
VertexBuffer verticesBuffer = new VertexBuffer ( Type . Position ) ;
VertexBuffer verticesBuffer = new VertexBuffer ( Type . Position ) ;
verticesBuffer . setupData ( Usage . Static , 3 , Format . Float , BufferUtils . createFloatBuffer ( meshBuilder . getVertices ( materialIndex ) ) ) ;
verticesBuffer . setupData ( Usage . Static , 3 , Format . Float , BufferUtils . createFloatBuffer ( meshBuilder . getVertices ( materialIndex ) ) ) ;
mesh . setBuffer ( verticesBuffer ) ;
// initial vertex position (used with animation)
LOGGER . fine ( "Creating normals buffer." ) ;
VertexBuffer verticesBind = new VertexBuffer ( Type . BindPosePosition ) ;
verticesBind . setupData ( Usage . CpuOnly , 3 , Format . Float , BufferUtils . createFloatBuffer ( meshBuilder . getVertices ( materialIndex ) ) ) ;
VertexBuffer normalsBuffer = new VertexBuffer ( Type . Normal ) ;
VertexBuffer normalsBuffer = new VertexBuffer ( Type . Normal ) ;
normalsBuffer . setupData ( Usage . Static , 3 , Format . Float , BufferUtils . createFloatBuffer ( meshBuilder . getNormals ( materialIndex ) ) ) ;
normalsBuffer . setupData ( Usage . Static , 3 , Format . Float , BufferUtils . createFloatBuffer ( meshBuilder . getNormals ( materialIndex ) ) ) ;
mesh . setBuffer ( normalsBuffer ) ;
// initial normals position (used with animation)
VertexBuffer normalsBind = new VertexBuffer ( Type . BindPoseNormal ) ;
normalsBind . setupData ( Usage . CpuOnly , 3 , Format . Float , BufferUtils . createFloatBuffer ( meshBuilder . getNormals ( materialIndex ) ) ) ;
mesh . setBuffer ( verticesBuffer ) ;
meshContext . setBindPoseBuffer ( materialIndex , verticesBind ) ; // this is stored in the context and applied when needed (when animation is applied to the mesh)
// setting vertices colors
if ( verticesColors ! = null ) {
if ( verticesColors ! = null ) {
LOGGER . fine ( "Setting vertices colors." ) ;
mesh . setBuffer ( Type . Color , 4 , meshBuilder . getVertexColorsBuffer ( materialIndex ) ) ;
mesh . setBuffer ( Type . Color , 4 , meshBuilder . getVertexColorsBuffer ( materialIndex ) ) ;
mesh . getBuffer ( Type . Color ) . setNormalized ( true ) ;
mesh . getBuffer ( Type . Color ) . setNormalized ( true ) ;
}
}
// setting faces' normals
LOGGER . fine ( "Preparing the result part." ) ;
mesh . setBuffer ( normalsBuffer ) ;
meshContext . setBindNormalBuffer ( materialIndex , normalsBind ) ; // this is stored in the context and applied when needed (when animation is applied to the mesh)
// creating the result
Geometry geometry = new Geometry ( name + ( geometries . size ( ) + 1 ) , mesh ) ;
Geometry geometry = new Geometry ( name + ( geometries . size ( ) + 1 ) , mesh ) ;
if ( properties ! = null & & properties . getValue ( ) ! = null ) {
if ( properties ! = null & & properties . getValue ( ) ! = null ) {
this . applyProperties ( geometry , properties ) ;
this . applyProperties ( geometry , properties ) ;
@ -347,6 +336,7 @@ public class MeshHelper extends AbstractBlenderHelper {
* blender file
* blender file
* /
* /
private void readBMesh ( MeshBuilder meshBuilder , Structure meshStructure , BlenderContext blenderContext ) throws BlenderFileException {
private void readBMesh ( MeshBuilder meshBuilder , Structure meshStructure , BlenderContext blenderContext ) throws BlenderFileException {
LOGGER . fine ( "Reading BMesh." ) ;
Pointer pMLoop = ( Pointer ) meshStructure . getFieldValue ( "mloop" ) ;
Pointer pMLoop = ( Pointer ) meshStructure . getFieldValue ( "mloop" ) ;
Pointer pMPoly = ( Pointer ) meshStructure . getFieldValue ( "mpoly" ) ;
Pointer pMPoly = ( Pointer ) meshStructure . getFieldValue ( "mpoly" ) ;
Pointer pMEdge = ( Pointer ) meshStructure . getFieldValue ( "medge" ) ;
Pointer pMEdge = ( Pointer ) meshStructure . getFieldValue ( "medge" ) ;
@ -409,6 +399,7 @@ public class MeshHelper extends AbstractBlenderHelper {
* blender file
* blender file
* /
* /
private void readTraditionalFaces ( MeshBuilder meshBuilder , Structure meshStructure , BlenderContext blenderContext ) throws BlenderFileException {
private void readTraditionalFaces ( MeshBuilder meshBuilder , Structure meshStructure , BlenderContext blenderContext ) throws BlenderFileException {
LOGGER . fine ( "Reading traditional faces." ) ;
Pointer pMFace = ( Pointer ) meshStructure . getFieldValue ( "mface" ) ;
Pointer pMFace = ( Pointer ) meshStructure . getFieldValue ( "mface" ) ;
List < Structure > mFaces = pMFace . isNotNull ( ) ? pMFace . fetchData ( blenderContext . getInputStream ( ) ) : null ;
List < Structure > mFaces = pMFace . isNotNull ( ) ? pMFace . fetchData ( blenderContext . getInputStream ( ) ) : null ;
if ( mFaces ! = null & & mFaces . size ( ) > 0 ) {
if ( mFaces ! = null & & mFaces . size ( ) > 0 ) {