/*** * * Copyright (c) 1996-2002, Valve LLC. All rights reserved. * * This product contains software technology licensed from Id * Software, Inc. ("Id Technology"). Id Technology (c) 1996 Id Software, Inc. * All Rights Reserved. * * Use, distribution, and modification of this source code and/or resulting * object code is restricted to non-commercial enhancements to products from * Valve LLC. All other use, distribution, or modification is prohibited * without written permission from Valve LLC. * ****/ #pragma once #ifndef STUDIO_H #define STUDIO_H /* ============================================================================== STUDIO MODELS Studio models are position independent, so the cache manager can move them. ============================================================================== */ // header #define STUDIO_VERSION 10 #define IDSTUDIOHEADER (('T'<<24)+('S'<<16)+('D'<<8)+'I') // little-endian "IDST" #define IDSEQGRPHEADER (('Q'<<24)+('S'<<16)+('D'<<8)+'I') // little-endian "IDSQ" // studio limits #define MAXSTUDIOVERTS 16384 // max vertices per submodel #define MAXSTUDIOSEQUENCES 256 // total animation sequences #define MAXSTUDIOSKINS 256 // total textures #define MAXSTUDIOSRCBONES 512 // bones allowed at source movement #define MAXSTUDIOBONES 128 // total bones actually used #define MAXSTUDIOMODELS 32 // sub-models per model #define MAXSTUDIOBODYPARTS 32 // body parts per submodel #define MAXSTUDIOGROUPS 16 // sequence groups (e.g. barney01.mdl, barney02.mdl, e.t.c) #define MAXSTUDIOMESHES 256 // max textures per model #define MAXSTUDIOCONTROLLERS 32 // max controllers per model #define MAXSTUDIOATTACHMENTS 64 // max attachments per model #define MAXSTUDIOBONEWEIGHTS 4 // absolute hardware limit! #define MAXSTUDIONAME 32 // a part of specs #define MAXSTUDIOPOSEPARAM 24 #define MAX_STUDIO_LIGHTMAP_SIZE 256 // must match with engine const!!! // client-side model flags #define STUDIO_ROCKET (1U<<0) // leave a trail #define STUDIO_GRENADE (1U<<1) // leave a trail #define STUDIO_GIB (1U<<2) // leave a trail #define STUDIO_ROTATE (1U<<3) // rotate (bonus items) #define STUDIO_TRACER (1U<<4) // green split trail #define STUDIO_ZOMGIB (1U<<5) // small blood trail #define STUDIO_TRACER2 (1U<<6) // orange split trail + rotate #define STUDIO_TRACER3 (1U<<7) // purple trail #define STUDIO_AMBIENT_LIGHT (1U<<8) // force to use ambient shading #define STUDIO_TRACE_HITBOX (1U<<9) // always use hitbox trace instead of bbox #define STUDIO_FORCE_SKYLIGHT (1U<<10) // always grab lightvalues from the sky settings (even if sky is invisible) #define STUDIO_HAS_BUMP (1U<<16) // loadtime set #define STUDIO_STATIC_PROP (1U<<29) // hint for engine #define STUDIO_HAS_BONEINFO (1U<<30) // extra info about bones (pose matrix, procedural index etc) #define STUDIO_HAS_BONEWEIGHTS (1U<<31) // yes we got support of bone weighting // lighting & rendermode options #define STUDIO_NF_FLATSHADE 0x0001 #define STUDIO_NF_CHROME 0x0002 #define STUDIO_NF_FULLBRIGHT 0x0004 #define STUDIO_NF_NOMIPS 0x0008 // ignore mip-maps #define STUDIO_NF_SMOOTH 0x0010 // smooth tangent space #define STUDIO_NF_ADDITIVE 0x0020 // rendering with additive mode #define STUDIO_NF_MASKED 0x0040 // use texture with alpha channel #define STUDIO_NF_NORMALMAP 0x0080 // indexed normalmap #define STUDIO_NF_GLOSSMAP 0x0100 // glossmap #define STUDIO_NF_GLOSSPOWER 0x0200 #define STUDIO_NF_LUMA 0x0400 // self-illuminate parts #define STUDIO_NF_ALPHASOLID 0x0800 // use with STUDIO_NF_MASKED to have solid alphatest surfaces for env_static #define STUDIO_NF_TWOSIDE 0x1000 // render mesh as twosided #define STUDIO_NF_HEIGHTMAP 0x2000 #define STUDIO_NF_NODRAW (1<<16) // failed to create shader for this mesh #define STUDIO_NF_NODLIGHT (1<<17) // failed to create dlight shader for this mesh #define STUDIO_NF_NOSUNLIGHT (1<<18) // failed to create sun light shader for this mesh #define STUDIO_NF_HAS_ALPHA (1<<20) // external texture has alpha-channel #define STUDIO_NF_HAS_DETAIL (1<<21) // studiomodels has detail textures #define STUDIO_NF_COLORMAP (1<<30) // internal system flag #define STUDIO_NF_UV_COORDS (1<<31) // using half-float coords instead of ST // motion flags #define STUDIO_X 0x0001 #define STUDIO_Y 0x0002 #define STUDIO_Z 0x0004 #define STUDIO_XR 0x0008 #define STUDIO_YR 0x0010 #define STUDIO_ZR 0x0020 #define STUDIO_LX 0x0040 #define STUDIO_LY 0x0080 #define STUDIO_LZ 0x0100 #define STUDIO_LXR 0x0200 #define STUDIO_LYR 0x0400 #define STUDIO_LZR 0x0800 #define STUDIO_LINEAR 0x1000 #define STUDIO_QUADRATIC_MOTION 0x2000 #define STUDIO_RESERVED 0x4000 // g-cont. reserved one bit for me #define STUDIO_TYPES 0x7FFF #define STUDIO_RLOOP 0x8000 // controller that wraps shortest distance // bonecontroller types #define STUDIO_MOUTH 4 // hardcoded // sequence flags #define STUDIO_LOOPING 0x0001 // ending frame should be the same as the starting frame #define STUDIO_SNAP 0x0002 // do not interpolate between previous animation and this one #define STUDIO_DELTA 0x0004 // this sequence "adds" to the base sequences, not slerp blends #define STUDIO_AUTOPLAY 0x0008 // temporary flag that forces the sequence to always play #define STUDIO_POST 0x0010 // #define STUDIO_ALLZEROS 0x0020 // this animation/sequence has no real animation data #define STUDIO_BLENDPOSE 0x0040 // to differentiate GoldSrc style blending from Source style blending (with pose parameters) #define STUDIO_CYCLEPOSE 0x0080 // cycle index is taken from a pose parameter index #define STUDIO_REALTIME 0x0100 // cycle index is taken from a real-time clock, not the animations cycle index #define STUDIO_LOCAL 0x0200 // sequence has a local context sequence #define STUDIO_HIDDEN 0x0400 // don't show in default selection views #define STUDIO_IKRULES 0x0800 // sequence has IK-rules #define STUDIO_ACTIVITY 0x1000 // Has been updated at runtime to activity index #define STUDIO_EVENT 0x2000 // Has been updated at runtime to event index #define STUDIO_WORLD 0x4000 // sequence blends in worldspace #define STUDIO_LIGHT_FROM_ROOT 0x8000 // get lighting point from root bonepos not from entity origin // autolayer flags #define STUDIO_AL_POST 0x0001 // #define STUDIO_AL_SPLINE 0x0002 // convert layer ramp in/out curve is a spline instead of linear #define STUDIO_AL_XFADE 0x0004 // pre-bias the ramp curve to compense for a non-1 weight, // assuming a second layer is also going to accumulate #define STUDIO_AL_NOBLEND 0x0008 // animation always blends at 1.0 (ignores weight) #define STUDIO_AL_LOCAL 0x0010 // layer is a local context sequence #define STUDIO_AL_POSE 0x0020 // layer blends using a pose parameter instead of parent cycle typedef struct studiohdr_s { int32_t ident; int32_t version; char name[64]; int32_t length; vec3_t eyeposition; // ideal eye position vec3_t min; // ideal movement hull size vec3_t max; vec3_t bbmin; // clipping bounding box vec3_t bbmax; int32_t flags; int32_t numbones; // bones int32_t boneindex; int32_t numbonecontrollers; // bone controllers int32_t bonecontrollerindex; int32_t numhitboxes; // complex bounding boxes int32_t hitboxindex; int32_t numseq; // animation sequences int32_t seqindex; int32_t numseqgroups; // demand loaded sequences int32_t seqgroupindex; int32_t numtextures; // raw textures int32_t textureindex; int32_t texturedataindex; int32_t numskinref; // replaceable textures int32_t numskinfamilies; int32_t skinindex; int32_t numbodyparts; int32_t bodypartindex; int32_t numattachments; // queryable attachable points int32_t attachmentindex; int32_t studiohdr2index; int32_t soundindex; // UNUSED int32_t soundgroups; // UNUSED int32_t soundgroupindex; // UNUSED int32_t numtransitions; // animation node to animation node transition graph int32_t transitionindex; } studiohdr_t; // extra header to hold more offsets typedef struct { int32_t numposeparameters; int32_t poseparamindex; int32_t numikautoplaylocks; int32_t ikautoplaylockindex; int32_t numikchains; int32_t ikchainindex; int32_t keyvalueindex; int32_t keyvaluesize; int32_t numhitboxsets; int32_t hitboxsetindex; int32_t unused[6]; // for future expansions } studiohdr2_t; // header for demand loaded sequence group data typedef struct { int32_t id; int32_t version; char name[64]; int32_t length; } studioseqhdr_t; // bone flags #define BONE_ALWAYS_PROCEDURAL 0x0001 // bone is always procedurally animated #define BONE_SCREEN_ALIGN_SPHERE 0x0002 // bone aligns to the screen, not constrained in motion. #define BONE_SCREEN_ALIGN_CYLINDER 0x0004 // bone aligns to the screen, constrained by it's own axis. #define BONE_JIGGLE_PROCEDURAL 0x0008 #define BONE_FIXED_ALIGNMENT 0x0010 // bone can't spin 360 degrees, all interpolation is normalized around a fixed orientation #define BONE_USED_MASK (BONE_USED_BY_HITBOX|BONE_USED_BY_ATTACHMENT|BONE_USED_BY_VERTEX|BONE_USED_BY_BONE_MERGE) #define BONE_USED_BY_ANYTHING BONE_USED_MASK #define BONE_USED_BY_HITBOX 0x00000100// bone (or child) is used by a hit box #define BONE_USED_BY_ATTACHMENT 0x00000200// bone (or child) is used by an attachment point #define BONE_USED_BY_VERTEX 0x00000400// bone (or child) is used by the toplevel model via skinned vertex #define BONE_USED_BY_BONE_MERGE 0x00000800 // bones typedef struct mstudiobone_s { char name[MAXSTUDIONAME]; // bone name for symbolic links int32_t parent; // parent bone int32_t flags; // bone flags int32_t bonecontroller[6]; // bone controller index, -1 == none float value[6]; // default DoF values float scale[6]; // scale for delta DoF values } mstudiobone_t; #define STUDIO_PROC_AXISINTERP 1 #define STUDIO_PROC_QUATINTERP 2 #define STUDIO_PROC_AIMATBONE 3 #define STUDIO_PROC_AIMATATTACH 4 #define STUDIO_PROC_JIGGLE 5 typedef struct { int32_t control; // local transformation of this bone used to calc 3 point blend int32_t axis; // axis to check vec3_t pos[6]; // X+, X-, Y+, Y-, Z+, Z- vec4_t quat[6]; // X+, X-, Y+, Y-, Z+, Z- } mstudioaxisinterpbone_t; typedef struct { float inv_tolerance; // 1.0f / radian angle of trigger influence vec4_t trigger; // angle to match vec3_t pos; // new position vec4_t quat; // new angle } mstudioquatinterpinfo_t; typedef struct { int32_t control; // local transformation to check int32_t numtriggers; int32_t triggerindex; } mstudioquatinterpbone_t; // extra info for bones typedef struct { float poseToBone[3][4]; // boneweighting reqiures vec4_t qAlignment; int32_t proctype; int32_t procindex; // procedural rule vec4_t quat; // aligned bone rotation int32_t reserved[10]; // for future expansions } mstudioboneinfo_t; // JIGGLEBONES #define JIGGLE_IS_FLEXIBLE 0x01 #define JIGGLE_IS_RIGID 0x02 #define JIGGLE_HAS_YAW_CONSTRAINT 0x04 #define JIGGLE_HAS_PITCH_CONSTRAINT 0x08 #define JIGGLE_HAS_ANGLE_CONSTRAINT 0x10 #define JIGGLE_HAS_LENGTH_CONSTRAINT 0x20 #define JIGGLE_HAS_BASE_SPRING 0x40 #define JIGGLE_IS_BOING 0x80 // simple squash and stretch sinusoid "boing" typedef struct { int32_t flags; // general params float length; // how from from bone base, along bone, is tip float tipMass; // flexible params float yawStiffness; float yawDamping; float pitchStiffness; float pitchDamping; float alongStiffness; float alongDamping; // angle constraint float angleLimit; // maximum deflection of tip in radians // yaw constraint float minYaw; // in radians float maxYaw; // in radians float yawFriction; float yawBounce; // pitch constraint float minPitch; // in radians float maxPitch; // in radians float pitchFriction; float pitchBounce; // base spring float baseMass; float baseStiffness; float baseDamping; float baseMinLeft; float baseMaxLeft; float baseLeftFriction; float baseMinUp; float baseMaxUp; float baseUpFriction; float baseMinForward; float baseMaxForward; float baseForwardFriction; // boing float boingImpactSpeed; float boingImpactAngle; float boingDampingRate; float boingFrequency; float boingAmplitude; } mstudiojigglebone_t; typedef struct { int32_t parent; int32_t aim; // might be bone or attach vec3_t aimvector; vec3_t upvector; vec3_t basepos; } mstudioaimatbone_t; // bone controllers typedef struct { int32_t bone; // -1 == 0 int32_t type; // X, Y, Z, XR, YR, ZR, M float start; float end; int32_t rest; // byte index value at rest int32_t index; // 0-3 user set controller, 4 mouth } mstudiobonecontroller_t; // intersection boxes typedef struct { int32_t bone; int32_t group; // intersection group vec3_t bbmin; // bounding box vec3_t bbmax; } mstudiobbox_t; typedef struct { char name[MAXSTUDIONAME]; int32_t numhitboxes; int32_t hitboxindex; } mstudiohitboxset_t; // demand loaded sequence groups typedef struct { char label[MAXSTUDIONAME]; // textual name char name[64]; // file name int32_t cache; // cache index pointer int32_t data; // hack for group 0 } mstudioseqgroup_t; // events #include "studio_event.h" #define STUDIO_ATTACHMENT_LOCAL (1<<0) // vectors are filled // attachment typedef struct { char name[MAXSTUDIONAME]; int32_t flags; int32_t bone; vec3_t org; // attachment position vec3_t vectors[3]; // attachment vectors } mstudioattachment_t; #define IK_SELF 1 #define IK_WORLD 2 #define IK_GROUND 3 #define IK_RELEASE 4 #define IK_ATTACHMENT 5 #define IK_UNLATCH 6 typedef struct { float scale[6]; uint16_t offset[6]; } mstudioikerror_t; typedef struct { int32_t index; int32_t type; int32_t chain; int32_t bone; int32_t attachment; // attachment index int32_t slot; // iktarget slot. Usually same as chain. float height; float radius; float floor; vec3_t pos; vec4_t quat; int32_t ikerrorindex; // compressed IK error int32_t iStart; float start; // beginning of influence float peak; // start of full influence float tail; // end of full influence float end; // end of all influence float contact; // frame footstep makes ground concact float drop; // how far down the foot should drop when reaching for IK float top; // top of the foot box int32_t unused[4]; // for future expansions } mstudioikrule_t; typedef struct { int32_t chain; float flPosWeight; float flLocalQWeight; int32_t flags; int32_t unused[4]; // for future expansions } mstudioiklock_t; typedef struct { int32_t endframe; int32_t motionflags; float v0; // velocity at start of block float v1; // velocity at end of block float angle; // YAW rotation at end of this blocks movement vec3_t vector; // movement vector relative to this blocks initial angle vec3_t position; // relative to start of animation??? } mstudiomovement_t; // additional info for each animation in sequence blend group or single sequence typedef struct { char label[MAXSTUDIONAME]; // animation label (may be matched with sequence label) float fps; // frames per second (match with sequence fps or be different) int32_t flags; // looping/non-looping flags int32_t numframes; // frames per animation // piecewise movement int32_t nummovements; // piecewise movement int32_t movementindex; int32_t numikrules; int32_t ikruleindex; // non-zero when IK data is stored in the mdl int32_t unused[8]; // for future expansions } mstudioanimdesc_t; // autoplaying sequences typedef struct { int16_t iSequence; int16_t iPose; int32_t flags; float start; // beginning of influence float peak; // start of full influence float tail; // end of full influence float end; // end of all influence } mstudioautolayer_t; // sequence descriptions typedef struct mstudioseqdesc_s { char label[MAXSTUDIONAME]; // sequence label float fps; // frames per second int32_t flags; // looping/non-looping flags int32_t activity; int32_t actweight; int32_t numevents; int32_t eventindex; int32_t numframes; // number of frames per sequence int32_t weightlistindex; // weightlists int32_t iklockindex; // IK locks int32_t motiontype; int32_t motionbone; // index of pose parameter vec3_t linearmovement; int32_t autolayerindex; // autolayer descriptions int32_t keyvalueindex; // local key-values vec3_t bbmin; // per sequence bounding box vec3_t bbmax; int32_t numblends; int32_t animindex; // mstudioanim_t pointer relative to start of sequence group data // [blend][bone][X, Y, Z, XR, YR, ZR] int32_t blendtype[2]; // X, Y, Z, XR, YR, ZR (same as paramindex) float blendstart[2]; // starting value (same as paramstart) float blendend[2]; // ending value (same as paramend) uint8_t groupsize[2]; // 255 x 255 blends should be enough uint8_t numautolayers; // count of autoplaying layers uint8_t numiklocks; // IK-locks per sequence int32_t seqgroup; // sequence group for demand loading int32_t entrynode; // transition node at entry int32_t exitnode; // transition node at exit uint8_t nodeflags; // transition rules (really this is bool) uint8_t cycleposeindex; // index of pose parameter to use as cycle index uint8_t fadeintime; // ideal cross fade in time (0.2 secs default) time = (fadeintime / 100) uint8_t fadeouttime; // ideal cross fade out time (0.2 msecs default) time = (fadeouttime / 100) int32_t animdescindex; // mstudioanimdesc_t [blend] } mstudioseqdesc_t; typedef struct { char name[MAXSTUDIONAME]; int32_t flags; // ???? float start; // starting value float end; // ending value float loop; // looping range, 0 for no looping, 360 for rotations, etc. } mstudioposeparamdesc_t; typedef struct mstudioanim_s { uint16_t offset[6]; } mstudioanim_t; // animation frames typedef union { struct { uint8_t valid; uint8_t total; } num; int16_t value; } mstudioanimvalue_t; // body part index typedef struct { char name[64]; int32_t nummodels; int32_t base; int32_t modelindex; // index into models array } mstudiobodyparts_t; // skin info typedef struct mstudiotex_s { char name[64]; uint32_t flags; int32_t width; int32_t height; int32_t index; } mstudiotexture_t; // ikinfo typedef struct { int32_t bone; vec3_t kneeDir; // ideal bending direction (per link, if applicable) vec3_t unused0; // unused } mstudioiklink_t; typedef struct { char name[MAXSTUDIONAME]; int32_t linktype; int32_t numlinks; int32_t linkindex; } mstudioikchain_t; typedef struct { uint8_t weight[4]; int8_t bone[4]; } mstudioboneweight_t; // skin families // short index[skinfamilies][skinref] // studio models typedef struct { char name[64]; int32_t type; // UNUSED float boundingradius; // UNUSED int32_t nummesh; int32_t meshindex; int32_t numverts; // number of unique vertices int32_t vertinfoindex; // vertex bone info int32_t vertindex; // vertex vec3_t int32_t numnorms; // number of unique surface normals int32_t norminfoindex; // normal bone info int32_t normindex; // normal vec3_t int32_t blendvertinfoindex; // boneweighted vertex info int32_t blendnorminfoindex; // boneweighted normal info } mstudiomodel_t; // vec3_t boundingbox[model][bone][2]; // complex intersection info // meshes typedef struct { int32_t numtris; int32_t triindex; int32_t skinref; int32_t numnorms; // per mesh normals int32_t normindex; // UNUSED! } mstudiomesh_t; // triangles typedef struct { int16_t vertindex; // index into vertex array int16_t normindex; // index into normal array int16_t s,t; // s,t position on skin } mstudiotrivert_t; #endif//STUDIO_H