This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
See the GNU General Public License for more details.
*/
+#ifndef MODEL_ALIAS_H
+#define MODEL_ALIAS_H
+
/*
==============================================================================
#include "modelgen.h"
-/*
-typedef struct
-{
- int firstpose;
- int numposes;
- float interval;
- trivertx_t bboxmin;
- trivertx_t bboxmax;
- int frame;
- char name[16];
-} maliasframedesc_t;
-
-typedef struct
-{
- trivertx_t bboxmin;
- trivertx_t bboxmax;
- int frame;
-} maliasgroupframedesc_t;
-
-typedef struct
-{
- int numframes;
- int intervals;
- maliasgroupframedesc_t frames[1];
-} maliasgroup_t;
-
-typedef struct mtriangle_s {
- int facesfront;
- int vertindex[3];
-} mtriangle_t;
-*/
-
typedef struct {
int ident;
int version;
float size;
} daliashdr_t;
-#define MAXALIASVERTS 4096
-#define MAXALIASFRAMES 1024
-#define MAXALIASTRIS 4096
-
/*
========================================================================
// renamed a things to avoid conflicts
#define MD2ALIAS_VERSION 8
-
-#define MD2MAX_TRIANGLES 4096
-#define MD2MAX_VERTS 4096
-#define MD2MAX_FRAMES 1024
-#define MD2MAX_SKINNAME 64
-// sanity checking size
-#define MD2MAX_SIZE (16777216)
+#define MD2_SKINNAME 64
typedef struct
{
short t;
} md2stvert_t;
-typedef struct
+typedef struct
{
short index_xyz[3];
short index_st[3];
int ofs_end; // end of file
} md2_t;
-// LordHavoc: Q1 and Q2 models are converted to the same internal format
-#define ALIASTYPE_MDLMD2 1
+// LordHavoc: mdl, md2 and md3 models are converted to the same internal format
+#define ALIASTYPE_ALIAS 1
#define ALIASTYPE_ZYM 2
-extern void Mod_LoadAliasModel (struct model_s *mod, void *buffer);
-extern void Mod_LoadQ2AliasModel (struct model_s *mod, void *buffer);
+extern void Mod_IDP0_Load(struct model_s *mod, void *buffer);
+extern void Mod_IDP2_Load(struct model_s *mod, void *buffer);
+extern void Mod_IDP3_Load(struct model_s *mod, void *buffer);
extern void Mod_AliasInit(void);
#include "model_zymotic.h"
+
+// all md3 ints, floats, and shorts, are little endian, and thus need to be
+// passed through LittleLong/LittleFloat/LittleShort to avoid breaking on
+// bigendian machines (Macs for example)
+#define MD3VERSION 15
+#define MD3NAME 64
+#define MD3FRAMENAME 16
+
+// the origin is at 1/64th scale
+// the pitch and yaw are encoded as 8 bits each
+typedef struct md3vertex_s
+{
+ short origin[3], normalpitchyaw;
+}
+md3vertex_t;
+
+// one per frame
+typedef struct md3frameinfo_s
+{
+ float mins[3];
+ float maxs[3];
+ float origin[3];
+ float radius;
+ char name[MD3FRAMENAME];
+}
+md3frameinfo_t;
+
+// one per tag per frame
+typedef struct md3tag_s
+{
+ char name[MD3NAME];
+ float origin[3];
+ float rotationmatrix[9];
+}
+md3tag_t;
+
+// one per shader per mesh
+typedef struct md3shader_s
+{
+ char name[MD3NAME];
+ // engine field (yes this empty int does exist in the file)
+ int shadernum;
+}
+md3shader_t;
+
+// one per mesh per model
+//
+// note that the lump_ offsets in this struct are relative to the beginning
+// of the mesh struct
+//
+// to find the next mesh in the file, you must go to lump_end, which puts you
+// at the beginning of the next mesh
+typedef struct md3mesh_s
+{
+ char identifier[4]; // "IDP3"
+ char name[MD3NAME];
+ int flags;
+ int num_frames;
+ int num_shaders;
+ int num_vertices;
+ int num_triangles;
+ int lump_elements;
+ int lump_shaders;
+ int lump_texcoords;
+ int lump_framevertices;
+ int lump_end;
+}
+md3mesh_t;
+
+// this struct is at the beginning of the md3 file
+//
+// note that the lump_ offsets in this struct are relative to the beginning
+// of the header struct (which is the beginning of the file)
+typedef struct md3modelheader_s
+{
+ char identifier[4]; // "IDP3"
+ int version; // 15
+ char name[MD3NAME];
+ int flags;
+ int num_frames;
+ int num_tags;
+ int num_meshes;
+ int num_skins;
+ int lump_frameinfo;
+ int lump_tags;
+ int lump_meshes;
+ int lump_end;
+}
+md3modelheader_t;
+
+// this layer is fog (completely specialized behavior, automatic NODRAW_IF_NOTFOGGED behavior)
+#define ALIASLAYER_FOG 1
+// apply diffuse lighting
+#define ALIASLAYER_DIFFUSE 8
+// apply specular lighting
+#define ALIASLAYER_SPECULAR 16
+// tint with pants color
+#define ALIASLAYER_COLORMAP_PANTS 32
+// tint with shirt color
+#define ALIASLAYER_COLORMAP_SHIRT 64
+// don't draw this layer if colormap is not used
+#define ALIASLAYER_NODRAW_IF_NOTCOLORMAPPED 128
+// don't draw this layer if colormap is used
+#define ALIASLAYER_NODRAW_IF_COLORMAPPED 256
+// ignore NODRAW flags on this layer only if all previous layers were skipped
+#define ALIASLAYER_FORCEDRAW_IF_FIRSTPASS 512
+
+typedef struct aliaslayer_s
+{
+ int flags;
+ rtexture_t *texture;
+ rtexture_t *nmap;
+}
+aliaslayer_t;
+
+// indicates this skin is transparent
+#define ALIASSKIN_TRANSPARENT 1
+
+typedef struct aliasskin_s
+{
+ int flags;
+ int num_layers;
+ aliaslayer_t *data_layers;
+}
+aliasskin_t;
+
+typedef struct aliasmesh_s
+{
+ int num_skins;
+ int num_triangles;
+ int num_frames;
+ int num_vertices;
+ aliasskin_t *data_skins;
+ int *data_element3i;
+ int *data_neighbor3i;
+ float *data_texcoord2f;
+ float *data_aliasvertex3f;
+ float *data_aliassvector3f;
+ float *data_aliastvector3f;
+ float *data_aliasnormal3f;
+}
+aliasmesh_t;
+
+typedef struct aliastag_s
+{
+ char name[MD3NAME];
+ matrix4x4_t matrix;
+}
+aliastag_t;
+
+
+#endif
+