mirror of
https://github.com/Laupetin/OpenAssetTools.git
synced 2025-10-24 07:15:51 +00:00
Add loading of iw4 assets clipmap and mapents
This commit is contained in:
@@ -116,11 +116,11 @@ GameAssetPoolIW4::GameAssetPoolIW4(const int priority)
|
||||
m_sound = nullptr;
|
||||
m_sound_curve = nullptr;
|
||||
m_loaded_sound = nullptr;
|
||||
// m_clip_map = nullptr;
|
||||
m_clip_map = nullptr;
|
||||
// m_com_world = nullptr;
|
||||
// m_game_world_sp = nullptr;
|
||||
// m_game_world_mp = nullptr;
|
||||
// m_map_ents = nullptr;
|
||||
m_map_ents = nullptr;
|
||||
// m_fx_world = nullptr;
|
||||
// m_gfx_world = nullptr;
|
||||
m_gfx_light_def = nullptr;
|
||||
@@ -168,12 +168,12 @@ void GameAssetPoolIW4::InitPoolStatic(const asset_type_t type, const size_t capa
|
||||
CASE_INIT_POOL_STATIC(ASSET_TYPE_SOUND, m_sound, snd_alias_list_t);
|
||||
CASE_INIT_POOL_STATIC(ASSET_TYPE_SOUND_CURVE, m_sound_curve, SndCurve);
|
||||
CASE_INIT_POOL_STATIC(ASSET_TYPE_LOADED_SOUND, m_loaded_sound, LoadedSound);
|
||||
// CASE_INIT_POOL_STATIC(ASSET_TYPE_CLIPMAP_SP, m_clip_map, clipMap_t);
|
||||
// CASE_INIT_POOL_STATIC(ASSET_TYPE_CLIPMAP_MP, m_clip_map, clipMap_t);
|
||||
CASE_INIT_POOL_STATIC(ASSET_TYPE_CLIPMAP_SP, m_clip_map, clipMap_t);
|
||||
CASE_INIT_POOL_STATIC(ASSET_TYPE_CLIPMAP_MP, m_clip_map, clipMap_t);
|
||||
// CASE_INIT_POOL_STATIC(ASSET_TYPE_COMWORLD, m_com_world, ComWorld);
|
||||
// CASE_INIT_POOL_STATIC(ASSET_TYPE_GAMEWORLD_SP, m_game_world_sp, GameWorldSp);
|
||||
// CASE_INIT_POOL_STATIC(ASSET_TYPE_GAMEWORLD_MP, m_game_world_mp, GameWorldMp);
|
||||
// CASE_INIT_POOL_STATIC(ASSET_TYPE_MAP_ENTS, m_map_ents, MapEnts);
|
||||
CASE_INIT_POOL_STATIC(ASSET_TYPE_MAP_ENTS, m_map_ents, MapEnts);
|
||||
// CASE_INIT_POOL_STATIC(ASSET_TYPE_FXWORLD, m_fx_world, FxWorld);
|
||||
// CASE_INIT_POOL_STATIC(ASSET_TYPE_GFXWORLD, m_gfx_world, GfxWorld);
|
||||
CASE_INIT_POOL_STATIC(ASSET_TYPE_LIGHT_DEF, m_gfx_light_def, GfxLightDef);
|
||||
@@ -228,12 +228,12 @@ void GameAssetPoolIW4::InitPoolDynamic(const asset_type_t type)
|
||||
CASE_INIT_POOL_DYNAMIC(ASSET_TYPE_SOUND, m_sound, snd_alias_list_t);
|
||||
CASE_INIT_POOL_DYNAMIC(ASSET_TYPE_SOUND_CURVE, m_sound_curve, SndCurve);
|
||||
CASE_INIT_POOL_DYNAMIC(ASSET_TYPE_LOADED_SOUND, m_loaded_sound, LoadedSound);
|
||||
// CASE_INIT_POOL_DYNAMIC(ASSET_TYPE_CLIPMAP_SP, m_clip_map, clipMap_t);
|
||||
// CASE_INIT_POOL_DYNAMIC(ASSET_TYPE_CLIPMAP_MP, m_clip_map, clipMap_t);
|
||||
CASE_INIT_POOL_DYNAMIC(ASSET_TYPE_CLIPMAP_SP, m_clip_map, clipMap_t);
|
||||
CASE_INIT_POOL_DYNAMIC(ASSET_TYPE_CLIPMAP_MP, m_clip_map, clipMap_t);
|
||||
// CASE_INIT_POOL_DYNAMIC(ASSET_TYPE_COMWORLD, m_com_world, ComWorld);
|
||||
// CASE_INIT_POOL_DYNAMIC(ASSET_TYPE_GAMEWORLD_SP, m_game_world_sp, GameWorldSp);
|
||||
// CASE_INIT_POOL_DYNAMIC(ASSET_TYPE_GAMEWORLD_MP, m_game_world_mp, GameWorldMp);
|
||||
// CASE_INIT_POOL_DYNAMIC(ASSET_TYPE_MAP_ENTS, m_map_ents, MapEnts);
|
||||
CASE_INIT_POOL_DYNAMIC(ASSET_TYPE_MAP_ENTS, m_map_ents, MapEnts);
|
||||
// CASE_INIT_POOL_DYNAMIC(ASSET_TYPE_FXWORLD, m_fx_world, FxWorld);
|
||||
// CASE_INIT_POOL_DYNAMIC(ASSET_TYPE_GFXWORLD, m_gfx_world, GfxWorld);
|
||||
CASE_INIT_POOL_DYNAMIC(ASSET_TYPE_LIGHT_DEF, m_gfx_light_def, GfxLightDef);
|
||||
@@ -297,12 +297,12 @@ XAssetInfoGeneric* GameAssetPoolIW4::AddAsset(asset_type_t type, std::string nam
|
||||
CASE_ADD_TO_POOL(ASSET_TYPE_SOUND, m_sound, sound);
|
||||
CASE_ADD_TO_POOL(ASSET_TYPE_SOUND_CURVE, m_sound_curve, sndCurve);
|
||||
CASE_ADD_TO_POOL(ASSET_TYPE_LOADED_SOUND, m_loaded_sound, loadSnd);
|
||||
// CASE_ADD_TO_POOL(ASSET_TYPE_CLIPMAP_SP, m_clip_map, clipMap);
|
||||
// CASE_ADD_TO_POOL(ASSET_TYPE_CLIPMAP_MP, m_clip_map, clipMap);
|
||||
CASE_ADD_TO_POOL(ASSET_TYPE_CLIPMAP_SP, m_clip_map, clipMap);
|
||||
CASE_ADD_TO_POOL(ASSET_TYPE_CLIPMAP_MP, m_clip_map, clipMap);
|
||||
// CASE_ADD_TO_POOL(ASSET_TYPE_COMWORLD, m_com_world, comWorld);
|
||||
// CASE_ADD_TO_POOL(ASSET_TYPE_GAMEWORLD_SP, m_game_world_sp, gameWorldSp);
|
||||
// CASE_ADD_TO_POOL(ASSET_TYPE_GAMEWORLD_MP, m_game_world_mp, gameWorldMp);
|
||||
// CASE_ADD_TO_POOL(ASSET_TYPE_MAP_ENTS, m_map_ents, mapEnts);
|
||||
CASE_ADD_TO_POOL(ASSET_TYPE_MAP_ENTS, m_map_ents, mapEnts);
|
||||
// CASE_ADD_TO_POOL(ASSET_TYPE_FXWORLD, m_fx_world, fxWorld);
|
||||
// CASE_ADD_TO_POOL(ASSET_TYPE_GFXWORLD, m_gfx_world, gfxWorld);
|
||||
CASE_ADD_TO_POOL(ASSET_TYPE_LIGHT_DEF, m_gfx_light_def, lightDef);
|
||||
@@ -357,12 +357,12 @@ XAssetInfoGeneric* GameAssetPoolIW4::GetAsset(const asset_type_t type, std::stri
|
||||
CASE_GET_ASSET(ASSET_TYPE_SOUND, m_sound);
|
||||
CASE_GET_ASSET(ASSET_TYPE_SOUND_CURVE, m_sound_curve);
|
||||
CASE_GET_ASSET(ASSET_TYPE_LOADED_SOUND, m_loaded_sound);
|
||||
// CASE_GET_ASSET(ASSET_TYPE_CLIPMAP_SP, m_clip_map);
|
||||
// CASE_GET_ASSET(ASSET_TYPE_CLIPMAP_MP, m_clip_map);
|
||||
CASE_GET_ASSET(ASSET_TYPE_CLIPMAP_SP, m_clip_map);
|
||||
CASE_GET_ASSET(ASSET_TYPE_CLIPMAP_MP, m_clip_map);
|
||||
// CASE_GET_ASSET(ASSET_TYPE_COMWORLD, m_com_world);
|
||||
// CASE_GET_ASSET(ASSET_TYPE_GAMEWORLD_SP, m_game_world_sp);
|
||||
// CASE_GET_ASSET(ASSET_TYPE_GAMEWORLD_MP, m_game_world_mp);
|
||||
// CASE_GET_ASSET(ASSET_TYPE_MAP_ENTS, m_map_ents);
|
||||
CASE_GET_ASSET(ASSET_TYPE_MAP_ENTS, m_map_ents);
|
||||
// CASE_GET_ASSET(ASSET_TYPE_FXWORLD, m_fx_world);
|
||||
// CASE_GET_ASSET(ASSET_TYPE_GFXWORLD, m_gfx_world);
|
||||
CASE_GET_ASSET(ASSET_TYPE_LIGHT_DEF, m_gfx_light_def);
|
||||
|
@@ -28,11 +28,11 @@ public:
|
||||
std::unique_ptr<AssetPool<IW4::snd_alias_list_t>> m_sound;
|
||||
std::unique_ptr<AssetPool<IW4::SndCurve>> m_sound_curve;
|
||||
std::unique_ptr<AssetPool<IW4::LoadedSound>> m_loaded_sound;
|
||||
// std::unique_ptr<AssetPool<IW4::clipMap_t>> m_clip_map;
|
||||
std::unique_ptr<AssetPool<IW4::clipMap_t>> m_clip_map;
|
||||
// std::unique_ptr<AssetPool<IW4::ComWorld>> m_com_world;
|
||||
// std::unique_ptr<AssetPool<IW4::GameWorldSp>> m_game_world_sp;
|
||||
// std::unique_ptr<AssetPool<IW4::GameWorldMp>> m_game_world_mp;
|
||||
// std::unique_ptr<AssetPool<IW4::MapEnts>> m_map_ents;
|
||||
std::unique_ptr<AssetPool<IW4::MapEnts>> m_map_ents;
|
||||
// std::unique_ptr<AssetPool<IW4::FxWorld>> m_fx_world;
|
||||
// std::unique_ptr<AssetPool<IW4::GfxWorld>> m_gfx_world;
|
||||
std::unique_ptr<AssetPool<IW4::GfxLightDef>> m_gfx_light_def;
|
||||
|
@@ -87,11 +87,11 @@ namespace IW4
|
||||
struct snd_alias_list_t;
|
||||
struct SndCurve;
|
||||
struct LoadedSound;
|
||||
// struct clipMap_t;
|
||||
struct clipMap_t;
|
||||
// struct ComWorld;
|
||||
// struct GameWorldSp;
|
||||
// struct GameWorldMp;
|
||||
// struct MapEnts;
|
||||
struct MapEnts;
|
||||
// struct FxWorld;
|
||||
// struct GfxWorld;
|
||||
struct GfxLightDef;
|
||||
@@ -127,11 +127,11 @@ namespace IW4
|
||||
snd_alias_list_t* sound;
|
||||
SndCurve* sndCurve;
|
||||
LoadedSound* loadSnd;
|
||||
// clipMap_t* clipMap;
|
||||
clipMap_t* clipMap;
|
||||
// ComWorld* comWorld;
|
||||
// GameWorldSp* gameWorldSp;
|
||||
// GameWorldMp* gameWorldMp;
|
||||
// MapEnts* mapEnts;
|
||||
MapEnts* mapEnts;
|
||||
// FxWorld* fxWorld;
|
||||
// GfxWorld* gfxWorld;
|
||||
GfxLightDef* lightDef;
|
||||
@@ -1788,6 +1788,279 @@ namespace IW4
|
||||
StructuredDataDef* defs;
|
||||
};
|
||||
|
||||
struct TriggerModel
|
||||
{
|
||||
int contents;
|
||||
unsigned __int16 hullCount;
|
||||
unsigned __int16 firstHull;
|
||||
};
|
||||
|
||||
struct TriggerHull
|
||||
{
|
||||
Bounds bounds;
|
||||
int contents;
|
||||
unsigned __int16 slabCount;
|
||||
unsigned __int16 firstSlab;
|
||||
};
|
||||
|
||||
struct TriggerSlab
|
||||
{
|
||||
float dir[3];
|
||||
float midPoint;
|
||||
float halfSize;
|
||||
};
|
||||
|
||||
struct MapTriggers
|
||||
{
|
||||
unsigned int count;
|
||||
TriggerModel* models;
|
||||
unsigned int hullCount;
|
||||
TriggerHull* hulls;
|
||||
unsigned int slabCount;
|
||||
TriggerSlab* slabs;
|
||||
};
|
||||
|
||||
struct Stage
|
||||
{
|
||||
const char* name;
|
||||
float origin[3];
|
||||
unsigned __int16 triggerIndex;
|
||||
char sunPrimaryLightIndex;
|
||||
};
|
||||
|
||||
struct MapEnts
|
||||
{
|
||||
const char* name;
|
||||
char* entityString;
|
||||
int numEntityChars;
|
||||
MapTriggers trigger;
|
||||
Stage* stages;
|
||||
char stageCount;
|
||||
};
|
||||
|
||||
typedef unsigned short LeafBrush;
|
||||
|
||||
struct cStaticModel_s
|
||||
{
|
||||
XModel* xmodel;
|
||||
float origin[3];
|
||||
float invScaledAxis[3][3];
|
||||
Bounds absBounds;
|
||||
};
|
||||
|
||||
struct ClipMaterial
|
||||
{
|
||||
const char* name;
|
||||
int surfaceFlags;
|
||||
int contents;
|
||||
};
|
||||
|
||||
struct cNode_t
|
||||
{
|
||||
cplane_s* plane;
|
||||
__int16 children[2];
|
||||
};
|
||||
|
||||
struct cLeafBrushNodeLeaf_t
|
||||
{
|
||||
LeafBrush* brushes;
|
||||
};
|
||||
|
||||
struct cLeafBrushNodeChildren_t
|
||||
{
|
||||
float dist;
|
||||
float range;
|
||||
unsigned __int16 childOffset[2];
|
||||
};
|
||||
|
||||
union cLeafBrushNodeData_t
|
||||
{
|
||||
cLeafBrushNodeLeaf_t leaf;
|
||||
cLeafBrushNodeChildren_t children;
|
||||
};
|
||||
|
||||
struct cLeafBrushNode_s
|
||||
{
|
||||
char axis;
|
||||
__int16 leafBrushCount;
|
||||
int contents;
|
||||
cLeafBrushNodeData_t data;
|
||||
};
|
||||
|
||||
struct CollisionBorder
|
||||
{
|
||||
float distEq[3];
|
||||
float zBase;
|
||||
float zSlope;
|
||||
float start;
|
||||
float length;
|
||||
};
|
||||
|
||||
struct CollisionPartition
|
||||
{
|
||||
char triCount;
|
||||
char borderCount;
|
||||
char firstVertSegment;
|
||||
int firstTri;
|
||||
CollisionBorder* borders;
|
||||
};
|
||||
|
||||
union CollisionAabbTreeIndex
|
||||
{
|
||||
int firstChildIndex;
|
||||
int partitionIndex;
|
||||
};
|
||||
|
||||
struct __declspec(align(16)) CollisionAabbTree
|
||||
{
|
||||
float midPoint[3];
|
||||
unsigned __int16 materialIndex;
|
||||
unsigned __int16 childCount;
|
||||
float halfSize[3];
|
||||
CollisionAabbTreeIndex u;
|
||||
};
|
||||
|
||||
struct cLeaf_t
|
||||
{
|
||||
unsigned __int16 firstCollAabbIndex;
|
||||
unsigned __int16 collAabbCount;
|
||||
int brushContents;
|
||||
int terrainContents;
|
||||
Bounds bounds;
|
||||
int leafBrushNode;
|
||||
};
|
||||
|
||||
struct cmodel_t
|
||||
{
|
||||
Bounds bounds;
|
||||
float radius;
|
||||
cLeaf_t leaf;
|
||||
};
|
||||
|
||||
struct cbrush_t
|
||||
{
|
||||
unsigned __int16 numsides;
|
||||
unsigned __int16 glassPieceIndex;
|
||||
cbrushside_t* sides;
|
||||
char* baseAdjacentSide;
|
||||
__int16 axialMaterialNum[2][3];
|
||||
char firstAdjacentSideOffsets[2][3];
|
||||
char edgeCount[2][3];
|
||||
};
|
||||
|
||||
struct SModelAabbNode
|
||||
{
|
||||
Bounds bounds;
|
||||
unsigned __int16 firstChild;
|
||||
unsigned __int16 childCount;
|
||||
};
|
||||
|
||||
struct GfxPlacement
|
||||
{
|
||||
float quat[4];
|
||||
float origin[3];
|
||||
};
|
||||
|
||||
enum DynEntityType
|
||||
{
|
||||
DYNENT_TYPE_INVALID = 0x0,
|
||||
DYNENT_TYPE_CLUTTER = 0x1,
|
||||
DYNENT_TYPE_DESTRUCT = 0x2,
|
||||
DYNENT_TYPE_COUNT = 0x3,
|
||||
};
|
||||
|
||||
struct DynEntityDef
|
||||
{
|
||||
DynEntityType type;
|
||||
GfxPlacement pose;
|
||||
XModel* xModel;
|
||||
unsigned __int16 brushModel;
|
||||
unsigned __int16 physicsBrushModel;
|
||||
FxEffectDef* destroyFx;
|
||||
PhysPreset* physPreset;
|
||||
int health;
|
||||
PhysMass mass;
|
||||
int contents;
|
||||
};
|
||||
|
||||
struct DynEntityPose
|
||||
{
|
||||
GfxPlacement pose;
|
||||
float radius;
|
||||
};
|
||||
|
||||
struct DynEntityClient
|
||||
{
|
||||
int physObjId;
|
||||
unsigned __int16 flags;
|
||||
unsigned __int16 lightingHandle;
|
||||
int health;
|
||||
};
|
||||
|
||||
struct DynEntityColl
|
||||
{
|
||||
unsigned __int16 sector;
|
||||
unsigned __int16 nextEntInSector;
|
||||
float linkMins[2];
|
||||
float linkMaxs[2];
|
||||
};
|
||||
|
||||
typedef __declspec(align(128)) cbrush_t cbrush_array_t;
|
||||
typedef __declspec(align(128)) Bounds BoundsArray;
|
||||
|
||||
struct clipMap_t
|
||||
{
|
||||
const char* name;
|
||||
int isInUse;
|
||||
int planeCount;
|
||||
cplane_s* planes;
|
||||
unsigned int numStaticModels;
|
||||
cStaticModel_s* staticModelList;
|
||||
unsigned int numMaterials;
|
||||
ClipMaterial* materials;
|
||||
unsigned int numBrushSides;
|
||||
cbrushside_t* brushsides;
|
||||
unsigned int numBrushEdges;
|
||||
cbrushedge_t* brushEdges;
|
||||
unsigned int numNodes;
|
||||
cNode_t* nodes;
|
||||
unsigned int numLeafs;
|
||||
cLeaf_t* leafs;
|
||||
unsigned int leafbrushNodesCount;
|
||||
cLeafBrushNode_s* leafbrushNodes;
|
||||
unsigned int numLeafBrushes;
|
||||
LeafBrush* leafbrushes;
|
||||
unsigned int numLeafSurfaces;
|
||||
unsigned int* leafsurfaces;
|
||||
unsigned int vertCount;
|
||||
vec3_t* verts;
|
||||
int triCount;
|
||||
unsigned __int16* triIndices;
|
||||
char* triEdgeIsWalkable;
|
||||
int borderCount;
|
||||
CollisionBorder* borders;
|
||||
int partitionCount;
|
||||
CollisionPartition* partitions;
|
||||
int aabbTreeCount;
|
||||
CollisionAabbTree* aabbTrees;
|
||||
unsigned int numSubModels;
|
||||
cmodel_t* cmodels;
|
||||
unsigned __int16 numBrushes;
|
||||
cbrush_array_t* brushes;
|
||||
BoundsArray* brushBounds;
|
||||
int* brushContents;
|
||||
MapEnts* mapEnts;
|
||||
unsigned __int16 smodelNodeCount;
|
||||
SModelAabbNode* smodelNodes;
|
||||
unsigned __int16 dynEntCount[2];
|
||||
DynEntityDef* dynEntDefList[2];
|
||||
DynEntityPose* dynEntPoseList[2];
|
||||
DynEntityClient* dynEntClientList[2];
|
||||
DynEntityColl* dynEntCollList[2];
|
||||
unsigned int checksum;
|
||||
char padding[48];
|
||||
};
|
||||
|
||||
#ifndef __zonecodegenerator
|
||||
}
|
||||
#endif
|
||||
|
Reference in New Issue
Block a user