private static W3dFile Parse(BinaryReader reader, string filePath) { var context = new W3dParseContext(); context.PushChunk(nameof(W3dFile), reader.BaseStream.Length); var result = new W3dFile { FilePath = filePath }; W3dContainerChunk.ParseChunks(reader, reader.BaseStream.Length, chunkType => { switch (chunkType) { case W3dChunkType.W3D_CHUNK_MESH: result.Chunks.Add(W3dMesh.Parse(reader, context)); break; case W3dChunkType.W3D_CHUNK_BOX: result.Chunks.Add(W3dBox.Parse(reader, context)); break; case W3dChunkType.W3D_CHUNK_HIERARCHY: result.Chunks.Add(W3dHierarchyDef.Parse(reader, context)); break; case W3dChunkType.W3D_CHUNK_HLOD: result.Chunks.Add(W3dHLod.Parse(reader, context)); break; case W3dChunkType.W3D_CHUNK_ANIMATION: result.Chunks.Add(W3dAnimation.Parse(reader, context)); break; case W3dChunkType.W3D_CHUNK_COMPRESSED_ANIMATION: result.Chunks.Add(W3dCompressedAnimation.Parse(reader, context)); break; case W3dChunkType.W3D_CHUNK_EMITTER: result.Chunks.Add(W3dEmitter.Parse(reader, context)); break; default: throw W3dContainerChunk.CreateUnknownChunkException(chunkType); } }); context.PopAsset(); return(result); }
public static W3dBox Parse(BinaryReader reader) { var result = new W3dBox { Version = reader.ReadUInt32() }; var flags = reader.ReadUInt32(); result.BoxType = (W3dBoxType)(flags & 0b11); result.CollisionTypes = (W3dBoxCollisionTypes)(flags & 0xFF0); result.Name = reader.ReadFixedLengthString(W3dConstants.NameLength * 2); result.Color = W3dRgb.Parse(reader); result.Center = reader.ReadVector3(); result.Extent = reader.ReadVector3(); return(result); }
internal static W3dBox Parse(BinaryReader reader, W3dParseContext context) { return(ParseChunk(reader, context, header => { var result = new W3dBox { Version = reader.ReadUInt32() }; var flags = reader.ReadUInt32(); result.BoxType = (W3dBoxType)(flags & 0b11); result.CollisionTypes = (W3dBoxCollisionTypes)(flags & 0xFF0); result.Name = reader.ReadFixedLengthString(W3dConstants.NameLength * 2); result.Color = W3dRgb.Parse(reader); result.Center = reader.ReadVector3(); result.Extent = reader.ReadVector3(); return result; }));
private static W3dFile Parse(BinaryReader reader, string filePath) { var meshes = new List <W3dMesh>(); var boxes = new List <W3dBox>(); W3dHierarchyDef hierarchy = null; W3dHLod hlod = null; var animations = new List <W3dAnimation>(); var compressedAnimations = new List <W3dCompressedAnimation>(); var emitters = new List <W3dEmitter>(); W3dFile result; if (reader.BaseStream.Length > 0) { result = ParseChunk <W3dFile>(reader, (uint)reader.BaseStream.Length, (x, header) => { switch (header.ChunkType) { case W3dChunkType.W3D_CHUNK_MESH: meshes.Add(W3dMesh.Parse(reader, header.ChunkSize)); break; case W3dChunkType.W3D_CHUNK_BOX: boxes.Add(W3dBox.Parse(reader)); break; case W3dChunkType.W3D_CHUNK_HIERARCHY: if (hierarchy != null) { throw new InvalidDataException(); } hierarchy = W3dHierarchyDef.Parse(reader, header.ChunkSize); break; case W3dChunkType.W3D_CHUNK_HLOD: if (hlod != null) { throw new InvalidDataException(); } hlod = W3dHLod.Parse(reader, header.ChunkSize); break; case W3dChunkType.W3D_CHUNK_ANIMATION: animations.Add(W3dAnimation.Parse(reader, header.ChunkSize)); break; case W3dChunkType.W3D_CHUNK_COMPRESSED_ANIMATION: compressedAnimations.Add(W3dCompressedAnimation.Parse(reader, header.ChunkSize)); break; case W3dChunkType.W3D_CHUNK_EMITTER: emitters.Add(W3dEmitter.Parse(reader, header.ChunkSize)); break; default: throw CreateUnknownChunkException(header); } }); } else { result = new W3dFile(); } result.FilePath = filePath; result.Meshes = meshes; result.Boxes = boxes; result.Hierarchy = hierarchy; result.HLod = hlod; result.Animations = animations; result.CompressedAnimations = compressedAnimations; result.Emitters = emitters; return(result); }