Open Source Tomb Raider Engine
Du kannst nicht mehr als 25 Themen auswählen Themen müssen mit entweder einem Buchstaben oder einer Ziffer beginnen. Sie können Bindestriche („-“) enthalten und bis zu 35 Zeichen lang sein.

TombRaider.h 96KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769
  1. /* -*- Mode: C++; tab-width: 3; indent-tabs-mode: t; c-basic-offset: 3 -*- */
  2. /*================================================================
  3. *
  4. * Project : OpenRaider
  5. * Author : Mongoose
  6. * Website : http://www.westga.edu/~stu7440/
  7. * Email : stu7440@westga.edu
  8. * Object : OpenRaider
  9. * License : GPL, See file COPYING for details
  10. * Comments: Loads TR 1, 2, 3, and 4 maps, meshes, and textures
  11. *
  12. * WARNING: No endian routines as of yet
  13. *
  14. * Define ZLIB_SUPPORT to build TR4 support
  15. *
  16. * This file was generated using Mongoose's C++
  17. * template generator script. <stu7440@westga.edu>
  18. *
  19. *-- History ------------------------------------------------
  20. *
  21. * 2003.05.13:
  22. * Mongoose - New API, maintance cost was becoming so high
  23. * it was needed to sort out methods in groups
  24. * like my newer source code -- of course some
  25. * methods were altered or removed ( clean up )
  26. *
  27. * 2003.05.19:
  28. * Mongoose - I'm now using Roy's documented TR5 structures, so
  29. * I can fill in my blanks and share common structures
  30. * with other TR5 pak loaders using it - I've removed
  31. * most of my old TR5 test code - it may have been more
  32. * correct for DX lights ( not sure ) it's still in CVS
  33. *
  34. * 2003.05.13:
  35. * Mongoose - New API, maintance cost was becoming so high
  36. * it was needed to sort out methods in groups
  37. * like my newer source code -- of course some
  38. * methods were altered or removed ( clean up )
  39. *
  40. * 2001.06.19:
  41. * Mongoose - New texture API for the new TR4/TR5 bump map
  42. * support, also purged textile exposure
  43. *
  44. *
  45. * 2001.05.21:
  46. * Mongoose - Added to project OpenRaider, more documentation
  47. * than Freyja version I wrote ( 3d modeler )
  48. *
  49. * TR4 texel and texture fixes
  50. *
  51. * Runtime debug output toggle
  52. *
  53. *
  54. * 2000.05.13:
  55. * Mongoose - Added gcc and VC++ pragmas for packing
  56. *
  57. * id style typedefs for structs
  58. *
  59. * Heavy clean up and ported to C++
  60. *
  61. * I saved yuri's notes as best I could and
  62. * reformatted and corrected as needed.
  63. *
  64. * Mongoose - Created, based on:
  65. * tr_view's tr2io.c by Yuri Zhivago, PhD,
  66. * TR Rosetta Stone ( TombRaider pak format specs )
  67. ================================================================*/
  68. #ifndef _TOMBRAIDER_H_
  69. #define _TOMBRAIDER_H_
  70. #ifdef WIN32
  71. // Have to remove GCC packing, by removing in preprocessor
  72. #define __attribute__(packed)
  73. // MSVC++ pragma to pack structs
  74. #define TR2_H 1
  75. #pragma pack(push, tr2_h, 1)
  76. #endif
  77. //#include "TombRaider1.h"
  78. typedef enum
  79. {
  80. TR_VERSION_UNKNOWN,
  81. TR_VERSION_1,
  82. TR_VERSION_2,
  83. TR_VERSION_3,
  84. TR_VERSION_4,
  85. TR_VERSION_5
  86. } tr2_version_type;
  87. typedef enum
  88. {
  89. TR_FREAD_NORMAL = 0,
  90. TR_FREAD_COMPRESSED
  91. } tr_fread_mode_t;
  92. typedef enum
  93. {
  94. tombraiderLight_typeDirectional = 1,
  95. tombraiderLight_typeSpot = 2,
  96. tombraiderLight_typePoint = 3
  97. } tombraiderLightType;
  98. typedef enum
  99. {
  100. tombraiderLight_useCutoff = 1,
  101. tombraiderLight_useAttenuation = 2
  102. } tombraiderLightFlags;
  103. typedef enum
  104. {
  105. tombraiderRoom_underWater = 1
  106. } tombraiderRoomFlags;
  107. typedef enum
  108. {
  109. tombraiderSector_wall = 1
  110. } tombraiderSectorFlags;
  111. typedef enum
  112. {
  113. tombraiderFace_Alpha = 1,
  114. tombraiderFace_Colored = 2,
  115. tombraiderFace_PartialAlpha = 4
  116. } tombraiderFace_Flags;
  117. #define TR_SOUND_FOOTSTEP0 1
  118. #define TR_SOUND_F_PISTOL 12
  119. enum TR4_Objects
  120. {
  121. TR4_LARA = 0,
  122. TR4_PISTOLS_ANIM = 1,
  123. TR4_UZI_ANIM = 2,
  124. TR4_SHOTGUN_ANIM = 3,
  125. TR4_CROSSBOW_ANIM = 4,
  126. TR4_GRENADE_GUN_ANIM = 5,
  127. TR4_SIXSHOOTER_ANIM = 6,
  128. TR4_FLARE_ANIM = 7,
  129. TR4_LARA_SKIN = 8,
  130. TR4_LARA_SKIN_JOINTS = 9,
  131. TR4_LARA_SCREAM = 10,
  132. TR4_LARA_CROSSBOW_LASER = 11,
  133. TR4_LARA_REVOLVER_LASER = 12,
  134. TR4_LARA_HOLSTERS = 13,
  135. TR4_LARA_HOLSTERS_PISTOLS = 14,
  136. TR4_LARA_HOLSTERS_UZIS = 15,
  137. TR4_LARA_HOLSTERS_SIXSHOOTER = 16,
  138. TR4_LARA_SPEECH_HEAD1 = 17,
  139. TR4_LARA_SPEECH_HEAD2 = 18,
  140. TR4_LARA_SPEECH_HEAD3 = 19,
  141. TR4_LARA_SPEECH_HEAD4 = 20
  142. };
  143. #define TR_ANIAMTION_RUN 0
  144. #define TR_ANIAMTION_STAND 11
  145. #define TR_ANIAMTION_TURN_L 12
  146. #define TR_ANIAMTION_TURN_R 13
  147. #define TR_ANIAMTION_HIT_WALL_FRONT 53
  148. #define TR_ANIAMTION_SWIM_IDLE 87
  149. #define TR_ANIAMTION_SWIM 86
  150. #define TR_ANIAMTION_SWIM_L 143
  151. #define TR_ANIAMTION_SWIM_R 144
  152. #define TR_ANIAMTION_GRAB_LEDGE 96
  153. #define TR_ANIAMTION_PULLING_UP 97
  154. /*---------------------------------------------------------------
  155. * Basic 24-bit colour structure
  156. * (although it appears that only 6 bits
  157. * per colour are actually used, making it 18-bit colour)
  158. ---------------------------------------------------------------*/
  159. typedef struct tr2_colour_s
  160. {
  161. unsigned char r;
  162. unsigned char g;
  163. unsigned char b;
  164. } __attribute__ ((packed)) tr2_colour_t;
  165. /*--------------------------------------------------------------
  166. * Basic vertex structure.
  167. * Note that all vertices are relative coordinates;
  168. * each mesh (room, object, etc.) has its own offset by
  169. * which the vertex coordinates are translated.
  170. --------------------------------------------------------------*/
  171. typedef struct tr2_vertex_s
  172. {
  173. short x;
  174. short y;
  175. short z;
  176. } __attribute__ ((packed)) tr2_vertex_t;
  177. /*--------------------------------------------------------------
  178. * A rectangular (quad) face definition.
  179. * Four vertices (the values are indices into the
  180. * appropriate vertex list) and a texture (an index
  181. * into the texture list) or colour (index into 8-bit palette).
  182. *
  183. * I've seen a few coloured polygons where Texture is
  184. * greater than 255, but ANDing the value with 0xFF
  185. * seems to produce acceptable results.
  186. --------------------------------------------------------------*/
  187. typedef struct tr2_quad_s /* was tr2_face4 */
  188. {
  189. unsigned short vertices[4];
  190. unsigned short texture;
  191. } __attribute__ ((packed)) tr2_quad_t;
  192. typedef struct tr4_quad_s
  193. {
  194. unsigned short vertices[4]; // The 4 vertices of a quad
  195. unsigned short texture; // Object-texture index
  196. unsigned short lighting; // transparency flag & strength of
  197. // the hilight
  198. // Bit 0: if set, alpha channel = intensity (same meaning that when the Attribute field of tr2_object_texture is 2. Cf TRosetta stone document)
  199. // Bit 1-7: strength of the hilight. In TR4, objects can exhibit some kind of light reflection when seen from some particular angles. These bits give the strength of this effect: the more bigger the value is, the more visible is the effect.
  200. } __attribute__ ((packed)) tr4_quad_t;
  201. /*--------------------------------------------------------------
  202. * A triangular face definition.
  203. * Three vertices (the values are indices into the
  204. * appropriate vertex list) and a texture (an index into the
  205. * texture list) or colour (index into palette).
  206. *
  207. * In the case of a colour, (Texture & 0xff) is the index
  208. * into the 8-bit palette, while (Texture >> 8) is
  209. * the index into the 16-bit palette.
  210. --------------------------------------------------------------*/
  211. typedef struct tr2_tri_s /* was tr2_face3 */
  212. {
  213. unsigned short vertices[3];
  214. unsigned short texture;
  215. } __attribute__ ((packed)) tr2_tri_t;
  216. typedef struct tr4_tri_s
  217. {
  218. unsigned short vertices[3]; // The 3 vertices of a tri
  219. unsigned short texture; // Object-texture index
  220. unsigned short lighting; // transparency flag & strength of
  221. // the hilight
  222. } __attribute__ ((packed)) tr4_tri_t;
  223. /*--------------------------------------------------------------
  224. * An 8-bit texture tile (65536 bytes).
  225. *
  226. * Each byte represents a pixel whose colour
  227. * is in the 8-bit palette.
  228. --------------------------------------------------------------*/
  229. typedef struct tr2_textile8_s
  230. {
  231. unsigned char tile[256 * 256];
  232. } __attribute__ ((packed)) tr2_textile8_t;
  233. /*--------------------------------------------------------------
  234. * A 16-bit texture tile (131072 bytes).
  235. *
  236. * Each word represents a pixel
  237. * whose colour is of the form ARGB, MSB-to-LSB:
  238. *
  239. * 1-bit transparency (0: transparent, 1: opaque)
  240. * 5-bit red channel
  241. * 5-bit green channel
  242. * 5-bit blue channel
  243. --------------------------------------------------------------*/
  244. typedef struct tr2_textile16_s
  245. {
  246. unsigned short tile[256 * 256];
  247. } __attribute__ ((packed)) tr2_textile16_t;
  248. /* --------------------------------------------------------------
  249. * 32bit textiles
  250. * BGRA with 4bytes each channel
  251. --------------------------------------------------------------*/
  252. typedef struct tr2_textile32_s
  253. {
  254. unsigned int tile[256 * 256];
  255. } __attribute__ ((packed)) tr2_textile32_t;
  256. /*--------------------------------------------------------------
  257. * The "header" of a room.
  258. * + X/Z indicate the base position of the room
  259. * mesh in world coordinates.
  260. * + YLowest and yHighest indicate the lowest and
  261. * + Highest points in this room
  262. * (even though their actual values appear to
  263. * be reversed, since a "high" point will have a
  264. * smaller value than a "low" point).
  265. *
  266. * When positioning objects/items, as well as the room meshes
  267. * themselves, y is always 0-relative (not room-relative).
  268. --------------------------------------------------------------*/
  269. typedef struct tr2_room_info_s
  270. {
  271. int x; // X-offset of room (world coordinates)
  272. int z; // Z-offset of room (world coordinates)
  273. int y_bottom; // Y-offset of lowest point in room (world coordinates)
  274. // (actually highest value)
  275. int y_top; // Y-offset of highest point in room (world coordinates)
  276. // (actually lowest value)
  277. } __attribute__ ((packed)) tr2_room_info_t;
  278. /*--------------------------------------------------------------
  279. * Portal structure.
  280. * This defines every viable exit from a given "room".
  281. *
  282. * Note that "rooms" are really just areas. They aren't
  283. * necessarily enclosed. The door structure below defines
  284. * areas of egress, not the actual moveable mesh,
  285. * texture, and action (if any).
  286. --------------------------------------------------------------*/
  287. typedef struct tr2_room_portal_s
  288. {
  289. unsigned short adjoining_room; // Which room this "door" leads to
  290. tr2_vertex_t normal; // Which way the "door" faces
  291. tr2_vertex_t vertices[4]; // The corners of the "door"
  292. } __attribute__ ((packed)) tr2_room_portal_t;
  293. /*--------------------------------------------------------------
  294. * Room sector structure.
  295. *
  296. * Sectors are 1024 * 1024 (world coordinates). Floor and
  297. * Ceiling are signed number of 256 units of height
  298. * (relative to 0), e.g. Floor 0x04 corresponds to
  299. * Y = 1024 in world coordinates.
  300. *
  301. * Note: this implies that, while X and Z can be quite large,
  302. * Y is constrained to -32768..32512. Floor/Ceiling value of
  303. * 0x81 indicates impenetrable wall.
  304. *
  305. * Floor values are used by the game engine to determine what
  306. * objects Lara can traverse and how.
  307. *
  308. * Relative steps of 1 (-256) can be walked up;
  309. * steps of 2..7 (-512..-1792) can/must be climbed;
  310. * steps larger than 7 (-2048..-32768) cannot be climbed (too tall)
  311. *
  312. * In TR3, BoxIndex is more complicated. Only bits 4-14 are the
  313. * "real" index; bits 0-3 are most likely some kind of flag,
  314. * such as what kind of footstep sound to make (wood, metal, snow).
  315. * Furthermore, there is a special value of the "real" index,
  316. * 2047, or 0x7ff.
  317. *
  318. * RoomAbove and RoomBelow indicate what neighboring rooms are
  319. * in these directions; if RoomAbove is not "none", then the
  320. * ceiling is a collisional portal to that room, while if
  321. * RoomBelow is not "none", then the floor is a collisional
  322. * portal to that room.
  323. --------------------------------------------------------------*/
  324. typedef struct tr2_room_sector_s
  325. {
  326. unsigned short fd_index; // Index into FloorData[]
  327. unsigned short box_index; // Index into Boxes[]/Zones[] ( -1 if none )
  328. unsigned char room_below; // The number of the room below this one
  329. // ( -1 or 255 if none )
  330. char floor; // Absolute height of floor
  331. // ( Multiply by 256 for world coordinates )
  332. unsigned char room_above; // The number of the room above this one
  333. // ( -1 or 255 if none )
  334. char ceiling; // Absolute height of ceiling
  335. // ( Multiply by 256 for world coordinates )
  336. } __attribute__ ((packed)) tr2_room_sector_t;
  337. /*--------------------------------------------------------------
  338. * Room lighting structure.
  339. * X/Y/Z are in world coordinates.
  340. * Lighting values seem to range from 0..8192.
  341. --------------------------------------------------------------*/
  342. typedef struct tr2_room_light_s
  343. {
  344. int x;
  345. int y;
  346. int z;
  347. unsigned short intensity1;
  348. unsigned short intensity2;
  349. unsigned int fade1;
  350. unsigned int fade2;
  351. } __attribute__ ((packed)) tr2_room_light_t;
  352. typedef struct tr4_room_light_s
  353. {
  354. int xPosition; // world coords
  355. int yPosition; // world coords
  356. int zPosition; // world coords
  357. tr2_colour_t color; // three bytes rgb values
  358. unsigned char lightType; // same as D3D (i.e. 2 is for spotlight)
  359. unsigned char unknown; // always 0xff?
  360. unsigned char intensity;
  361. float in;
  362. float out;
  363. float length;
  364. float cutoff;
  365. float xDir, yDir, zDir; // direction?
  366. } __attribute__ ((packed)) tr4_room_light_t;
  367. /*--------------------------------------------------------------
  368. * Room vertex structure.
  369. * This defines the vertices within a room.
  370. --------------------------------------------------------------*/
  371. typedef struct tr2_vertex_room_s
  372. {
  373. tr2_vertex_t vertex;
  374. // Following 3 entries
  375. short lighting1; // Values range from 0 to 32767,
  376. // 0 = total darkness. (TR3)
  377. // I think the values ranged from
  378. // 0 to 8192 in TR1/2, 0=total brightness
  379. unsigned short attributes; // 0x8000 Something to do with water surface
  380. // 0x4000 Under water lighting modulation
  381. // and movement if viewed from
  382. // above water surface
  383. // 0x2000 Water/quicksand surface movement
  384. // 0x1fef Nothing?
  385. // 0x0010 Everything?
  386. short lighting2; // Seems to be the same as lighting1
  387. } __attribute__ ((packed)) tr2_vertex_room_t;
  388. /*--------------------------------------------------------------
  389. * Sprite structure
  390. --------------------------------------------------------------*/
  391. typedef struct tr2_room_sprite_s
  392. {
  393. short vertex; // offset into vertex list
  394. short texture; // offset into texture list
  395. } __attribute__ ((packed)) tr2_room_sprite_t;
  396. /*--------------------------------------------------------------
  397. * Room mesh structure.
  398. * This is the geometry of the "room," including
  399. * walls, floors, rocks, water, etc. It does _not_ include
  400. * objects that Lara can interact with (keyboxes,
  401. * moveable blocks, moveable doors, etc.)
  402. --------------------------------------------------------------*/
  403. typedef struct tr2_room_data_s
  404. {
  405. short num_vertices; // number of vertices in the following list
  406. tr2_vertex_room_t *vertices; // list of vertices (relative coordinates)
  407. short num_rectangles; // number of textured rectangles
  408. tr2_quad_t *rectangles; // list of textured rectangles
  409. short num_triangles; // number of textured triangles
  410. tr2_tri_t *triangles; // list of textured triangles
  411. short num_sprites; // number of sprites
  412. tr2_room_sprite_t *sprites; // list of sprites
  413. } __attribute__ ((packed)) tr2_room_data_t;
  414. /*--------------------------------------------------------------
  415. * Room static mesh data.
  416. * Positions and IDs of static meshes
  417. * (e.g. skeletons, spiderwebs, furniture)
  418. --------------------------------------------------------------*/
  419. typedef struct tr2_room_staticmesh_s
  420. {
  421. int x; // absolute position in world coordinates
  422. int y;
  423. int z;
  424. unsigned short rotation; // high two bits (0xc000)
  425. // indicate steps of 90 degrees
  426. unsigned short intensity1;
  427. unsigned short intensity2;
  428. unsigned short object_id; // which StaticMesh item to draw
  429. } __attribute__ ((packed)) tr2_room_staticmesh_t;
  430. /*--------------------------------------------------------------
  431. * Room structure.
  432. * Here's where all the room data come together.
  433. --------------------------------------------------------------*/
  434. typedef struct tr2_room_s
  435. {
  436. tr2_room_info_t info; // where the room exists, in world coordinates
  437. unsigned int num_data_words; // number of data words (bitu16)
  438. unsigned char *data; // the raw data from which the rest
  439. // of this is derived
  440. tr2_room_data_t room_data; // the room mesh
  441. unsigned short num_portals; // number of visibility portals
  442. // that leave this room
  443. tr2_room_portal_t *portals; // list of visibility portals
  444. unsigned short num_zsectors; // width of sector list
  445. unsigned short num_xsectors; // height of sector list
  446. tr2_room_sector_t *sector_list;// list of sectors in this room
  447. short intensity1;
  448. short intensity2;
  449. short light_mode;
  450. unsigned short num_lights; // number of lights in this room
  451. tr2_room_light_t *lights; // list of lights
  452. unsigned short num_static_meshes; // number of static meshes
  453. tr2_room_staticmesh_t *static_meshes; // static meshes
  454. short alternate_room;
  455. short flags; // 0x0001 - room is filled with water
  456. // 0x0020 - Lara's ponytail
  457. // gets blown by the wind
  458. tr2_colour_t room_light_colour; // TR3 ONLY!
  459. tr4_room_light_t *tr4Lights; // TR4 ONLY!
  460. } __attribute__ ((packed)) tr2_room_t;
  461. /*--------------------------------------------------------------
  462. * Animation structure.
  463. --------------------------------------------------------------*/
  464. typedef struct tr2_animation_s
  465. {
  466. unsigned int frame_offset; // byte offset into Frames[]
  467. // (divide by 2 for Frames[i])
  468. unsigned char frame_rate; // "ticks" per frame
  469. unsigned char frame_size; // number of words in Frames[]
  470. // used by this animation
  471. short state_id;
  472. short unknown1;
  473. short unknown2;
  474. short unknown3;
  475. short unknown4;
  476. unsigned short frame_start; // first frame in this animation
  477. unsigned short frame_end; // last frame in this animation
  478. // (numframes = (End - Start) + 1)
  479. unsigned short next_animation;
  480. unsigned short next_frame;
  481. unsigned short num_state_changes;
  482. unsigned short state_change_offset; // offset into StateChanges[]
  483. unsigned short num_anim_commands;
  484. unsigned short anim_command; // offset into AnimCommands[]
  485. } __attribute__ ((packed)) tr2_animation_t;
  486. // Data for an animation structure (40 bytes vice 32 in TR1/2/3)
  487. typedef struct tr4_animation_s
  488. {
  489. unsigned int frame_offset;// same meaning than in TR3
  490. unsigned char frame_rate;// same meaning than in TR3
  491. unsigned char frame_size;// same meaning than in TR3
  492. unsigned short state_id;// same meaning than in TR3
  493. short unknown;// same meaning than in TR3
  494. short speed;// same meaning than in TR3
  495. unsigned short accel_lo;// same meaning than in TR3
  496. short accel_hi;// same meaning than in TR3
  497. unsigned char unknown2[8];// new in TR4
  498. unsigned short frame_start;// same meaning than in TR3
  499. unsigned short frame_end;// same meaning than in TR3
  500. unsigned short next_animation;// same meaning than in TR3
  501. unsigned short next_frame;// same meaning than in TR3
  502. unsigned short num_state_changes;// same meaning than in TR3
  503. unsigned short state_change_offset;// same meaning than in TR3
  504. unsigned short num_anim_commands;// same meaning than in TR3
  505. unsigned short anim_command;// same meaning than in TR3
  506. } __attribute__ ((packed)) tr4_animation_t;
  507. /*--------------------------------------------------------------
  508. * State Change structure
  509. --------------------------------------------------------------*/
  510. typedef struct tr2_state_change_s
  511. {
  512. unsigned short state_id;
  513. unsigned short num_anim_dispatches; // number of dispatches
  514. // (seems to always be 1..5)
  515. unsigned short anim_dispatch; // Offset into AnimDispatches[]
  516. } __attribute__ ((packed)) tr2_state_change_t;
  517. /*--------------------------------------------------------------
  518. * Animation Dispatch structure
  519. --------------------------------------------------------------*/
  520. typedef struct tr2_anim_dispatch_s
  521. {
  522. short low;
  523. short high;
  524. short next_animation;
  525. short next_frame;
  526. } __attribute__ ((packed)) tr2_anim_dispatch_t;
  527. /*--------------------------------------------------------------
  528. * AnimCommand structure
  529. --------------------------------------------------------------*/
  530. typedef struct tr2_anim_command_s
  531. {
  532. short value;
  533. } __attribute__ ((packed)) tr2_anim_command_t;
  534. /*--------------------------------------------------------------
  535. * MeshTree structure
  536. *
  537. * MeshTree[] is actually groups of four ints. The first one is a
  538. * "flags" word; bit 1 (0x0002) indicates "make previous mesh an
  539. * anchor (e.g. PUSH)"; bit 0 (0x0001) indicates "return to previous
  540. * anchor (e.g. POP)".
  541. * The next three ints are X, Y, Z offsets from the last mesh position.
  542. --------------------------------------------------------------*/
  543. typedef struct tr2_meshtree_s
  544. {
  545. int flags; // 0x0001 = POP, 0x0002 = PUSH
  546. int x;
  547. int y;
  548. int z;
  549. } __attribute__ ((packed)) tr2_meshtree_t;
  550. /*--------------------------------------------------------------
  551. * Moveable structure. This defines a list of contiguous meshes that
  552. * comprise one object, e.g. in WALL.TR2,
  553. * moveable[0] = Lara (StartingMesh 0, NumMeshes 15),
  554. * moveable[13] = Tiger (StartingMesh 215, NumMeshes 27)
  555. * moveable[15] = Spikes (StartingMesh 249, NumMeshes 1)
  556. * moveable[16] = Boulder (StartingMesh 250, NumMeshes 1)
  557. * moveable[20] = Rolling Blade (StartingMesh 254, NumMeshes 1)
  558. --------------------------------------------------------------*/
  559. typedef struct tr2_moveable_s
  560. {
  561. unsigned int object_id; // Item Identifier
  562. unsigned short num_meshes; // number of meshes in this object
  563. unsigned short starting_mesh; // first mesh
  564. unsigned int mesh_tree; // offset into MeshTree[]
  565. unsigned int frame_offset; // byte offset into Frames[]
  566. // (divide by 2 for Frames[i])
  567. unsigned short animation; // offset into Animations[]
  568. } __attribute__ ((packed)) tr2_moveable_t;
  569. /*--------------------------------------------------------------
  570. * StaticMesh structure.
  571. *
  572. * This defines meshes that don't move (e.g. skeletons
  573. * lying on the floor, spiderwebs, etc.)
  574. --------------------------------------------------------------*/
  575. typedef struct tr2_staticmesh_s
  576. {
  577. unsigned int object_id; // Item Identifier
  578. unsigned short starting_mesh; // first mesh
  579. tr2_vertex_t bounding_box[2][2];
  580. unsigned short flags;
  581. } __attribute__ ((packed)) tr2_staticmesh_t;
  582. /*--------------------------------------------------------------
  583. * Object texture vertex structure.
  584. *
  585. * Maps coordinates into texture tiles.
  586. --------------------------------------------------------------*/
  587. typedef struct tr2_object_texture_vert_s
  588. {
  589. unsigned char xcoordinate;
  590. unsigned char xpixel;
  591. unsigned char ycoordinate;
  592. unsigned char ypixel;
  593. } __attribute__ ((packed)) tr2_object_texture_vert_t;
  594. /*--------------------------------------------------------------
  595. * Object texture structure.
  596. --------------------------------------------------------------*/
  597. typedef struct tr2_object_texture_s
  598. {
  599. unsigned short transparency_flags; // 0: Opaque
  600. // 1: Use transparency
  601. // 2: Use partial transparency
  602. // [grayscale intensity :: transparency]
  603. unsigned short tile; // index into textile list
  604. tr2_object_texture_vert_t vertices[4]; // the four corners of the texture
  605. } __attribute__ ((packed)) tr2_object_texture_t;
  606. /*--------------------------------------------------------------
  607. * Sprite texture structure.
  608. --------------------------------------------------------------*/
  609. typedef struct tr2_sprite_texture_s
  610. {
  611. unsigned short tile;
  612. unsigned char x;
  613. unsigned char y;
  614. unsigned short width; // actually, (width * 256) + 255
  615. unsigned short height; // actually, (height * 256) + 255
  616. short left_side;
  617. short top_side;
  618. short right_side;
  619. short bottom_side;
  620. } __attribute__ ((packed)) tr2_sprite_texture_t;
  621. /*--------------------------------------------------------------
  622. * Sprite Sequence structure
  623. --------------------------------------------------------------*/
  624. typedef struct tr2_sprite_sequence_s
  625. {
  626. int object_id; // Item identifier (same numbering as in tr2_moveable)
  627. short negative_length; // negative of "how many sprites are in this sequence"
  628. short offset; // where (in sprite texture list) this sequence starts
  629. } __attribute__ ((packed)) tr2_sprite_sequence_t;
  630. /*--------------------------------------------------------------
  631. * Mesh structure.
  632. *
  633. * The mesh list contains the mesh info for Lara (in all her
  634. * various incarnations), blocks, enemies (tigers, birds, bad guys),
  635. * moveable blocks, zip line handles, boulders, spinning blades,
  636. * you name it.
  637. *
  638. * If NumNormals is negative, Normals[] represent vertex
  639. * lighting values (one per vertex).
  640. --------------------------------------------------------------*/
  641. typedef struct tr2_mesh_s
  642. {
  643. tr2_vertex_t centre; // this seems to describe the
  644. // approximate geometric centre
  645. // of the mesh (possibly the centre of gravity?)
  646. // (relative coordinates, just like the vertices)
  647. int collision_size; // radius of collisional sphere
  648. short num_vertices; // number of vertices in this mesh
  649. tr2_vertex_t *vertices; // list of vertices (relative coordinates)
  650. short num_normals; // number of normals in this mesh
  651. // (should always equal NumVertices)
  652. tr2_vertex_t *normals; // list of normals (NULL if NumNormals < 0)
  653. short *mesh_lights; // if NumNormals < 0
  654. short num_textured_rectangles; // number of textured rectangles
  655. tr2_quad_t *textured_rectangles; // list of textured rectangles
  656. short num_textured_triangles; // number of textured triangles in this mesh
  657. tr2_tri_t *textured_triangles; // list of textured triangles
  658. short num_coloured_rectangles; // number of coloured rectangles
  659. tr2_quad_t *coloured_rectangles; // list of coloured rectangles
  660. short num_coloured_triangles; // number of coloured triangles in this mesh
  661. tr2_tri_t *coloured_triangles; // list of coloured triangles
  662. } __attribute__ ((packed)) tr2_mesh_t;
  663. /*--------------------------------------------------------------
  664. * Frame structure.
  665. *
  666. * Frames indicates how composite meshes are positioned and rotated.
  667. * They work in conjunction with Animations[] and Bone2[].
  668. *
  669. * A given frame has the following format:
  670. * short BB1x, BB1y, BB1z // bounding box (low)
  671. * short BB2x, BB2y, BB2z // bounding box (high)
  672. * short OffsetX, OffsetY, OffsetZ // starting offset for this moveable
  673. * (TR1 ONLY: short NumValues // number of angle sets to follow)
  674. * (TR2/3: NumValues is implicitly NumMeshes (from moveable))
  675. *
  676. * What follows next is a list of angle sets. In TR2/3, an angle set can
  677. * specify either one or three axes of rotation. If either of the high two
  678. * bits (0xc000) of the first angle unsigned short are set, it's one axis:
  679. * only one unsigned short,
  680. * low 10 bits (0x03ff),
  681. * scale is 0x100 == 90 degrees;
  682. * the high two bits are interpreted as follows:
  683. * 0x4000 == X only, 0x8000 == Y only,
  684. * 0xC000 == Z only.
  685. *
  686. * If neither of the high bits are set, it's a three-axis rotation. The next
  687. * 10 bits (0x3ff0) are the X rotation, the next 10 (including the following
  688. * unsigned short) (0x000f, 0xfc00) are the Y rotation,
  689. * the next 10 (0x03ff) are the Z rotation, same scale as
  690. * before (0x100 == 90 degrees).
  691. *
  692. * Rotations are performed in Y, X, Z order.
  693. * TR1 ONLY: All angle sets are two words and interpreted like the two-word
  694. * sets in TR2/3, EXCEPT that the word order is reversed.
  695. --------------------------------------------------------------*/
  696. typedef struct tr2_frame_s
  697. {
  698. tr2_vertex_t vector[3];
  699. int num_words;
  700. unsigned short *words;
  701. } __attribute__ ((packed)) tr2_frame_t;
  702. /*--------------------------------------------------------------
  703. * Item structure
  704. --------------------------------------------------------------*/
  705. typedef struct tr2_item_s
  706. {
  707. short object_id;
  708. short room;
  709. int x;
  710. int y;
  711. int z;
  712. short angle;
  713. short intensity1;
  714. short intensity2;
  715. short flags; // 0x0100 indicates "inactive" or "invisible"
  716. } __attribute__ ((packed)) tr2_item_t;
  717. /*--------------------------------------------------------------
  718. * SoundSource structure
  719. --------------------------------------------------------------*/
  720. typedef struct tr2_sound_source_s
  721. {
  722. int x; // position of sound source
  723. int y;
  724. int z;
  725. unsigned short sound_id; // internal sound index
  726. unsigned short flags; // 0x40, 0x80, or 0xc0
  727. } __attribute__ ((packed)) tr2_sound_source_t;
  728. /*--------------------------------------------------------------
  729. * Boxes structure
  730. --------------------------------------------------------------*/
  731. typedef struct tr2_boxes_s
  732. {
  733. unsigned char zmin; // sectors (* 1024 units)
  734. unsigned char zmax;
  735. unsigned char xmin;
  736. unsigned char xmax;
  737. short true_floor; // Y value (no scaling)
  738. short overlap_index; // index into Overlaps[]
  739. } __attribute__ ((packed)) tr2_box_t;
  740. /*--------------------------------------------------------------
  741. * AnimatedTexture structure
  742. * - really should be simple short[], since it's variable length
  743. --------------------------------------------------------------*/
  744. typedef struct tr2_animated_texture_s
  745. {
  746. short num_texture_ids; // Number of Texture IDs - 1
  747. short *texture_list; // list of textures to cycle through
  748. } __attribute__ ((packed)) tr2_animated_texture_t;
  749. /*--------------------------------------------------------------
  750. * Camera structure
  751. --------------------------------------------------------------*/
  752. typedef struct tr2_camera_s
  753. {
  754. int x;
  755. int y;
  756. int z;
  757. short room;
  758. unsigned short unknown1; // correlates to Boxes[]?
  759. } __attribute__ ((packed)) tr2_camera_t;
  760. // Data for a flyby camera (40 bytes)
  761. typedef struct tr4_extra_camera_s
  762. {
  763. int pos[6]; // Positions ? (x1,y1,z1,x2,y2,z2) roatations?
  764. unsigned char index[2]; // A pair of indices
  765. unsigned short unknown[5];// ??
  766. int id ;// Index of something
  767. } __attribute__ ((packed)) tr4_extra_camera_t;
  768. /*--------------------------------------------------------------
  769. * Sound sample structure
  770. --------------------------------------------------------------*/
  771. typedef struct tr2_sound_details_s
  772. {
  773. short sample;
  774. short volume;
  775. short sound_range;
  776. short flags; // bits 8-15: priority?, 2-7: number of sound samples
  777. // in this group, bits 0-1: channel number
  778. } __attribute__ ((packed)) tr2_sound_details_t;
  779. /*--------------------------------------------------------------
  780. * Cutscene Camera structure
  781. --------------------------------------------------------------*/
  782. typedef struct tr2_cinematic_frame_s
  783. {
  784. short roty; // Rotation about Y axis, +/-32767 ::= +/- 180 degrees
  785. short rotz; // Rotation about Z axis, +/-32767 ::= +/- 180 degrees
  786. short rotz2; // Rotation about Z axis (why two?),
  787. // +/-32767 ::= +/- 180 degrees
  788. short posz; // Z position of camera, relative to something
  789. short posy; // Y position of camera, relative to something
  790. short posx; // X position of camera, relative to something
  791. short unknown1;
  792. short rotx; // Rotation about X axis, +/-32767 ::= +/- 180 degrees
  793. } __attribute__ ((packed)) tr2_cinematic_frame_t;
  794. /*--------------------------------------------------------------
  795. * Used to read TR4 AI data
  796. * this field replaces the bitu16 NumCinematicFrames of TR1/2/3 levels
  797. * Data for a AI object (24 bytes)
  798. --------------------------------------------------------------*/
  799. typedef struct tr4_ai_object_s
  800. {
  801. unsigned short int object_id; // the objectID from the AI object
  802. // (AI_FOLLOW is 402)
  803. unsigned short int room;
  804. int x, y, a;
  805. unsigned short int ocb;
  806. unsigned short int flags; // The trigger flags
  807. // (button 1-5, first button has value 2)
  808. int angle; // rotation
  809. } __attribute__ ((packed)) tr4_ai_object_t;
  810. /*--------------------------------------------------------------
  811. * Used to read packed TR4 texels
  812. --------------------------------------------------------------*/
  813. typedef struct tr4_object_texture_s
  814. {
  815. unsigned short attribute; // same meaning than in TR3
  816. unsigned short tile; // same meaning than in TR3
  817. unsigned short flags;// new in TR4
  818. tr2_object_texture_vert_t vertices[4];// same meaning than in TR3
  819. unsigned int unknown1, unknown2; // new in TR4: x & y offset in something
  820. unsigned int xsize,ysize;// new in TR4: width-1 & height-1 of the object texture
  821. } __attribute__ ((packed)) tr4_object_texture_t;
  822. typedef struct tr5_room_layer_s // (56 bytes)
  823. {
  824. u_int32_t numLayerVertices; // number of vertices in this layer (4 bytes)
  825. u_int16_t unknownL1; // unknown (2 bytes)
  826. u_int16_t numLayerRectangles; // number of rectangles in this layer (2 bytes)
  827. u_int16_t numLayerTriangles; // number of triangles in this layer (2 bytes)
  828. u_int16_t unknownL2; // appears to be the number of 2 sided textures in this layer, however is sometimes 1 off (2 bytes)
  829. u_int16_t filler; // always 0 (2 bytes)
  830. u_int16_t filler2; // always 0 (2 bytes)
  831. // The following 6 floats (4 bytes each)
  832. // define the bounding box for the layer
  833. float layerBoundingBoxX1;
  834. float layerBoundingBoxY1;
  835. float layerBoundingBoxZ1;
  836. float layerBoundingBoxX2;
  837. float layerBoundingBoxY2;
  838. float layerBoundingBoxZ2;
  839. u_int32_t filler3; // always 0 (4 bytes)
  840. u_int32_t unknownL6; // unknown (4 bytes)
  841. u_int32_t unknownL7; // unknown (4 bytes)
  842. u_int32_t unknownL8; // unknown. Always the same throughout the level. (4 bytes)
  843. } tr5_room_layer_t;
  844. typedef struct tr5_face4_s // (12 bytes)
  845. {
  846. u_int16_t vertices[4]; // the values are the indices into the appropriate layer vertice list. (2 bytes each)
  847. u_int16_t texture; // the texture number for this face. Needs to be masked with 0xFFF as the high 4 bits are flags.(2 bytes)
  848. u_int16_t unknownF4; // unknown (2 bytes)
  849. } tr5_face4_t;
  850. typedef struct tr5_face3_s // (10 bytes)
  851. {
  852. u_int16_t vertices[3]; // the values are the indices into the appropriate layer vertice list (2 bytes each)
  853. u_int16_t texture; // the texture number for this face. Needs to be masked with 0xFFF as the high 4 bits are flags (2 bytes)
  854. u_int16_t unknownF3; // unknown (2 bytes)
  855. } tr5_face3_t;
  856. typedef struct tr5_vertex_s // (28 bytes)
  857. {
  858. float x; // x of vertex (4 bytes)
  859. float y; // y of vertex (4 bytes)
  860. float z; // z of vertex (4 bytes)
  861. float nx; // x of vertex normal (4 bytes)
  862. float ny; // y of vertex normal (4 bytes)
  863. float nz; // z of vertex normal (4 bytes)
  864. u_int32_t vColor; // vertex color ARGB format (4 bytes)
  865. } tr5_vertex_t;
  866. typedef struct tr5_room_geometry_s
  867. {
  868. // This is to help store and manage TR5 layer based polgons for rooms
  869. tr5_face4_t *quads;
  870. tr5_face3_t *tris;
  871. tr5_vertex_t *verts;
  872. } tr5_room_geometry_t;
  873. typedef struct tr5_light_s // (88 bytes)
  874. {
  875. /* Maybe wrong: The first three floats specify the position of the light
  876. in world coordinates
  877. The sun type light should not use these but seems to have a
  878. large x value (9 million, give or take)
  879. a zero y value, and a small z value (4 - 20) in the original TR5 levels
  880. */
  881. float x; // x position of light (4 bytes)
  882. float y; // y position of light (4 bytes)
  883. float z; // z position of light (4 bytes)
  884. // The next three specify the color of the light
  885. float red; // color of red spectrum (4 bytes)
  886. float green; // color of green spectrum (4 bytes)
  887. float blue; // color of blue spectrum (4 bytes)
  888. u_int32_t seperator; // not used 0xCDCDCDCD (4 bytes)
  889. /* At this point the following info diverges dependant
  890. on which type of light being used:
  891. 0 = sun, 1 = light, 2 = spot, 3 = shadow
  892. The sun type doesn't use the next two.
  893. For the spot type these are the hotspot and falloff angle cosines
  894. For the light and shadow types these are the TR units
  895. for the hotspot/falloff (1024=1sector)
  896. */
  897. float input; // cosine of the IN value for light / size of IN value (4 bytes)
  898. float output; // cosine of the OUT value for light / size of OUT value (4 bytes)
  899. // The next two are only used by the spot type light
  900. float radInput; // (IN radians) * 2 (4 bytes)
  901. float radOutput; // (OUT radians) * 2 (4 bytes)
  902. // The next is also only used by the spot type light
  903. float range; // Range of light (4 bytes)
  904. /* The final 3 floats are used only by the 'sun' and 'spot' type lights.
  905. They describe the directional vector of the light.
  906. This can be obtained by :
  907. if both x and y LightDirectionVectorX = cosX * sinY
  908. LightDirectionVectorY = sinX
  909. LightDirectionVectorZ = cosX * cosY
  910. */
  911. float directionVectorX; // light direction (4 bytes)
  912. float directionVectorY; // light direction (4 bytes)
  913. float directionVectorZ; // light direction (4 bytes)
  914. // The next six values repeat some of the previous information in long data types vice floats
  915. int32_t x2; // x position of light (4 bytes)
  916. int32_t y2; // y position of light (4 bytes)
  917. int32_t z2; // z position of light (4 bytes)
  918. // 16384 = 1.0 for the rotations ( 1/16384 )
  919. int32_t directionVectorX2; // light direction (4 bytes)
  920. int32_t directionVectorY2; // light direction (4 bytes)
  921. int32_t directionVectorZ2; // light direction (4 bytes)
  922. // The next char specifies the type of light as specified above
  923. u_int8_t lightType; // type of light. (1 byte)
  924. u_int8_t seperator2[3]; // 0xCDCDCD (3 bytes)
  925. } tr5_light_t;
  926. // [ FIRST NUMBER IS OFFSET IN BYTES FROM START OF ROOM STRUCTURE]
  927. typedef struct tr5_room_s
  928. {
  929. u_int32_t checkXELA; // "XELA" (4 bytes)
  930. u_int32_t roomDataSize; /* size of the following data ( use this vice
  931. 'walking thru' to get next room) (4 bytes) */
  932. u_int32_t seperator; // 0xCDCDCDCD (4 bytes)
  933. u_int32_t endSDOffset; /* usually this number + 216 will give you the
  934. offset from the start of the room data to the end
  935. of the Sector Data. HOWEVER have seen where this
  936. bitu32 is equal to -1 so it is better to use the
  937. following bitu32 and + 216 +
  938. ((NumXSectors * NumZSectors)*8) if you need
  939. to obtain this information. (4 bytes) */
  940. u_int32_t startSDOffset; /* this number + 216 will give you the offset from
  941. the start of the room to the start of the
  942. sector data. (4 bytes) */
  943. u_int32_t seperator2; // will either be 0x00000000 or 0xCDCDCDCD (4 bytes)
  944. u_int32_t endPortalOffset; /* this number + 216 will give you the offset
  945. from the start of the room to the end of the
  946. portal data. (4 bytes) */
  947. int32_t x; // X position of room ( world coordinates) (4 bytes)
  948. int32_t seperator3; // 0x00000000 (4 bytes)
  949. int32_t z; // Z position of room (world coordinates) (4 bytes)
  950. int32_t yBottom; // lowest point in room (4 bytes)
  951. int32_t yTop; // highest point in room (4 bytes)
  952. u_int16_t numZSectors; // sector table width (2 bytes)
  953. u_int16_t numXSectors; // sector table height (2 bytes)
  954. u_int32_t roomAmbientColor; // ARGB format (blue is least significant byte) (4 bytes)
  955. u_int16_t numRoomLights; // number of lights in this room (2 bytes)
  956. u_int16_t numStaticMeshes; // number of static meshes in this room (2 bytes)
  957. u_int16_t unknownR1; // usually 0x0001 however high byte is sometimes non zero (2 bytes)
  958. u_int16_t unknownR2; // usually 0x0000 however low byte is sometimes non zero (2 bytes)
  959. u_int32_t filler; // always 0x00007FFF (4 bytes)
  960. u_int32_t filler2; // always 0x00007FFF (4 bytes)
  961. u_int32_t seperator4; // 0xCDCDCDCD (4 bytes)
  962. u_int32_t seperator5; // 0xCDCDCDCD (4 bytes)
  963. unsigned char seperator6[6]; // 6 bytes 0xFF
  964. u_int16_t roomFlag; // 0x01 = water, 0x20 = wind, others unknown (2 bytes)
  965. u_int16_t unknownR5; // unknown (2 bytes)
  966. unsigned char seperator7[10]; // 10 bytes 0x00
  967. u_int32_t seperator8; // 0xCDCDCDCD (4 bytes)
  968. u_int32_t unknownR6; // unknown (4 bytes)
  969. float roomX; // X position of room in world coordinates * If null room then this data will be 0xCDCDCDCD (4 bytes)
  970. u_int32_t seperator9; // 0x00000000 or 0xCDCDCDCD if null room. (4 bytes)
  971. float roomZ; // Z position of room in world coordinates * If null room then will be bitu32 0xCDCDCDCD (4 bytes)
  972. u_int32_t seperator10; // 0xCDCDCDCD (4 bytes)
  973. u_int32_t seperator11; // 0xCDCDCDCD (4 bytes)
  974. u_int32_t seperator12; // 0xCDCDCDCD (4 bytes)
  975. u_int32_t seperator13; // 0xCDCDCDCD (4 bytes)
  976. u_int32_t seperator14; // 0x00000000 unless null room then 0xCDCDCDCD (4 bytes)
  977. u_int32_t seperator15; // 0xCDCDCDCD (4 bytes)
  978. u_int32_t numRoomTriangles; // total number of triangles this room (4 bytes)
  979. u_int32_t numRoomRectangles; // total number of rectangles this room (4 bytes)
  980. u_int32_t seperator16; // 0x00000000 (4 bytes)
  981. u_int32_t lightSize; // size of light data (number of lights * 88) (4 bytes)
  982. u_int32_t numTotalRoomLights; // total number of lights this room (4 bytes)
  983. u_int32_t unknownR7; // unknown, usually equals 0, 1, 2, or 3 (4 bytes)
  984. int32_t unknownR8; // usually equals room yTop. Sometimes a few blocks off. If null room then 0xCDCDCDCD
  985. int32_t lyBottom; // equals room yBottom. If null room then 0xCDCDCDCD (4 bytes)
  986. u_int32_t numLayers; // number of layers (pieces) this room (4 bytes)
  987. u_int32_t layerOffset; // this number + 216 will give you an offset from the start of the room data to the start of the layer data (4 bytes)
  988. u_int32_t verticesOffset; // this number + 216 will give you an offset from the start of the room data to the start of the verex data (4 bytes)
  989. u_int32_t polyOffset; // this number + 216 will give you an offset from the start of the room data to the start of the rectangle/triangle data (4 bytes)
  990. u_int32_t polyOffset2; // same as above ? (4 bytes)
  991. u_int32_t verticesSize; // size of vertices data block (4 bytes)
  992. u_int32_t seperator17; // 0xCDCDCDCD (4 bytes)
  993. u_int32_t seperator18; // 0xCDCDCDCD (4 bytes)
  994. u_int32_t seperator19; // 0xCDCDCDCD (4 bytes)
  995. u_int32_t seperator20; // 0xCDCDCDCD (4 bytes)
  996. tr5_light_t *lights; //[LightSize]; // data for the lights (88 bytes * NumRoomLights)
  997. tr2_room_sector_t *sectors; //Data[(NumXSectors * NumZSectors) * 8]; // normal sector data structure
  998. u_int16_t numDoors; // number of portals (2 bytes)
  999. tr2_room_portal_t *doors;//[NumDoors]; // normal portal structure (32 bytes * NumDoors)
  1000. u_int16_t seperator21; // 0xCDCD (2 bytes)
  1001. tr2_room_staticmesh_t *meshes; //[NumStaticMeshes]; // normal room static mesh structure (20 bytes * NumRoomStaticMeshes)
  1002. tr5_room_layer_t *layers; // [NumLayers]; // data for the room layers (pieces) (56 bytes * NumLayers)
  1003. tr5_room_geometry_t *faces; //[NumRoomRectangles + NumRoomTriangles];
  1004. /* Data for the room polys (face4 and face3).
  1005. Structured as first layers rectangles then triangles, followed by the
  1006. next layers rectangles and triangles, etc., until all layers are done.
  1007. (12 bytes each rectangle. 10 bytes each triangle) */
  1008. tr5_vertex_t *vertices; //[VerticesSize];
  1009. /* data for the room vertices. Structured as vertices for the first layer,
  1010. then vertices for the second layer, etc., until all layers are done.
  1011. (28 bytes each vertex. */
  1012. } tr5_room_t;
  1013. typedef struct tr5_object_texture_vertex_s // (4 bytes)
  1014. {
  1015. u_int8_t xCoordinate; // 0 if Xpixel is the low value, 255 if Xpixel is the high value in the object texture (1 byte)
  1016. u_int8_t xPixel; // (1 byte)
  1017. u_int8_t yCoordinate; // 0 if Ypixel is the low value, 255 if Ypixel is the high value in the object texture (1 byte)
  1018. u_int8_t yPixel; // (1 byte)
  1019. } tr5_object_texture_vertex_t;
  1020. typedef struct tr5_object_texture_s // (40 bytes)
  1021. {
  1022. u_int16_t attribute; //0, 1, or 2 (2 means 2 sided) (2 bytes)
  1023. u_int32_t tile; // need to mask with 0xFF as other bits are flags. ie int15_t seems to indicate triangle (4 bytes)
  1024. tr5_object_texture_vertex_t vertices[4]; // Vertices[4] (16 bytes)
  1025. u_int32_t uv1; // unknown how used (4 bytes)
  1026. u_int32_t uv2; // unknown how used (4 bytes)
  1027. u_int32_t xSize; // unknown how used, x size (4 bytes)
  1028. u_int32_t ySize; // unknown how used, y size (4 bytes)
  1029. u_int16_t seperator; // always 0x0000 (2 bytes)
  1030. } tr5_object_texture_t;
  1031. typedef struct tr5_flyby_camera_s // (40 bytes)
  1032. {
  1033. int32_t cameraX; // x position of camera in world coordinates (4 bytes)
  1034. int32_t cameraY; // y position of camera in world coordinates (4 bytes)
  1035. int32_t cameraZ; // z position of camera in world coordinates (4 bytes)
  1036. int32_t targetX; // x position of aiming point in world coords (4 bytes)
  1037. int32_t targetY; // y position of aiming point in world coords (4 bytes)
  1038. int32_t targetZ; // z position of aiming point in world coords (4 bytes)
  1039. int8_t sequence; // sequence # of camera (1 byte)
  1040. int8_t cameraNumber; // camera # (1 byte)
  1041. u_int16_t fov; // fov of camera ( .0054945 for each degree ) (2 bytes)
  1042. u_int16_t roll; // roll of camera ( .0054945 for each degree ) (2 bytes)
  1043. u_int16_t timer; // timer number (2 bytes)
  1044. u_int16_t speed; // ( .000015259 each ) (2 bytes)
  1045. u_int16_t flags; // ( see your handy TRLE manual for the specs ) (2 bytes)
  1046. u_int32_t room; // room number (4 bytes)
  1047. } tr5_flyby_camera_t;
  1048. typedef struct tr5_moveable_s // ( 20 bytes ) ( same as old structure but has u_int16_t filler at the end )
  1049. {
  1050. u_int32_t objectId; // object identifier ( matched in Items[] )
  1051. u_int16_t numMeshes; // number of meshes in this object
  1052. u_int16_t startingMesh; // starting mesh ( offset into MeshPointers[] )
  1053. u_int32_t meshTree; // offset into MeshTree[] )
  1054. u_int32_t frameOffset; // byte offset into Frames[] ( divide by 2 for Frames[i] )
  1055. u_int16_t animation; // offset into Animations[]
  1056. u_int16_t filler; // always equal to 65519 ( 0xFFEF )
  1057. } tr5_moveable_t;
  1058. typedef struct tr5_mesh_s
  1059. {
  1060. tr2_vertex_t center; // relative coordinates of mesh centre (6 bytes)
  1061. u_int8_t unknown1[4]; // unknown (4 bytes)
  1062. int16_t numVertices; // number of vertices to follow (2 bytes)
  1063. tr2_vertex_t *vertices; //[NumVertices]; // list of vertices (NumVertices * 6 bytes)
  1064. int16_t numNormals; // number of normals to follow (2 bytes)
  1065. tr2_vertex_t *normals; //[NumNormals]; // list of normals (NumNormals * 6 bytes) (becomes Lights if NumNormals < 0; 2 bytes)
  1066. int16_t numTexturedRectangles; // number of textured rectangles to follow (2 bytes)
  1067. tr5_face4_t *texturedRectangles; //[NumTexturedRectangles]; // list of textured rectangles (NumTexturedRectangles * 12 bytes)
  1068. int16_t numTexturedTriangles; // number of textured triangles to follow (2 bytes)
  1069. tr5_face3_t *texturedTriangles; //[NumTexturedTriangles]; // list of textured triangles (NumTexturedTriangles * 10 bytes)
  1070. } tr5_mesh_t;
  1071. typedef struct tr5_animation_s // ( 40 bytes ) ( same as old structure but has 8 bytes before FrameStart )
  1072. {
  1073. u_int32_t FrameOffset; // byte offset into Frames[] ( divide by 2 for Frames[i] )
  1074. u_int8_t FrameRate; // Engine ticks per frame
  1075. u_int8_t FrameSize; // number of int16_t's in Frames[] used by this animation
  1076. u_int16_t StateId; //
  1077. int16_t Unknown;
  1078. int16_t Speed; // Evengi Popov found this but I never seen what he said it was for
  1079. u_int16_t AccelLo; // same as above
  1080. int16_t AccelHi; // same as above
  1081. u_int8_t AUnknown[8]; // Unknown
  1082. u_int16_t FrameStart; // first frame in this animation
  1083. u_int16_t FrameEnd; // last frame in this animation ( numframes = ( End - Start) + 1 )
  1084. u_int16_t NextAnimation;
  1085. u_int16_t NextFrame;
  1086. u_int16_t NumStateChanges;
  1087. u_int16_t StateChangeOffset; // offset into StateChanges[]
  1088. u_int16_t NumAnimCommands; // how many of them to use
  1089. u_int16_t AnimCommand; // offset into AnimCommand[]
  1090. } tr5_animation_t;
  1091. typedef struct tr5_cinematic_frame_s
  1092. {
  1093. unsigned int unknown[24];
  1094. } tr5_cinematic_frame_t;
  1095. #ifdef WIN32
  1096. #pragma pack(pop, tr2_h, 1)
  1097. #endif
  1098. class TombRaider
  1099. {
  1100. public:
  1101. ////////////////////////////////////////////////////////////
  1102. // Constructors
  1103. ////////////////////////////////////////////////////////////
  1104. TombRaider();
  1105. /*------------------------------------------------------
  1106. * Pre :
  1107. * Post : Constructs an object of TombRaider
  1108. *
  1109. *-- History ------------------------------------------
  1110. *
  1111. * 2000.05.13:
  1112. * Mongoose - Created
  1113. ------------------------------------------------------*/
  1114. ~TombRaider();
  1115. /*------------------------------------------------------
  1116. * Pre : TombRaider object is allocated
  1117. * Post : Deconstructs an object of TombRaider
  1118. *
  1119. *-- History ------------------------------------------
  1120. *
  1121. * 2000.05.13:
  1122. * Mongoose - Created
  1123. ------------------------------------------------------*/
  1124. ////////////////////////////////////////////////////////////
  1125. // Wash me -- not part of cleaned API
  1126. ////////////////////////////////////////////////////////////
  1127. int NumRooms();
  1128. /*------------------------------------------------------
  1129. * Pre :
  1130. * Post :
  1131. *
  1132. *-- History ------------------------------------------
  1133. *
  1134. * 2000.05.13:
  1135. * Mongoose - Created
  1136. ------------------------------------------------------*/
  1137. int NumMoveables();
  1138. /*------------------------------------------------------
  1139. * Pre :
  1140. * Post :
  1141. *
  1142. *-- History ------------------------------------------
  1143. *
  1144. * 2000.05.13:
  1145. * Mongoose - Created
  1146. ------------------------------------------------------*/
  1147. int NumTextures();
  1148. /*------------------------------------------------------
  1149. * Pre :
  1150. * Post :
  1151. *
  1152. *-- History ------------------------------------------
  1153. *
  1154. * 2000.05.13:
  1155. * Mongoose - Created
  1156. ------------------------------------------------------*/
  1157. int NumSpecialTextures();
  1158. /*------------------------------------------------------
  1159. * Pre :
  1160. * Post : Returns number of "special" textures/images
  1161. *
  1162. *-- History ------------------------------------------
  1163. *
  1164. * 2001.06.19:
  1165. * Mongoose - Created
  1166. ------------------------------------------------------*/
  1167. int NumAnimations();
  1168. /*------------------------------------------------------
  1169. * Pre :
  1170. * Post :
  1171. *
  1172. *-- History ------------------------------------------
  1173. *
  1174. * 2000.05.13:
  1175. * Mongoose - Created
  1176. ------------------------------------------------------*/
  1177. unsigned int NumFrames();
  1178. /*------------------------------------------------------
  1179. * Pre :
  1180. * Post :
  1181. *
  1182. *-- History ------------------------------------------
  1183. *
  1184. * 2000.05.13:
  1185. * Mongoose - Created
  1186. ------------------------------------------------------*/
  1187. int NumStaticMeshes();
  1188. /*------------------------------------------------------
  1189. * Pre :
  1190. * Post :
  1191. *
  1192. *-- History ------------------------------------------
  1193. *
  1194. * 2000.05.13:
  1195. * Mongoose - Created
  1196. ------------------------------------------------------*/
  1197. int NumSprites();
  1198. /*------------------------------------------------------
  1199. * Pre :
  1200. * Post :
  1201. *
  1202. *-- History ------------------------------------------
  1203. *
  1204. * 2000.05.13:
  1205. * Mongoose - Created
  1206. ------------------------------------------------------*/
  1207. int NumSpriteSequences();
  1208. /*------------------------------------------------------
  1209. * Pre :
  1210. * Post :
  1211. *
  1212. *-- History ------------------------------------------
  1213. *
  1214. * 2001.06.06:
  1215. * Mongoose - Created
  1216. ------------------------------------------------------*/
  1217. int NumItems();
  1218. /*------------------------------------------------------
  1219. * Pre :
  1220. * Post :
  1221. *
  1222. *-- History ------------------------------------------
  1223. *
  1224. * 2001.06.06:
  1225. * Mongoose - Created
  1226. ------------------------------------------------------*/
  1227. tr2_version_type Engine();
  1228. /*------------------------------------------------------
  1229. * Pre :
  1230. * Post :
  1231. *
  1232. *-- History ------------------------------------------
  1233. *
  1234. * 2000.05.13:
  1235. * Mongoose - Created
  1236. ------------------------------------------------------*/
  1237. unsigned short *Frame();
  1238. /*------------------------------------------------------
  1239. * Pre :
  1240. * Post :
  1241. *
  1242. *-- History ------------------------------------------
  1243. *
  1244. * 2000.05.13:
  1245. * Mongoose - Created
  1246. ------------------------------------------------------*/
  1247. tr2_animation_t *Animation();
  1248. /*------------------------------------------------------
  1249. * Pre :
  1250. * Post :
  1251. *
  1252. *-- History ------------------------------------------
  1253. *
  1254. * 2000.05.13:
  1255. * Mongoose - Created
  1256. ------------------------------------------------------*/
  1257. tr2_item_t *Item();
  1258. /*------------------------------------------------------
  1259. * Pre :
  1260. * Post :
  1261. *
  1262. *-- History ------------------------------------------
  1263. *
  1264. * 2000.05.13:
  1265. * Mongoose - Created
  1266. ------------------------------------------------------*/
  1267. tr2_object_texture_t *ObjectTextures();
  1268. /*------------------------------------------------------
  1269. * Pre :
  1270. * Post :
  1271. *
  1272. *-- History ------------------------------------------
  1273. *
  1274. * 2000.05.13:
  1275. * Mongoose - Created
  1276. ------------------------------------------------------*/
  1277. unsigned int getNumBoxes();
  1278. /*------------------------------------------------------
  1279. * Pre :
  1280. * Post : returns number of boxes
  1281. *
  1282. *-- History ------------------------------------------
  1283. *
  1284. * 200?.??.??:
  1285. * Mongoose - Created
  1286. ------------------------------------------------------*/
  1287. tr2_box_t *Box();
  1288. /*------------------------------------------------------
  1289. * Pre :
  1290. * Post :
  1291. *
  1292. *-- History ------------------------------------------
  1293. *
  1294. * 2000.05.13:
  1295. * Mongoose - Created
  1296. ------------------------------------------------------*/
  1297. tr2_mesh_t *Mesh();
  1298. /*------------------------------------------------------
  1299. * Pre :
  1300. * Post :
  1301. *
  1302. *-- History ------------------------------------------
  1303. *
  1304. * 2000.05.13:
  1305. * Mongoose - Created
  1306. ------------------------------------------------------*/
  1307. int getNumAnimsForMoveable(int moveable_index);
  1308. /*------------------------------------------------------
  1309. * Pre : moveable_id is valid
  1310. * Post : Returns number of animations for a moveable
  1311. *
  1312. *-- History ------------------------------------------
  1313. *
  1314. * 2002.08.15:
  1315. * Mongoose - Using signed values now ( like it should have )
  1316. *
  1317. * 2002.04.04:
  1318. * Mongoose - Created, based on TRViewer algorithm
  1319. ------------------------------------------------------*/
  1320. tr2_staticmesh_t *StaticMesh();
  1321. /*------------------------------------------------------
  1322. * Pre :
  1323. * Post :
  1324. *
  1325. *-- History ------------------------------------------
  1326. *
  1327. * 2000.05.13:
  1328. * Mongoose - Created
  1329. ------------------------------------------------------*/
  1330. tr2_moveable_t *Moveable();
  1331. /*------------------------------------------------------
  1332. * Pre :
  1333. * Post :
  1334. *
  1335. *-- History ------------------------------------------
  1336. *
  1337. * 2000.05.13:
  1338. * Mongoose - Created
  1339. ------------------------------------------------------*/
  1340. tr2_meshtree_t *MeshTree();
  1341. /*------------------------------------------------------
  1342. * Pre :
  1343. * Post :
  1344. *
  1345. *-- History ------------------------------------------
  1346. *
  1347. * 2000.05.13:
  1348. * Mongoose - Created
  1349. ------------------------------------------------------*/
  1350. tr2_sprite_texture_t *Sprite();
  1351. /*------------------------------------------------------
  1352. * Pre :
  1353. * Post : Returns the sprite array
  1354. *
  1355. *-- History ------------------------------------------
  1356. *
  1357. * 2001.06.02:
  1358. * Mongoose - Created
  1359. ------------------------------------------------------*/
  1360. tr2_sprite_sequence_t *SpriteSequence();
  1361. /*------------------------------------------------------
  1362. * Pre :
  1363. * Post :
  1364. *
  1365. *-- History ------------------------------------------
  1366. *
  1367. * 2001.06.06:
  1368. * Mongoose - Created
  1369. ------------------------------------------------------*/
  1370. unsigned char *SpecialTexTile(int texture);
  1371. /*------------------------------------------------------
  1372. * Pre : texture is valid index into tex_special list
  1373. *
  1374. * Post : Makes a 32bit RGBA image from a stexture/bmap
  1375. * and returns it. Returns NULL on error.
  1376. *
  1377. *-- History ------------------------------------------
  1378. *
  1379. * 2001.06.19:
  1380. * Mongoose - Created
  1381. ------------------------------------------------------*/
  1382. void Texture(int texture, unsigned char **image, unsigned char **bumpmap);
  1383. /*------------------------------------------------------
  1384. * Pre : texture is valid textile index
  1385. * Post : Returns copies of texture and it's bumpmap
  1386. * if found, otherwise returns NULL
  1387. *
  1388. *-- History ------------------------------------------
  1389. *
  1390. * 2001.06.19:
  1391. * Mongoose - Created
  1392. ------------------------------------------------------*/
  1393. unsigned int *Palette16();
  1394. /*------------------------------------------------------
  1395. * Pre :
  1396. * Post :
  1397. *
  1398. *-- History ------------------------------------------
  1399. *
  1400. * 2000.05.13:
  1401. * Mongoose - Created
  1402. ------------------------------------------------------*/
  1403. unsigned char *Palette8();
  1404. /*------------------------------------------------------
  1405. * Pre :
  1406. * Post :
  1407. *
  1408. *-- History ------------------------------------------
  1409. *
  1410. * 2000.05.13:
  1411. * Mongoose - Created
  1412. ------------------------------------------------------*/
  1413. tr2_room_t *Room();
  1414. /*------------------------------------------------------
  1415. * Pre :
  1416. * Post :
  1417. *
  1418. *-- History ------------------------------------------
  1419. *
  1420. * 2000.05.13:
  1421. * Mongoose - Created
  1422. ------------------------------------------------------*/
  1423. int checkMime(char *filename);
  1424. /*------------------------------------------------------
  1425. * Pre :
  1426. * Post : Returns 0 if TombRaider pak file
  1427. *
  1428. *-- History ------------------------------------------
  1429. *
  1430. * 2003.07.05:
  1431. * Mongoose - Created
  1432. ------------------------------------------------------*/
  1433. int Load(char *filename, void (*percent)(int));
  1434. /*------------------------------------------------------
  1435. * Pre : filename is valid string and points
  1436. * to vaild TombRaider 1-5 pak
  1437. *
  1438. * Post : Loads TombRaider 1-5 pak into memory
  1439. * and does some processing
  1440. *
  1441. * Returns 0 on sucess, and less than 0 on error
  1442. *
  1443. * At 10% all textures are loaded
  1444. * the exact figure '10' will always be passed to
  1445. * allow for texture caching while meshes load
  1446. * for TR4
  1447. *
  1448. *-- History ------------------------------------------
  1449. *
  1450. * 2002.01.02:
  1451. * Mongoose - New callback for percent loaded feedback
  1452. *
  1453. * 2000.05.13:
  1454. * Mongoose - Created
  1455. ------------------------------------------------------*/
  1456. ////////////////////////////////////////////////////////////
  1457. // Public Accessors
  1458. ////////////////////////////////////////////////////////////
  1459. float adjustTexel(unsigned char texel, char offset);
  1460. /*------------------------------------------------------
  1461. * Pre : Passed the correct coor/pixel pair from
  1462. * object texture
  1463. *
  1464. * Post : Makes a clamped 0.0 to 1.0 texel from coord pair
  1465. *
  1466. *-- History ------------------------------------------
  1467. *
  1468. * 2001.06.21:
  1469. * Mongoose - Created
  1470. ------------------------------------------------------*/
  1471. void computeRotationAngles(unsigned short **frame,
  1472. unsigned int *frame_offset,
  1473. unsigned int *angle_offset,
  1474. float *x, float *y, float *z);
  1475. /*------------------------------------------------------
  1476. * Pre : Given moveable animation data
  1477. * Post : Returns computed angles in x,y,z pointers
  1478. *
  1479. *-- History ------------------------------------------
  1480. *
  1481. * 2002.04.05:
  1482. * Mongoose - Created
  1483. ------------------------------------------------------*/
  1484. void computeUV(tr2_object_texture_vert_t *st, float *u, float *v);
  1485. /*------------------------------------------------------
  1486. * Pre : Args are valid pointers
  1487. * Post : Returns computed UV in u and v
  1488. *
  1489. *-- History ------------------------------------------
  1490. *
  1491. * 2002.04.05:
  1492. * Mongoose - Created
  1493. ------------------------------------------------------*/
  1494. int getBumpMapCount();
  1495. /*------------------------------------------------------
  1496. * Pre :
  1497. * Post : Returns number of bump maps in loaded pak
  1498. *
  1499. *-- History ------------------------------------------
  1500. *
  1501. * 2002.12.24:
  1502. * Mongoose - Created
  1503. ------------------------------------------------------*/
  1504. void getColor(int index, float color[4]);
  1505. /*------------------------------------------------------
  1506. * Pre :
  1507. * Post :
  1508. *
  1509. *-- History ------------------------------------------
  1510. *
  1511. * 2000.05.30:
  1512. * Mongoose - Created
  1513. ------------------------------------------------------*/
  1514. tr2_version_type getEngine();
  1515. /*------------------------------------------------------
  1516. * Pre :
  1517. * Post :
  1518. *
  1519. *-- History ------------------------------------------
  1520. *
  1521. * 2003.05.24:
  1522. * Mongoose - Obsoloetes Engine() method, name change
  1523. *
  1524. * 2000.05.13:
  1525. * Mongoose - Created
  1526. ------------------------------------------------------*/
  1527. void getMeshCollisionInfo(unsigned int meshIndex,
  1528. float center[3], float *radius);
  1529. /*------------------------------------------------------
  1530. * Pre : float Center[3], float radius allocated
  1531. *
  1532. * Post : Returns Center and radius of collision sphere
  1533. * for mesh[index]
  1534. *
  1535. *-- History ------------------------------------------
  1536. *
  1537. * 2003.05.16:
  1538. * Mongoose - Created
  1539. ------------------------------------------------------*/
  1540. int getMeshCount();
  1541. /*------------------------------------------------------
  1542. * Pre :
  1543. * Post : Returns SIGNED mesh count ( TR encoded < 0 errs )
  1544. *
  1545. *-- History ------------------------------------------
  1546. *
  1547. * 2000.05.13:
  1548. * Mongoose - Created
  1549. ------------------------------------------------------*/
  1550. void getMeshColoredRectangle(unsigned int meshIndex,
  1551. unsigned int faceIndex,
  1552. int index[6], float color[4]);
  1553. /*------------------------------------------------------
  1554. * Pre : This method interface may change later
  1555. *
  1556. * Pass allocated index[6], color[4] ( RGBA )
  1557. *
  1558. * Post : This method is made to let you fill arrays or
  1559. * create single faces, their may be an allocating
  1560. * version that passes back arrays later
  1561. *
  1562. * Returns Quads/Rects as 2 triangles, because
  1563. * returning quads would be too trival =)
  1564. *
  1565. *-- History ------------------------------------------
  1566. *
  1567. * 2000.05.16:
  1568. * Mongoose - Created, based on method from OpenRaider
  1569. ------------------------------------------------------*/
  1570. void getMeshColoredTriangle(unsigned int meshIndex,
  1571. unsigned int faceIndex,
  1572. int index[3], float color[4]);
  1573. /*------------------------------------------------------
  1574. * Pre : This method interface may change later
  1575. *
  1576. * Pass allocated index[3], color[4] ( RGBA )
  1577. *
  1578. * Post : This method is made to let you fill arrays or
  1579. * create single faces, their may be an allocating
  1580. * version that passes back arrays later
  1581. *
  1582. *-- History ------------------------------------------
  1583. *
  1584. * 2000.05.16:
  1585. * Mongoose - Created, based on method from OpenRaider
  1586. ------------------------------------------------------*/
  1587. void getMeshTexturedRectangle(unsigned int meshIndex,
  1588. unsigned int faceIndex,
  1589. int index[6], float st[12], int *texture,
  1590. unsigned short *transparency);
  1591. /*------------------------------------------------------
  1592. * Pre : This method interface may change later
  1593. *
  1594. * Pass allocated index[6], st[12], texture,
  1595. * and transparency
  1596. *
  1597. * Post : This method is made to let you fill arrays or
  1598. * create single faces, their may be an allocating
  1599. * version that passes back arrays later
  1600. *
  1601. * Returns Quads/Rects as 2 triangles, because
  1602. * returning quads would be too trival =)
  1603. *
  1604. *-- History ------------------------------------------
  1605. *
  1606. * 2000.05.16:
  1607. * Mongoose - Created, based on method from OpenRaider
  1608. ------------------------------------------------------*/
  1609. void getMeshTexturedTriangle(unsigned int meshIndex,
  1610. unsigned int faceIndex,
  1611. int index[3], float st[6], int *texture,
  1612. unsigned short *transparency);
  1613. /*------------------------------------------------------
  1614. * Pre : This method interface may change later
  1615. *
  1616. * Pass allocated index[3], st[6], texture,
  1617. * and transparency
  1618. *
  1619. * Post : This method is made to let you fill arrays or
  1620. * create single faces, their may be an allocating
  1621. * version that passes back arrays later
  1622. *
  1623. *-- History ------------------------------------------
  1624. *
  1625. * 2000.05.16:
  1626. * Mongoose - Created, based on method from OpenRaider
  1627. ------------------------------------------------------*/
  1628. int getMeshTexturedTriangleCount(unsigned int meshIndex);
  1629. int getMeshColoredTriangleCount(unsigned int meshIndex);
  1630. int getMeshTexturedRectangleCount(unsigned int meshIndex);
  1631. int getMeshColoredRectangleCount(unsigned int meshIndex);
  1632. /*------------------------------------------------------
  1633. * Pre : This method interface may change later
  1634. * Post : Get face counts for a given mesh
  1635. *
  1636. *-- History ------------------------------------------
  1637. *
  1638. * 2003.05.16:
  1639. * Mongoose - Created
  1640. ------------------------------------------------------*/
  1641. void getMeshVertexArrays(unsigned int meshIndex,
  1642. unsigned int *vertexCount, float **verts,
  1643. unsigned int *normalCount, float **norms,
  1644. unsigned int *colorCount, float **colors);
  1645. /*------------------------------------------------------
  1646. * Pre : Given mesh index
  1647. *
  1648. * Post : Returns allocated vertex, normal, and color arrays,
  1649. * and their element counts,
  1650. *
  1651. * Colors has been changed to be an intesity for now
  1652. *
  1653. * verts - XYX, norms - IJK, colors - I
  1654. *
  1655. *-- History ------------------------------------------
  1656. *
  1657. * 2003.05.13:
  1658. * Mongoose - Created, based on method from OpenRaider
  1659. ------------------------------------------------------*/
  1660. int getRoomBox(unsigned int roomIndex, unsigned int index,
  1661. float *xyzA, float *xyzB, float *xyzC, float *xyzD);
  1662. /*------------------------------------------------------
  1663. * Pre :
  1664. * Post : Returns a single collision box from room ( unified )
  1665. *
  1666. *-- History ------------------------------------------
  1667. *
  1668. * 2003.05.24:
  1669. * Mongoose - Created
  1670. ------------------------------------------------------*/
  1671. unsigned int getRoomBoxCount(unsigned int roomIndex);
  1672. /*------------------------------------------------------
  1673. * Pre :
  1674. * Post : Returns number of collision boxes in room ( unified )
  1675. *
  1676. *-- History ------------------------------------------
  1677. *
  1678. * 2003.05.24:
  1679. * Mongoose - Created
  1680. ------------------------------------------------------*/
  1681. void getRoomInfo(unsigned int index,
  1682. unsigned int *flags, float pos[3],
  1683. float bboxMin[3], float bboxMax[3]);
  1684. /*------------------------------------------------------
  1685. * Pre :
  1686. * Post :
  1687. *
  1688. *-- History ------------------------------------------
  1689. *
  1690. * 2003.05.24:
  1691. * Mongoose - Created
  1692. ------------------------------------------------------*/
  1693. int getRoomLight(unsigned int roomIndex, unsigned int index,
  1694. float pos[4], float color[4], float dir[3],
  1695. float *attenuation, float *cutoffAngle,
  1696. unsigned int *type, unsigned int *flags);
  1697. /*------------------------------------------------------
  1698. * Pre : All parms are allocated
  1699. * Post : Returns a single light from a room ( unified )
  1700. *
  1701. *-- History ------------------------------------------
  1702. *
  1703. * 2003.05.19:
  1704. * Mongoose - Created
  1705. ------------------------------------------------------*/
  1706. unsigned int getRoomLightCount(unsigned int roomIndex);
  1707. /*------------------------------------------------------
  1708. * Pre :
  1709. * Post : Returns number of lights in room ( unified )
  1710. *
  1711. *-- History ------------------------------------------
  1712. *
  1713. * 2003.05.24:
  1714. * Mongoose - Created
  1715. ------------------------------------------------------*/
  1716. int getRoomModel(unsigned int roomIndex, unsigned int index,
  1717. int *modelIndex, float pos[3], float *yaw);
  1718. /*------------------------------------------------------
  1719. * Pre : All parms are allocated
  1720. * Post : Returns a single model info from a room ( unified )
  1721. *
  1722. *-- History ------------------------------------------
  1723. *
  1724. * 2003.05.19:
  1725. * Mongoose - Created
  1726. ------------------------------------------------------*/
  1727. unsigned int getRoomModelCount(unsigned int roomIndex);
  1728. /*------------------------------------------------------
  1729. * Pre :
  1730. * Post : Returns number of room models in room ( unified )
  1731. *
  1732. *-- History ------------------------------------------
  1733. *
  1734. * 2003.05.24:
  1735. * Mongoose - Created
  1736. ------------------------------------------------------*/
  1737. int getRoomPortal(unsigned int roomIndex, unsigned int index,
  1738. int *adjoiningRoom, float normal[3], float vertices[12]);
  1739. /*------------------------------------------------------
  1740. * Pre :
  1741. * Post : Returns a single portal from room ( unified )
  1742. *
  1743. *-- History ------------------------------------------
  1744. *
  1745. * 2003.05.24:
  1746. * Mongoose - Created
  1747. ------------------------------------------------------*/
  1748. unsigned int getRoomPortalCount(unsigned int roomIndex);
  1749. /*------------------------------------------------------
  1750. * Pre :
  1751. * Post : Returns number of portals from room ( unified )
  1752. *
  1753. *-- History ------------------------------------------
  1754. *
  1755. * 2003.05.24:
  1756. * Mongoose - Created
  1757. ------------------------------------------------------*/
  1758. void getRoomRectangle(unsigned int roomIndex, unsigned int rectangleIndex,
  1759. unsigned int *indices, float *texCoords, int *texture,
  1760. unsigned int *flags);
  1761. /*------------------------------------------------------
  1762. * Pre :
  1763. * Post : Gets rectangle data with texCoords for non-matching
  1764. * vertex/uv for each vertex in TombRaider room ( unified )
  1765. *
  1766. *-- History ------------------------------------------
  1767. *
  1768. * 2003.05.24:
  1769. * Mongoose - Created
  1770. ------------------------------------------------------*/
  1771. unsigned int getRoomRectangleCount(unsigned int roomIndex);
  1772. /*------------------------------------------------------
  1773. * Pre :
  1774. * Post : Returns number of rectangles from room ( unified )
  1775. *
  1776. *-- History ------------------------------------------
  1777. *
  1778. * 2003.05.24:
  1779. * Mongoose - Created
  1780. ------------------------------------------------------*/
  1781. int getRoomSector(unsigned int roomIndex, unsigned int index,
  1782. unsigned int *flags, float *ceiling, float *floor,
  1783. int *floorDataIndex, int *boxIndex,
  1784. int *roomBelow, int *roomAbove);
  1785. /*------------------------------------------------------
  1786. * Pre :
  1787. * Post : Returns a single sector from room ( unified )
  1788. *
  1789. *-- History ------------------------------------------
  1790. *
  1791. * 2003.05.24:
  1792. * Mongoose - Created
  1793. ------------------------------------------------------*/
  1794. unsigned int getRoomSectorCount(unsigned int roomIndex,
  1795. unsigned int *zSectorsCount,
  1796. unsigned int *xSectorsCount);
  1797. /*------------------------------------------------------
  1798. * Pre :
  1799. * Post : Returns number of sectors in room ( unified )
  1800. * zSectorsCount - width of sector list
  1801. * xSectorsCount - height of sector list
  1802. *
  1803. *-- History ------------------------------------------
  1804. *
  1805. * 2003.05.24:
  1806. * Mongoose - Created
  1807. ------------------------------------------------------*/
  1808. void getRoomSprite(unsigned int roomIndex, unsigned int index,
  1809. float scale, int *texture,
  1810. float *pos, float *vertices, float *texcoords);
  1811. /*------------------------------------------------------
  1812. * Pre :
  1813. * Post :
  1814. *
  1815. *-- History ------------------------------------------
  1816. *
  1817. * 2003.05.19:
  1818. * Mongoose - Created
  1819. ------------------------------------------------------*/
  1820. unsigned int getRoomSpriteCount(unsigned int roomIndex);
  1821. /*------------------------------------------------------
  1822. * Pre :
  1823. * Post : Returns number of sprites in room ( unified )
  1824. *
  1825. *-- History ------------------------------------------
  1826. *
  1827. * 2003.05.24:
  1828. * Mongoose - Created
  1829. ------------------------------------------------------*/
  1830. void getRoomTriangle(unsigned int roomIndex, unsigned int triangleIndex,
  1831. unsigned int *indices, float *texCoords, int *texture,
  1832. unsigned int *flags);
  1833. /*------------------------------------------------------
  1834. * Pre :
  1835. * Post : Gets triangle data with texCoords for non-matching
  1836. * vertex/uv for each vertex in TombRaider room ( unified )
  1837. *
  1838. *-- History ------------------------------------------
  1839. *
  1840. * 2003.05.24:
  1841. * Mongoose - Created
  1842. ------------------------------------------------------*/
  1843. void getRoomTriangles(unsigned int index, int textureOffset,
  1844. unsigned int *count, unsigned int **indices,
  1845. float **texCoords, int **textures,
  1846. unsigned int **flags);
  1847. /*------------------------------------------------------
  1848. * Pre :
  1849. * Post : Gets triangle data with texCoords for non-matching
  1850. * vertex/uv for each vertex in TombRaider room
  1851. *
  1852. * This is used with room vertices, colors, etc
  1853. * to do partial array rendering, since the texcoords
  1854. * will never match vertices ( Tomb Raider is textile based )
  1855. *
  1856. *-- History ------------------------------------------
  1857. *
  1858. * 2003.05.24:
  1859. * Mongoose - Created
  1860. ------------------------------------------------------*/
  1861. void getRoomTriangles(unsigned int roomIndex, int textureOffset,
  1862. unsigned int *count,
  1863. unsigned int **indices, float **vertices,
  1864. float **texCoords, float **colors,
  1865. int **textures, unsigned int **flags);
  1866. /*------------------------------------------------------
  1867. * Pre :
  1868. * Post : Gets triangle data with duplicated
  1869. * vertex/color/normal data for each face vertex
  1870. * to match the textile based texcoords
  1871. *
  1872. * This uses more memory, but lets you do direct
  1873. * array rendering with OpenGL, D3D, etc
  1874. *
  1875. *-- History ------------------------------------------
  1876. *
  1877. * 2003.05.24:
  1878. * Mongoose - Created
  1879. ------------------------------------------------------*/
  1880. unsigned int getRoomTriangleCount(unsigned int roomIndex);
  1881. /*------------------------------------------------------
  1882. * Pre :
  1883. * Post : Returns number of triangles from room ( unified )
  1884. *
  1885. *-- History ------------------------------------------
  1886. *
  1887. * 2003.05.24:
  1888. * Mongoose - Created
  1889. ------------------------------------------------------*/
  1890. void getRoomVertex(unsigned int roomIndex, unsigned int vertexIndex,
  1891. float *xyz, float *rgba);
  1892. /*------------------------------------------------------
  1893. * Pre : Given room index and vertex index and
  1894. * xyz is allocated float[3]
  1895. * rbga is allocated float[4]
  1896. *
  1897. * Post : Returns vertex position xyz and color rbga
  1898. *
  1899. *-- History ------------------------------------------
  1900. *
  1901. * 2003.05.13:
  1902. * Mongoose - Created, based on method from OpenRaider
  1903. ------------------------------------------------------*/
  1904. void getRoomVertexArrays(unsigned int roomIndex,
  1905. unsigned int *vertexCount, float **vertices,
  1906. unsigned int *normalCount, float **normals,
  1907. unsigned int *colorCount, float **colors);
  1908. /*------------------------------------------------------
  1909. * Pre : Given room index
  1910. *
  1911. * Post : Returns allocated vertex and color arrays,
  1912. * and their element counts ( unified )
  1913. *
  1914. *-- History ------------------------------------------
  1915. *
  1916. * 2003.05.24:
  1917. * Mongoose - Unified API
  1918. *
  1919. * 2003.05.13:
  1920. * Mongoose - Created, based on method from OpenRaider
  1921. ------------------------------------------------------*/
  1922. unsigned int getRoomVertexCount(unsigned int roomIndex);
  1923. /*------------------------------------------------------
  1924. * Pre :
  1925. * Post : Returns number of lights in room ( unified )
  1926. *
  1927. *-- History ------------------------------------------
  1928. *
  1929. * 2003.05.24:
  1930. * Mongoose - Created
  1931. ------------------------------------------------------*/
  1932. int getSkyModelId();
  1933. /*------------------------------------------------------
  1934. * Pre :
  1935. * Post : Returns moveable id of sky mesh or -1 if none
  1936. *
  1937. *-- History ------------------------------------------
  1938. *
  1939. * 2001.05.28:
  1940. * Mongoose - Created
  1941. ------------------------------------------------------*/
  1942. void getSprites();
  1943. void getSoundSample(unsigned int index,
  1944. unsigned int *bytes, unsigned char **data);
  1945. /*------------------------------------------------------
  1946. * Pre :
  1947. * Post : Returns a copy of a sound sample and
  1948. * its byte size by it's sound sample index
  1949. *
  1950. *-- History ------------------------------------------
  1951. *
  1952. * 2003.05.10:
  1953. * Mongoose - Created
  1954. ------------------------------------------------------*/
  1955. unsigned int getSoundSamplesCount();
  1956. /*------------------------------------------------------
  1957. * Pre :
  1958. * Post : Returns number of sound samples loaded
  1959. *
  1960. *-- History ------------------------------------------
  1961. *
  1962. * 2003.05.10:
  1963. * Mongoose - Created
  1964. ------------------------------------------------------*/
  1965. bool isMeshValid(int index);
  1966. /*------------------------------------------------------
  1967. * Pre :
  1968. * Post : Returns true if mesh is valid
  1969. *
  1970. *-- History ------------------------------------------
  1971. *
  1972. * 2003.05.16:
  1973. * Mongoose - Created
  1974. ------------------------------------------------------*/
  1975. bool isRoomValid(int index);
  1976. /*------------------------------------------------------
  1977. * Pre :
  1978. * Post : Returns true if room is valid ( TRC support )
  1979. *
  1980. *-- History ------------------------------------------
  1981. *
  1982. * 2003.05.24:
  1983. * Mongoose - Created
  1984. ------------------------------------------------------*/
  1985. ////////////////////////////////////////////////////////////
  1986. // Public Mutators
  1987. ////////////////////////////////////////////////////////////
  1988. int loadSFX(char *filename);
  1989. /*------------------------------------------------------
  1990. * Pre :
  1991. * Post : Loads an external sound pak for TR2 and TR3
  1992. * games. Returns < 0 if error.
  1993. *
  1994. *-- History ------------------------------------------
  1995. *
  1996. * 2003.05.12:
  1997. * Mongoose - Created
  1998. ------------------------------------------------------*/
  1999. void reset();
  2000. /*------------------------------------------------------
  2001. * Pre :
  2002. * Post :
  2003. *
  2004. *-- History ------------------------------------------
  2005. *
  2006. * 2003.05.13:
  2007. * Mongoose - New API, was Clear()
  2008. *
  2009. * 2000.05.13:
  2010. * Mongoose - Created
  2011. ------------------------------------------------------*/
  2012. void setDebug(bool toggle);
  2013. /*------------------------------------------------------
  2014. * Pre :
  2015. * Post :
  2016. *
  2017. *-- History ------------------------------------------
  2018. *
  2019. * 2000.05.13:
  2020. * Mongoose - Created
  2021. ------------------------------------------------------*/
  2022. void setRoomVertexLightingFactor(float f);
  2023. /*------------------------------------------------------
  2024. * Pre :
  2025. * Post : Sets lighting factor for each vertex color per
  2026. * room in TR3 paks
  2027. *
  2028. *-- History ------------------------------------------
  2029. *
  2030. * 2003.05.13:
  2031. * Mongoose - Created
  2032. ------------------------------------------------------*/
  2033. void setTexelScalingFactor(float f);
  2034. /*------------------------------------------------------
  2035. * Pre :
  2036. * Post : Sets scaling for sprite texel alignment, etc
  2037. *
  2038. *-- History ------------------------------------------
  2039. *
  2040. * 2003.05.22:
  2041. * Mongoose - Created
  2042. ------------------------------------------------------*/
  2043. private:
  2044. ////////////////////////////////////////////////////////////
  2045. // Private Accessors
  2046. ////////////////////////////////////////////////////////////
  2047. void extractMeshes(unsigned char *mesh_data,
  2048. unsigned int num_mesh_pointers,
  2049. unsigned int *mesh_pointers);
  2050. /*------------------------------------------------------
  2051. * Pre :
  2052. * Post :
  2053. *
  2054. *-- History ------------------------------------------
  2055. *
  2056. * 2000.05.13:
  2057. * Mongoose - Created
  2058. ------------------------------------------------------*/
  2059. int Fread(void *buffer, size_t size, size_t count, FILE *f);
  2060. /*------------------------------------------------------
  2061. * Pre :
  2062. * Post :
  2063. *
  2064. *-- History ------------------------------------------
  2065. *
  2066. * 2000.05.13:
  2067. * Mongoose - Created
  2068. ------------------------------------------------------*/
  2069. void getRiffData(unsigned int *bytes, unsigned char **data);
  2070. /*------------------------------------------------------
  2071. * Pre :
  2072. * Post : Returns a copy of the sound samples and
  2073. * their size
  2074. *
  2075. *-- History ------------------------------------------
  2076. *
  2077. * 2003.05.10:
  2078. * Mongoose - Created
  2079. ------------------------------------------------------*/
  2080. void getRiffDataTR4(unsigned int index,
  2081. unsigned int *bytes, unsigned char **data);
  2082. /*------------------------------------------------------
  2083. * Pre :
  2084. * Post : Returns a copy of a TR4 sound sample
  2085. * and its size by it's sound sample index
  2086. *
  2087. *-- History ------------------------------------------
  2088. *
  2089. * 2003.05.10:
  2090. * Mongoose - Created
  2091. ------------------------------------------------------*/
  2092. int getRiffOffsets(unsigned char *riffData, unsigned int riffDataBytes,
  2093. unsigned int **offsets, unsigned int numOffsets);
  2094. /*------------------------------------------------------
  2095. * Pre :
  2096. * Post : Returns an array of offsets for a contigous
  2097. * RIFF data stream in chunks.
  2098. *
  2099. * Offsets will be allocated with enough space
  2100. * to hold expected number of offsets.
  2101. * ( Should be known number, otherwise not
  2102. * all RIFFs will be parsed. )
  2103. *
  2104. * Returns number of RIFFs found
  2105. *
  2106. *-- History ------------------------------------------
  2107. *
  2108. * 2003.05.12:
  2109. * Mongoose - Created
  2110. ------------------------------------------------------*/
  2111. unsigned char *getTexTile(int texture);
  2112. /*------------------------------------------------------
  2113. * Pre : texture is valid index into textile list
  2114. *
  2115. * Post : Makes a 32bit RGBA image from a textile
  2116. * and returns it. Returns NULL on error.
  2117. *
  2118. * This handles all selection and conversion
  2119. * including alpha layering flags now.
  2120. *
  2121. *-- History ------------------------------------------
  2122. *
  2123. * 2001.05.28:
  2124. * Mongoose - Created
  2125. ------------------------------------------------------*/
  2126. int loadTR5(FILE *f, void (*percent)(int));
  2127. /*------------------------------------------------------
  2128. * Pre : f is a valid FILE and percent is allocated
  2129. * Post : Loads a TR5 pak into memory
  2130. *
  2131. * At 10% all textures are loaded
  2132. * the exact figure '10' will always be passed to
  2133. * allow for texture caching while meshes load
  2134. *
  2135. *-- History ------------------------------------------
  2136. *
  2137. * 2002.01.02:
  2138. * Mongoose - New callback for percent loaded feedback
  2139. *
  2140. * 2001.06.18:
  2141. * Mongoose - Created
  2142. ------------------------------------------------------*/
  2143. void print(const char *methodName, const char *s, ...);
  2144. /*------------------------------------------------------
  2145. * Pre :
  2146. * Post :
  2147. *
  2148. *-- History ------------------------------------------
  2149. *
  2150. * 2003.05.13:
  2151. * Mongoose - New API clean up
  2152. *
  2153. * 2000.05.13:
  2154. * Mongoose - Created
  2155. ------------------------------------------------------*/
  2156. void printDebug(const char *methodName, const char *s, ...);
  2157. /*------------------------------------------------------
  2158. * Pre :
  2159. * Post :
  2160. *
  2161. *-- History ------------------------------------------
  2162. *
  2163. * 2003.05.13:
  2164. * Mongoose - New API clean up
  2165. *
  2166. * 2000.05.13:
  2167. * Mongoose - Created
  2168. ------------------------------------------------------*/
  2169. ////////////////////////////////////////////////////////////
  2170. // Private Mutators
  2171. ////////////////////////////////////////////////////////////
  2172. bool mReset; /* Guard multiple calls to reset() */
  2173. bool mDebug; /* Debug output toggle */
  2174. unsigned int mPakVersion; /* TombRaider pak file header version */
  2175. tr2_version_type mEngineVersion; /* TombRaider engine version */
  2176. tr2_colour_t _palette8[256]; /* 8-bit palette */
  2177. unsigned int _palette16[256]; /* 16-bit palette */
  2178. unsigned int _num_textiles; /* Total number of texture tiles */
  2179. unsigned short _num_room_textures; /* Num textures only for room use? */
  2180. unsigned short _num_misc_textures; /* Num of textures for misc use? */
  2181. unsigned short _num_bump_map_textures; /* Num of textures that are
  2182. bump map, texture pairs */
  2183. tr2_textile8_t *_textile8; /* 8-bit (palettised) textiles */
  2184. tr2_textile16_t *_textile16; /* 16-bit (ARGB) textiles */
  2185. tr2_textile32_t *_textile32; /* 32-bit (BGRA) textiles */
  2186. unsigned int _num_tex_special; /* Special textures and bump maps count */
  2187. unsigned char *_tex_special; /* Special textures and bump maps */
  2188. unsigned int _unknown_t; /* 32-bit unknown
  2189. (always 0 in real TR2 levels) */
  2190. unsigned short _num_rooms; /* Number of rooms in this level */
  2191. tr2_room_t *_rooms; /* List of rooms (TR1,TR2,TR3,TR4) */
  2192. tr5_room_t *mRoomsTR5; /* Rooms ( TR5 / TRC ) Only */
  2193. unsigned int _num_floor_data; /* Num of words of floor data
  2194. this level */
  2195. unsigned short *_floor_data; /* Floor data */
  2196. int mMeshCount; /* Number of meshes this level */
  2197. tr2_mesh_t *mMeshes; /* list of meshes */
  2198. unsigned int _num_animations; /* number of animations this level */
  2199. tr2_animation_t *_animations; /* list of animations */
  2200. unsigned int _num_state_changes; /* number of structures(?) this level */
  2201. tr2_state_change_t *_state_changes; /* list of structures */
  2202. unsigned int _num_anim_dispatches; /* number of ranges(?) this level */
  2203. tr2_anim_dispatch_t *_anim_dispatches; /* list of ranges */
  2204. unsigned int _num_anim_commands; /* number of Bone1s this level */
  2205. tr2_anim_command_t *_anim_commands; /* list of Bone1s */
  2206. unsigned int _num_mesh_trees; /* number of Bone2s this level */
  2207. tr2_meshtree_t *_mesh_trees; /* list of Bone2s */
  2208. unsigned int _num_frames; /* num of words of frame data this level */
  2209. unsigned short *_frames; /* frame data */
  2210. unsigned int _num_moveables; /* number of moveables this level */
  2211. tr2_moveable_t *_moveables; /* list of moveables */
  2212. u_int32_t numMoveablesTR5;
  2213. tr5_moveable_t *moveablesTR5;
  2214. u_int32_t numAnimationsTR5;
  2215. tr5_animation_t *animationsTR5;
  2216. u_int32_t numObjectTexturesTR5;
  2217. tr5_object_texture_t *objectTexturesTR5;
  2218. u_int32_t numCinematicFramesTR5;
  2219. tr5_cinematic_frame_t *cinematicFramesTR5;
  2220. u_int32_t numFlyByCamerasTR5;
  2221. tr5_flyby_camera_t *flyByCamerasTR5;
  2222. unsigned int _num_static_meshes; /* number of static meshes this level */
  2223. tr2_staticmesh_t *_static_meshes; /* static meshes */
  2224. unsigned int _num_object_textures; /* number of object textures this level */
  2225. tr2_object_texture_t *_object_textures; /* list of object textures */
  2226. unsigned int _num_sprite_textures; /* num of sprite textures this level */
  2227. tr2_sprite_texture_t *_sprite_textures; /* list of sprite textures */
  2228. unsigned int _num_sprite_sequences; /* num of sprite sequences this level */
  2229. tr2_sprite_sequence_t *_sprite_sequences; /* sprite sequence data */
  2230. int _num_cameras; /* Number of Cameras */
  2231. tr2_camera_t *_cameras; /* cameras */
  2232. int _num_sound_sources; /* Number of Sounds */
  2233. tr2_sound_source_t *_sound_sources; /* sounds */
  2234. int _num_boxes; /* Number of Boxes */
  2235. tr2_box_t *_boxes; /* boxes - looks like
  2236. struct { unsigned short value[4]; }
  2237. - value[0..2] might be a vector;
  2238. value[3] seems to be index into
  2239. Overlaps[] */
  2240. int _num_overlaps; /* Number of Overlaps */
  2241. short *_overlaps; /* Overlaps -
  2242. looks like ushort; 0x8000 is flag
  2243. of some sort appears to be an
  2244. offset into Boxes[] and/or
  2245. Boxes2[] */
  2246. short *_zones; /* Boxes2 */
  2247. int _num_animated_textures; /* Number of AnimTextures */
  2248. short *_animated_textures; /* Animtextures */
  2249. int _num_items; /* Number of Items */
  2250. tr2_item_t *_items; /* Items */
  2251. unsigned char *_light_map; /* Colour-light maps */
  2252. unsigned int _num_cinematic_frames; /* Number of cut-scene frames */
  2253. tr2_cinematic_frame_t *_cinematic_frames; /* Cut-scene frames */
  2254. short _num_demo_data; /* Number of Demo Data */
  2255. unsigned char *_demo_data; /* Demo data */
  2256. float mRoomVertexLightingFactor;
  2257. float mTexelScale;
  2258. // Sound data
  2259. short *mSoundMap; /* Sound map */
  2260. int mNumSoundDetails; /* Number of SampleModifiers */
  2261. tr2_sound_details_t *mSoundDetails; /* Sample modifiers */
  2262. int mNumSampleIndices; /* Number of Sample Indices */
  2263. int *mSampleIndices; /* Sample indices */
  2264. unsigned int *mSampleIndicesTR5;
  2265. bool mRiffAlternateLoaded; /* Is a TR2,TR3 SFX loaded? */
  2266. unsigned int *mRiffAlternateOffsets; /* After parsing this will
  2267. hold byte offsets for TR2,TR3
  2268. RIFFs in the buffered SFX */
  2269. int mRiffDataSz; /* Byte size of a loaded SFX */
  2270. unsigned char *mRiffData; /* SFX RIFF data in chunks */
  2271. unsigned int mNumTR4Samples;
  2272. unsigned char **mTR4Samples;
  2273. unsigned int *mTR4SamplesSz;
  2274. // For packed Fread emu/wrapper
  2275. unsigned char *mCompressedLevelData; /* Buffer used to emulate fread
  2276. with uncompressed libz data */
  2277. unsigned int mCompressedLevelDataOffset; /* Offset into buffer */
  2278. unsigned int mCompressedLevelSize; /* Size of buffer */
  2279. tr_fread_mode_t mFreadMode; /* Fread mode file|buffer */
  2280. };
  2281. #endif