📄 trimeshchunk.java
字号:
/*
* Copyright (c) 2003-2009 jMonkeyEngine
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are
* met:
*
* * Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
*
* * Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
*
* * Neither the name of 'jMonkeyEngine' nor the names of its contributors
* may be used to endorse or promote products derived from this software
* without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
* TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
* 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.jmex.model.converters.maxutils;
import java.io.DataInput;
import java.io.IOException;
import java.util.logging.Logger;
import com.jme.math.Matrix3f;
import com.jme.math.TransformMatrix;
import com.jme.math.Vector2f;
import com.jme.math.Vector3f;
/**
* Started Date: Jul 2, 2004<br><br>
*
* type == OBJ_TRIMESH == 4100<br>
* parent == NAMED_OBJECT == 0x4000<br>
*
* @author Jack Lindamood
*/
class TriMeshChunk extends ChunkerClass {
private static final Logger logger = Logger.getLogger(TriMeshChunk.class
.getName());
Vector3f[] vertexes;
Vector2f[] texCoords;
Matrix3f rotation;
Vector3f origin;
private byte color;
FacesChunk face;
TransformMatrix coordSystem;
public TriMeshChunk(DataInput myIn, ChunkHeader i) throws IOException {
super(myIn,i);
}
protected boolean processChildChunk(ChunkHeader i) throws IOException {
switch (i.type){
case VERTEX_LIST:
readVerts();
return true;
case TEXT_COORDS:
readTexCoords();
return true;
case COORD_SYS:
readCoordSystem();
return true;
case FACES_ARRAY:
if (face!=null)
throw new IOException("Face already non-null... ut ow");
face=new FacesChunk(myIn,i);
return true;
case VERTEX_OPTIONS:
readOptions();
return true;
case MESH_COLOR:
readMeshColor();
return true;
case MESH_TEXTURE_INFO:
readMeshTextureInfo();
return true;
default:
return false;
}
}
private void readMeshTextureInfo() throws IOException {
// currently no idea what this information means, but its here in case I figure it out
short type=myIn.readShort();
float xTiling=myIn.readFloat();
float yTiling=myIn.readFloat();;
float Xicon=myIn.readFloat();
float Yicon=myIn.readFloat();
float Zicon=myIn.readFloat();
float matrix[][]=new float[4][3];
for (int i=0;i<4;i++)
for (int j=0;j<3;j++)
matrix[i][j]=myIn.readFloat();
float scaling=myIn.readFloat();
float planIconW=myIn.readFloat();
float planIconH=myIn.readFloat();
float cylIconH=myIn.readFloat();;
}
private void readMeshColor() throws IOException {
color=myIn.readByte();
if (DEBUG || DEBUG_LIGHT) logger.info("Mesh color read as " + color);
}
private void readOptions() throws IOException {
int numOptions=myIn.readUnsignedShort();
for (int i=0;i<numOptions;i++){
short option=myIn.readShort();
}
if (DEBUG || DEBUG_LIGHT) logger.info("Options read");
}
private void readCoordSystem() throws IOException {
float[] parts=new float[9];
coordSystem=new TransformMatrix();
rotation=new Matrix3f();
for (int i=0;i<9;i++)
parts[i]=myIn.readFloat();
rotation.set(parts);
rotation.transposeLocal();
coordSystem.setRotation(rotation);
origin=new Vector3f(myIn.readFloat(),myIn.readFloat(),myIn.readFloat());
coordSystem.setTranslation(origin);
}
private void readTexCoords() throws IOException {
texCoords=new Vector2f[myIn.readUnsignedShort()];
for (int i=0;i<texCoords.length;i++){
texCoords[i]=new Vector2f(myIn.readFloat(),myIn.readFloat());
if (DEBUG) logger.info("TX#"+i+'='+texCoords[i]);
}
}
private void readVerts() throws IOException {
vertexes=new Vector3f[myIn.readUnsignedShort()];
for (int i=0;i<vertexes.length;i++){
vertexes[i]=new Vector3f(myIn.readFloat(),myIn.readFloat(),myIn.readFloat());
if (DEBUG) logger.info("V#"+i+'='+vertexes[i]);
}
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -