mirror of
				https://github.com/halpz/re3.git
				synced 2025-10-23 09:37:22 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			3736 lines
		
	
	
		
			124 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			3736 lines
		
	
	
		
			124 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /******************************************/
 | |
| /*                                        */
 | |
| /*    RenderWare(TM) Graphics Library     */
 | |
| /*                                        */
 | |
| /******************************************/
 | |
| 
 | |
| /*
 | |
|  * This file is a product of Criterion Software Ltd.
 | |
|  *
 | |
|  * This file is provided as is with no warranties of any kind and is
 | |
|  * provided without any obligation on Criterion Software Ltd.
 | |
|  * or Canon Inc. to assist in its use or modification.
 | |
|  *
 | |
|  * Criterion Software Ltd. and Canon Inc. will not, under any
 | |
|  * circumstances, be liable for any lost revenue or other damages
 | |
|  * arising from the use of this file.
 | |
|  *
 | |
|  * Copyright (c) 1999. Criterion Software Ltd.
 | |
|  * All Rights Reserved.
 | |
|  */
 | |
| 
 | |
| /*************************************************************************
 | |
|  *
 | |
|  * Filename: <C:/daily/rwsdk/include/d3d8/rpworld.h>
 | |
|  * Automatically Generated on: Wed Jul 10 10:45:01 2002
 | |
|  *
 | |
|  ************************************************************************/
 | |
| 
 | |
| #ifndef RPWORLD_H
 | |
| #define RPWORLD_H
 | |
| 
 | |
| /*--- Check For Previous Required Includes ---*/
 | |
| #ifndef RWCORE_H
 | |
| #error "Include RWCORE.H before including this file"
 | |
| #endif /* RWCORE_H */
 | |
| 
 | |
| /*--- System Header Files ---*/
 | |
| #include <stdarg.h>
 | |
| #include <stdlib.h>
 | |
| 
 | |
| /*--- Error enumerations ---*/
 | |
| #include "rpworld.rpe"
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/world/pipe/p2/d3d8/native.h ---*/
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/world/pipe/p2/d3d8/wrldpipe.h ---*/
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/world/pipe/p2/d3d8/nodeD3D8WorldSectorAllInOne.h ---*/
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| extern RxNodeDefinition *RxNodeDefinitionGetD3D8WorldSectorAllInOne(void);
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/world/pipe/p2/d3d8/nodeD3D8AtomicAllInOne.h ---*/
 | |
| #ifdef __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| extern RxNodeDefinition *RxNodeDefinitionGetD3D8AtomicAllInOne(void);
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/world/pipe/p2/d3d8/D3D8VertexBufferManager.h ---*/
 | |
| #ifdef    __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif /* __cplusplus */
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/world/pipe/p2/nodeWorldSectorInstance.h ---*/
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| extern RxNodeDefinition *RxNodeDefinitionGetWorldSectorInstance(void);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/world/pipe/p2/nodeWorldSectorEnumerateLights.h ---*/
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| extern RxNodeDefinition *RxNodeDefinitionGetWorldSectorEnumerateLights(void);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/world/pipe/p2/nodePreLight.h ---*/
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| extern RxNodeDefinition *RxNodeDefinitionGetPreLight(void);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/world/pipe/p2/nodePostLight.h ---*/
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| extern RxNodeDefinition *RxNodeDefinitionGetPostLight(void);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/world/pipe/p2/nodeMaterialScatter.h ---*/
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| extern RxNodeDefinition *RxNodeDefinitionGetMaterialScatter(void);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/world/pipe/p2/nodeLight.h ---*/
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| extern RxNodeDefinition *RxNodeDefinitionGetLight(void);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/world/pipe/p2/nodeFastPathSplitter.h ---*/
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| extern RxNodeDefinition *RxNodeDefinitionGetFastPathSplitter(void);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/world/pipe/p2/nodeAtomicInstance.h ---*/
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| extern RxNodeDefinition *RxNodeDefinitionGetAtomicInstance(void);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/world/pipe/p2/nodeAtomicEnumerateLights.h ---*/
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| extern RxNodeDefinition *RxNodeDefinitionGetAtomicEnumerateLights(void);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: c:/daily/rwsdk/world/bamateri.h ---*/
 | |
| 
 | |
| /*
 | |
|  * Handling surface materials
 | |
|  * Materials describe how things are to appear when rendered
 | |
|  *
 | |
|  * Copyright (c) 1998 Criterion Software Ltd.
 | |
|  */
 | |
| 
 | |
| /****************************************************************************
 | |
|  Global Types
 | |
|  */
 | |
| 
 | |
| 
 | |
| typedef struct RpMaterialChunkInfo RpMaterialChunkInfo;
 | |
| typedef struct RpMaterialChunkInfo _rpMaterial;
 | |
| 
 | |
| struct RpMaterialChunkInfo
 | |
| {
 | |
|     RwInt32             flags;  /**<  Material flags - unused currently - 
 | |
|                                    for future expansion */
 | |
|     RwRGBA              color;  /**<  Colour of material. */
 | |
|     RwInt32             unused;  /**<  Not used */
 | |
|     RwBool              textured;  /**<  Are we textured? */
 | |
|     RwSurfaceProperties surfaceProps;   /**<  Surface properties */
 | |
| };
 | |
| 
 | |
| #if (!defined(RwMaterialAssign))
 | |
| #define RwMaterialAssign(_target, _source)             \
 | |
|     ( *(_target) = *(_source) )
 | |
| #endif /* (!defined(RwMaterialAssign)) */
 | |
| 
 | |
| /**
 | |
|  * \ingroup rpworlddatatypes
 | |
|  * \typedef RpMaterial 
 | |
|  * Material object. This should be 
 | |
|  * considered an opaque type. Use the RpMaterial API functions to access.
 | |
|  */
 | |
| typedef struct RpMaterial RpMaterial;
 | |
| 
 | |
| #if (!defined(DOXYGEN))
 | |
| struct RpMaterial
 | |
| {
 | |
|         RwTexture           *texture; /**< texture */
 | |
|         RwRGBA              color; /**< color */              
 | |
|         RxPipeline          *pipeline; /**< pipeline */     
 | |
|         RwSurfaceProperties surfaceProps; /**< surfaceProps */
 | |
|         RwInt16             refCount;          /* C.f. rwsdk/world/bageomet.h:RpGeometry */
 | |
|         RwInt16             pad;
 | |
| };
 | |
| #endif /* (!defined(DOXYGEN)) */
 | |
| 
 | |
| /**
 | |
|  * \ingroup rpworlddatatypes
 | |
|  * \typedef RpMaterialCallBack
 | |
|  \ref RpMaterialCallBack 
 | |
|  * represents the function called from \ref RpGeometryForAllMaterials and 
 | |
|  * \ref RpWorldForAllMaterials for all materials referenced by polygons in a 
 | |
|  * given geometry. This function should return a pointer to the current 
 | |
|  * material to indicate success. The callback may return NULL to terminate 
 | |
|  * further callbacks on the materials.
 | |
|  * 
 | |
|  * \param  material   Pointer to the current material
 | |
|  * \param  data  Pointer to developer-defined data structure.
 | |
|  * 
 | |
|  * \return Pointer to the current material.
 | |
|  */
 | |
| typedef RpMaterial *(*RpMaterialCallBack)(RpMaterial *material, void *data);
 | |
| 
 | |
| /****************************************************************************
 | |
|  <macro/inline functionality
 | |
|  */
 | |
| 
 | |
| #define RpMaterialAddRefMacro(_material)                            \
 | |
|     (((_material)->refCount++), (_material))
 | |
| 
 | |
| #define RpMaterialAddRefVoidMacro(_material)                        \
 | |
| MACRO_START                                                         \
 | |
| {                                                                   \
 | |
|     (_material)->refCount++;                                        \
 | |
| }                                                                   \
 | |
| MACRO_STOP
 | |
| 
 | |
| 
 | |
| #define RpMaterialSetColorMacro(_material, _color)                  \
 | |
|     (RwRGBAAssign(&((_material)->color), (_color)), (_material))
 | |
| 
 | |
| #define RpMaterialGetColorMacro(_material)                          \
 | |
|     (&((_material)->color))
 | |
| 
 | |
| #define RpMaterialSetSurfacePropertiesMacro(_material, _surfProps)  \
 | |
|     (RwSurfacePropertiesAssign(&((_material)->surfaceProps),        \
 | |
|                                (_surfProps)), (_material))
 | |
| 
 | |
| #define RpMaterialSetSurfacePropertiesVoidMacro(_material, _surfProps)  \
 | |
| MACRO_START                                                             \
 | |
| {                                                                       \
 | |
|     RwSurfacePropertiesAssign(&((_material)->surfaceProps),             \
 | |
|                               (_surfProps));                            \
 | |
| }                                                                       \
 | |
| MACRO_STOP
 | |
| 
 | |
| #define RpMaterialGetSurfacePropertiesMacro(_material)              \
 | |
|     (&((_material)->surfaceProps))
 | |
| 
 | |
| #define RpMaterialGetTextureMacro(_material)                        \
 | |
|     ((_material)->texture)
 | |
| 
 | |
| 
 | |
| #if !(defined(RWDEBUG) || defined(RWSUPPRESSINLINE))
 | |
| 
 | |
| #define RpMaterialAddRef(_material)                                 \
 | |
|     RpMaterialAddRefMacro(_material)
 | |
| 
 | |
| #define RpMaterialSetColor(_material, _color)                       \
 | |
|     RpMaterialSetColorMacro(_material, _color)
 | |
| 
 | |
| #define RpMaterialGetColor(_material)                               \
 | |
|     RpMaterialGetColorMacro(_material)
 | |
| 
 | |
| #define RpMaterialSetSurfaceProperties(_material, _surfProps)       \
 | |
|     RpMaterialSetSurfacePropertiesMacro(_material, _surfProps)
 | |
| 
 | |
| #define RpMaterialGetSurfaceProperties(_material)                   \
 | |
|     RpMaterialGetSurfacePropertiesMacro(_material)
 | |
| 
 | |
| #define RpMaterialGetTexture(_material)                             \
 | |
|     RpMaterialGetTextureMacro(_material)
 | |
| 
 | |
| #endif /* (defined(RWDEBUG) || defined(RWSUPPRESSINLINE)) */
 | |
| 
 | |
| /****************************************************************************
 | |
|  Function prototypes
 | |
|  */
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /* Creating, destroying and referencing materials */
 | |
| extern RpMaterial *RpMaterialCreate(void);
 | |
| extern RwBool RpMaterialDestroy(RpMaterial *material);
 | |
| extern RpMaterial *RpMaterialClone(RpMaterial *material);
 | |
| 
 | |
| /* Textures */
 | |
| extern RpMaterial *RpMaterialSetTexture(RpMaterial *material, RwTexture *texture);
 | |
| 
 | |
| 
 | |
| #if (defined(RWDEBUG) || defined(RWSUPPRESSINLINE))
 | |
| extern RpMaterial *RpMaterialAddRef(RpMaterial *material);
 | |
| 
 | |
| /* Textures */
 | |
| extern RwTexture *RpMaterialGetTexture(const RpMaterial *material);
 | |
| 
 | |
| /* Setting and getting colors */
 | |
| extern RpMaterial *RpMaterialSetColor(RpMaterial *material, const RwRGBA *color);
 | |
| extern const RwRGBA *RpMaterialGetColor(const RpMaterial *material);
 | |
| 
 | |
| /* Setting and getting surface properties */
 | |
| extern RpMaterial *
 | |
| RpMaterialSetSurfaceProperties(RpMaterial *material,
 | |
|                                const RwSurfaceProperties *surfaceProperties);
 | |
| 
 | |
| extern const RwSurfaceProperties *
 | |
| RpMaterialGetSurfaceProperties(const RpMaterial *material);
 | |
| 
 | |
| #endif /* (defined(RWDEBUG) || defined(RWSUPPRESSINLINE)) */
 | |
| 
 | |
| 
 | |
| /* Attaching toolkits */
 | |
| extern RwInt32 RpMaterialRegisterPlugin(RwInt32 size, RwUInt32 pluginID,
 | |
|                                         RwPluginObjectConstructor constructCB,
 | |
|                                         RwPluginObjectDestructor destructCB,
 | |
|                                         RwPluginObjectCopy copyCB);
 | |
| extern RwInt32 RpMaterialRegisterPluginStream(RwUInt32 pluginID,
 | |
|                                               RwPluginDataChunkReadCallBack readCB,
 | |
|                                               RwPluginDataChunkWriteCallBack writeCB,
 | |
|                                               RwPluginDataChunkGetSizeCallBack getSizeCB);
 | |
| extern RwInt32 RpMaterialSetStreamAlwaysCallBack(
 | |
|                         RwUInt32 pluginID,
 | |
|                         RwPluginDataChunkAlwaysCallBack alwaysCB);
 | |
| extern RwInt32 RpMaterialGetPluginOffset(RwUInt32 pluginID);
 | |
| extern RwBool RpMaterialValidatePlugins(const RpMaterial *material);
 | |
| 
 | |
| /* Binary format */
 | |
| extern RwUInt32 RpMaterialStreamGetSize(const RpMaterial *material);
 | |
| extern RpMaterial *RpMaterialStreamRead(RwStream *stream);
 | |
| extern const RpMaterial *RpMaterialStreamWrite(const RpMaterial *material, RwStream *stream);
 | |
| extern RpMaterialChunkInfo *
 | |
| _rpMaterialChunkInfoRead(RwStream *stream, 
 | |
|                          RpMaterialChunkInfo *materialChunkInfo, 
 | |
|                          RwInt32 *bytesRead);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| #define RpMaterialChunkInfoRead(stream, materialChunkInfo, bytesRead) \
 | |
|        _rpMaterialChunkInfoRead(stream, materialChunkInfo, bytesRead)
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: c:/daily/rwsdk/world/bamatlst.h ---*/
 | |
| /****************************************************************************
 | |
|  Global Types
 | |
|  */
 | |
| 
 | |
| typedef struct RpMaterialList RpMaterialList;
 | |
| struct RpMaterialList
 | |
| {
 | |
|     RpMaterial     **materials;
 | |
|     RwInt32        numMaterials;
 | |
|     RwInt32        space;
 | |
| };
 | |
| 
 | |
| /****************************************************************************
 | |
|  Function prototypes
 | |
|  */
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| #define rpMaterialListGetNumMaterials(mlist) ((mlist)->numMaterials)
 | |
| 
 | |
| /* Setting up and destroying material lists */
 | |
| extern RpMaterialList *_rpMaterialListInitialize(RpMaterialList *matList);
 | |
| extern RpMaterialList *_rpMaterialListDeinitialize(RpMaterialList *matList);
 | |
| 
 | |
| /* Accessing material lists */
 | |
| extern RpMaterial     ** _rpMaterialListAlloc(RwUInt32 count);
 | |
| extern RpMaterial *_rpMaterialListGetMaterial(const RpMaterialList *matList,
 | |
|                                              RwInt32 matIndex);
 | |
| extern RpMaterialList * _rpMaterialListSetSize(RpMaterialList * matList, 
 | |
|                                                RwInt32 size);
 | |
| extern RpMaterialList *_rpMaterialListCopy(RpMaterialList *matListOut,
 | |
|                                           const RpMaterialList *matListIn);
 | |
| extern RwInt32 _rpMaterialListAppendMaterial(RpMaterialList *matList,
 | |
|                                             RpMaterial *material);
 | |
| extern RwInt32 _rpMaterialListFindMaterialIndex(const RpMaterialList *matList,
 | |
|                                                const RpMaterial *material);
 | |
| 
 | |
| /* Binary format */
 | |
| extern RwUInt32 _rpMaterialListStreamGetSize(const RpMaterialList *matList);
 | |
| extern RpMaterialList *_rpMaterialListStreamRead(RwStream *stream,
 | |
|                                                 RpMaterialList *matList);
 | |
| extern const RpMaterialList *_rpMaterialListStreamWrite(const RpMaterialList *matList,
 | |
|                                                        RwStream *stream);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| #define rpMaterialListInitialize(_matList) \
 | |
|     _rpMaterialListInitialize(_matList)
 | |
| 
 | |
| #define rpMaterialListDeinitialize(_matList) \
 | |
|     _rpMaterialListDeinitialize(_matList)
 | |
| 
 | |
| #define rpMaterialListGetMaterial(_matList, _matIndex) \
 | |
|     _rpMaterialListGetMaterial(_matList, _matIndex)
 | |
| 
 | |
| #define rpMaterialListCopy(_matListOut, _matListIn) \
 | |
|     _rpMaterialListCopy(_matListOut, _matListIn)
 | |
| 
 | |
| #define rpMaterialListAppendMaterial(_matList, _material) \
 | |
|     _rpMaterialListAppendMaterial(_matList, _material)
 | |
| 
 | |
| #define rpMaterialListStreamRead(_stream, _matList) \
 | |
|     _rpMaterialListStreamRead(_stream, _matList)
 | |
| 
 | |
| #define rpMaterialListStreamWrite(_matList, _stream) \
 | |
|     _rpMaterialListStreamWrite(_matList, _stream)
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: c:/daily/rwsdk/world/bamesh.h ---*/
 | |
| 
 | |
| /*
 | |
|  *
 | |
|  * Purpose: Provide construction and enumeration facilities for meshes.
 | |
|  *
 | |
|  * Copyright (c) 1998 Criterion Software Ltd.
 | |
|  */
 | |
| 
 | |
| #define RPMESHGLOBAL(var)                                   \
 | |
|     (RWPLUGINOFFSET(rpMeshGlobals,                          \
 | |
|                     RwEngineInstance,                       \
 | |
|                     meshModule.globalsOffset)->var)
 | |
| 
 | |
| #define rwPRIMTYPEOR                            \
 | |
|     (rwPRIMTYPELINELIST |                       \
 | |
|       rwPRIMTYPEPOLYLINE |                      \
 | |
|       rwPRIMTYPETRILIST |                       \
 | |
|       rwPRIMTYPETRISTRIP |                      \
 | |
|       rwPRIMTYPETRIFAN   |                      \
 | |
|       rwPRIMTYPEPOINTLIST)
 | |
| 
 | |
| #define rpMESHHEADERPRIMTYPEOR                  \
 | |
|     (0 /* rpMESHHEADERTRILIST*/ |               \
 | |
|       rpMESHHEADERTRISTRIP |                    \
 | |
|       rpMESHHEADERTRIFAN  |                     \
 | |
|       rpMESHHEADERLINELIST |                    \
 | |
|       rpMESHHEADERPOLYLINE |                    \
 | |
|       rpMESHHEADERPOINTLIST)
 | |
| 
 | |
| /****************************************************************************
 | |
|  Global variables
 | |
|  */
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern              "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| extern RwModuleInfo meshModule;
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| /****************************************************************************
 | |
|  Global types
 | |
|  */
 | |
| 
 | |
| /**
 | |
|  * \ingroup rpworlddatatypes
 | |
|  * \typedef RpMeshHeader
 | |
|  * typedef for header structure listing all meshes
 | |
|  * constituting a single RpGeometry or RpWorldSector
 | |
|  */
 | |
| typedef struct RpMeshHeader RpMeshHeader;
 | |
| 
 | |
| /**
 | |
|  * \ingroup rpworlddatatypes
 | |
|  * \ref RpMeshHeaderFlags
 | |
|  * represents the different types of mesh.
 | |
|  * \see RpMeshHeader
 | |
|  */
 | |
| enum RpMeshHeaderFlags
 | |
| {
 | |
|     /* NOTE: trilists are denoted by absence of any other
 | |
|      *       primtype flags, so be careful that you test:
 | |
|      *        (triListFlag == flags&triListFlag)
 | |
|      *       or:
 | |
|      *        (0 == flags&rpMESHHEADERPRIMMASK)
 | |
|      *       and not:
 | |
|      *        (flags&triListFlag)
 | |
|      */
 | |
|     rpMESHHEADERTRISTRIP  = 0x0001, /**< Render as tristrips */
 | |
|     rpMESHHEADERTRIFAN    = 0x0002, /**< On PS2 these will be converted to trilists */
 | |
|     rpMESHHEADERLINELIST  = 0x0004, /**< Render as linelists */
 | |
|     rpMESHHEADERPOLYLINE  = 0x0008, /**< On PS2 these will be converted to linelists */
 | |
|     rpMESHHEADERPOINTLIST = 0x0010, /**< Pointlists are supported only if rendered by
 | |
|                                      *   custom pipelines; there is no default RenderWare 
 | |
|                                      *   way to render pointlists. */
 | |
| 
 | |
|     rpMESHHEADERPRIMMASK  = 0x00FF, /**< All bits reserved for specifying primitive type */
 | |
|     rpMESHHEADERUNINDEXED = 0x0100, /**< Topology is defined implicitly by vertex
 | |
|                                      *   order, ergo the mesh contains no indices */
 | |
|     rpMESHHEADERFLAGSFORCEENUMSIZEINT = RWFORCEENUMSIZEINT
 | |
| };
 | |
| 
 | |
| /*
 | |
|  * Typedef for RpMeshHeaderFlags enumeration
 | |
|  * representing the different types of mesh
 | |
|  */
 | |
| typedef enum RpMeshHeaderFlags RpMeshHeaderFlags;
 | |
| 
 | |
| typedef struct rpMeshGlobals rpMeshGlobals;
 | |
| struct rpMeshGlobals
 | |
| {
 | |
|     RwInt16             nextSerialNum;
 | |
|     RwFreeList         *triStripListEntryFreeList;
 | |
|     RwUInt8             meshFlagsToPrimType[rpMESHHEADERPRIMTYPEOR];
 | |
|     RwUInt8             primTypeToMeshFlags[rwPRIMTYPEOR];
 | |
| };
 | |
| 
 | |
| typedef struct RpBuildMeshTriangle RpBuildMeshTriangle;
 | |
| 
 | |
| /**
 | |
|  * \ingroup rpworlddatatypes
 | |
|  * \struct RpBuildMeshTriangle
 | |
|  * This type represents an array of indices into
 | |
|  * the object vertex array. Used during the construction
 | |
|  * of tristrips.
 | |
|  *
 | |
|  * See API functions
 | |
|  * \see RpBuildMeshGeneratePreprocessTriStrip
 | |
|  * \see RpBuildMeshGenerateExhaustiveTriStrip
 | |
|  * \see RpBuildMeshGenerateTrivialTriStrip
 | |
|  * \see RpBuildMeshGenerateDefaultTriStrip
 | |
|  * and
 | |
|  * \see RpMeshSetTriStripMethod
 | |
|  * \see RpMeshGetTriStripMethod
 | |
|  */
 | |
| struct RpBuildMeshTriangle
 | |
| {
 | |
|     RwUInt16            vertIndex[3]; /**< indices into object vertex
 | |
|                                        *   array. */
 | |
|     RpMaterial         *material;     /**< pointer to material used to
 | |
|                                        *   render the mesh. */
 | |
| };
 | |
| 
 | |
| typedef struct RpBuildMesh RpBuildMesh;
 | |
| 
 | |
| /**
 | |
|  * \ingroup rpworlddatatypes
 | |
|  * \struct RpBuildMesh
 | |
|  * This type represents a mesh ready for tri stripping.
 | |
|  *
 | |
|  * See API functions
 | |
|  * \see RpBuildMeshGeneratePreprocessTriStrip
 | |
|  * \see RpBuildMeshGenerateExhaustiveTriStrip
 | |
|  * \see RpBuildMeshGenerateTrivialTriStrip
 | |
|  * \see RpBuildMeshGenerateDefaultTriStrip
 | |
|  * and
 | |
|  * \see RpMeshSetTriStripMethod
 | |
|  * \see RpMeshGetTriStripMethod
 | |
|  */
 | |
| struct RpBuildMesh
 | |
| {
 | |
|     RwUInt32            triangleBufferSize; /**< number of triangles
 | |
|                                              *   space has been allocated
 | |
|                                              *   for. */
 | |
|     RwUInt32            numTriangles;       /**< number of triangles to be
 | |
|                                              *   tristripped. */
 | |
|     RpBuildMeshTriangle *meshTriangles;     /**< pointer to build mesh
 | |
|                                              *   triangles. */
 | |
| };
 | |
| 
 | |
| typedef struct RpMesh RpMesh;
 | |
| 
 | |
| /**
 | |
|  * \ingroup rpworlddatatypes
 | |
|  * \struct RpMesh
 | |
|  * This type represents a single polygon mesh.
 | |
|  * A mesh is defined as a collection of triangles derived from an RpGeometry
 | |
|  * or RpWorldSector which have a common material.
 | |
|  *
 | |
|  * See API functions \see RpGeometryForAllMeshes and
 | |
|  * \see RpWorldSectorForAllMeshes and
 | |
|  * the corresponding function callback types:
 | |
|  */
 | |
| struct RpMesh
 | |
| {
 | |
|     RxVertexIndex      *indices;    /**< vertex indices defining the mesh */
 | |
|     RwUInt32            numIndices; /**< number of vertices in mesh */
 | |
|     RpMaterial         *material;   /**< pointer to material used to
 | |
|                                      *   render the mesh. */
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * \ingroup rpworlddatatypes
 | |
|  * \struct RpMeshHeader
 | |
|  * Header for all meshes that constitute a single RpGeometry or RpWorldSector
 | |
|  */
 | |
| struct RpMeshHeader
 | |
| {
 | |
|     RwUInt32            flags;    /**< \see RpMeshHeaderFlags */
 | |
|     RwUInt16            numMeshes; /**< Number of meshes in object */
 | |
|     RwUInt16            serialNum; /**< Determine if mesh has changed
 | |
|                                     * since last instance */
 | |
|     RwUInt32            totalIndicesInMesh; /**< Total triangle index
 | |
|                                              * count in all meshes
 | |
|                                              */
 | |
|     RwUInt32            firstMeshOffset; /**< Offset in bytes from end this
 | |
|                                           * structure RpMeshHeader
 | |
|                                           * to the first mesh
 | |
|                                           */
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * \ingroup rpworlddatatypes
 | |
|  * \typedef RpMeshCallBack
 | |
|  *  \ref RpMeshCallBack is the callback
 | |
|  * function supplied to \ref RpGeometryForAllMeshes and
 | |
|  * \ref RpWorldSectorForAllMeshes for all meshes in a given geometry.
 | |
|  *
 | |
|  * This function should return a pointer to the current mesh to indicate
 | |
|  * success. The callback may return NULL to terminate further callbacks
 | |
|  * on the meshes.
 | |
|  *
 | |
|  * \param  mesh   Pointer to the current mesh, supplied by
 | |
|  * iterator.
 | |
|  * \param  meshHeader   Pointer to the meshes header
 | |
|  * \param  data  Pointer to developer-defined data structure.
 | |
|  *
 | |
|  * \return
 | |
|  * Returns a pointer to the current mesh if successful or NULL if an error
 | |
|  * occurred.
 | |
|  */
 | |
| typedef RpMesh     *(*RpMeshCallBack) (RpMesh * mesh,
 | |
|                                        RpMeshHeader * meshHeader,
 | |
|                                        void *pData);
 | |
| 
 | |
| /****************************************************************************
 | |
|  Function prototypes
 | |
|  */
 | |
| 
 | |
| #if !(defined(RWDEBUG) || defined(RWSUPPRESSINLINE))
 | |
| 
 | |
| #define RpMeshHeaderGetPrimType(_mshHdr)                                        \
 | |
|     ( (RwPrimitiveType)RPMESHGLOBAL(meshFlagsToPrimType)[(_mshHdr)->flags &     \
 | |
|                                                          rpMESHHEADERPRIMMASK] )
 | |
| 
 | |
| #define RpMeshHeaderSetPrimType(_mshHdr, _prmTyp)                   \
 | |
|     ( (_mshHdr)->flags =                                            \
 | |
|           ((_mshHdr)->flags & ~rpMESHHEADERPRIMMASK) |              \
 | |
|           (rpMESHHEADERPRIMMASK &                                   \
 | |
|            RPMESHGLOBAL(primTypeToMeshFlags)[(_prmTyp) &            \
 | |
|                                            rpMESHHEADERPRIMMASK]),  \
 | |
|       (_mshHdr) )
 | |
| 
 | |
| #endif /* !(defined(RWDEBUG) || defined(RWSUPPRESSINLINE)) */
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern              "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| /* Opening and closing module */
 | |
| extern void        *_rpMeshOpen(void *instance, RwInt32 offset,
 | |
|                                 RwInt32 size);
 | |
| extern void        *_rpMeshClose(void *instance, RwInt32 offset,
 | |
|                                  RwInt32 size);
 | |
| 
 | |
| extern RwInt16      _rpMeshGetNextSerialNumber(void);
 | |
| 
 | |
| /* Create a build mesh with nothing in */
 | |
| extern RpBuildMesh *_rpBuildMeshCreate(RwUInt32 bufferSize);
 | |
| 
 | |
| /* Destroy a build mesh */
 | |
| extern RwBool       _rpBuildMeshDestroy(RpBuildMesh * mesh);
 | |
| 
 | |
| /* Destroy a build mesh */
 | |
| extern RwBool       _rpMeshDestroy(RpMeshHeader * mesh);
 | |
| 
 | |
| /* Add a triangle to a mesh */
 | |
| extern RpBuildMesh *_rpBuildMeshAddTriangle(RpBuildMesh * mesh,
 | |
|                                             RpMaterial * material,
 | |
|                                             RwInt32 vert1,
 | |
|                                             RwInt32 vert2,
 | |
|                                             RwInt32 vert3);
 | |
| 
 | |
| #if (defined(RWDEBUG) || defined(RWSUPPRESSINLINE))
 | |
| 
 | |
| /* Get primtype from a mesh header */
 | |
| extern RwPrimitiveType RpMeshHeaderGetPrimType(RpMeshHeader *
 | |
|                                                meshHeader);
 | |
| 
 | |
| /* Set primtype for a mesh header */
 | |
| extern RpMeshHeader *RpMeshHeaderSetPrimType(RpMeshHeader *
 | |
|                                              meshHeader,
 | |
|                                              RwPrimitiveType
 | |
|                                              primType);
 | |
| 
 | |
| #endif /* (defined(RWDEBUG) || defined(RWSUPPRESSINLINE)) */
 | |
| 
 | |
| /* Enumerate meshes within a mesh header */
 | |
| extern RpMeshHeader *_rpMeshHeaderForAllMeshes(RpMeshHeader *
 | |
|                                                meshHeader,
 | |
|                                                RpMeshCallBack
 | |
|                                                fpCallBack,
 | |
|                                                void *pData);
 | |
| 
 | |
| /* Mesh serialisation functions */
 | |
| extern RwStream    *_rpMeshWrite(const RpMeshHeader * meshHeader,
 | |
|                                  const void *object,
 | |
|                                  RwStream * stream,
 | |
|                                  const RpMaterialList * matList);
 | |
| extern RpMeshHeader *_rpMeshRead(RwStream * stream,
 | |
|                                  const void *object,
 | |
|                                  const RpMaterialList * matList);
 | |
| extern RwInt32      _rpMeshSize(const RpMeshHeader *meshHeader,
 | |
|                                 const void *object);
 | |
| /* Mesh header create/destroy functions */
 | |
| extern void          _rpMeshHeaderDestroy(RpMeshHeader * meshHeader);
 | |
| extern RpMeshHeader * _rpMeshHeaderCreate(RwUInt32 size);
 | |
| 
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: c:/daily/rwsdk/world/basector.h ---*/
 | |
| 
 | |
| /*
 | |
|  * Handling atomic sectors
 | |
|  * Atomic sectors are use to divide up the world into manageable portions
 | |
|  *
 | |
|  * Copyright (c) 1998 Criterion Software Ltd.
 | |
| */
 | |
| 
 | |
| /****************************************************************************
 | |
|  Defines
 | |
|  */
 | |
| 
 | |
| /* Type ID */
 | |
| #define rpWorldSector 0xff     /* Not a true 'type'! */
 | |
| 
 | |
| #define rpMINDISTANCEBETWEENVERTICES (RwReal)(0.0001)
 | |
| 
 | |
| #define RPV3DFROMVERTEXNORMAL(v, n) \
 | |
|     (v).x = (((RwReal)((n).x)) * ( (RwReal)(1.0/128))); \
 | |
|     (v).y = (((RwReal)((n).y)) * ( (RwReal)(1.0/128))); \
 | |
|     (v).z = (((RwReal)((n).z)) * ( (RwReal)(1.0/128)))
 | |
| 
 | |
| #define RPVERTEXNORMALFROMRWV3D(n, v)           \
 | |
|     {                                           \
 | |
|         RwFixed naTmp[3];                       \
 | |
|                                                 \
 | |
|         naTmp[0] = RwRealToFixed((v).x);        \
 | |
|         naTmp[1] = RwRealToFixed((v).y);        \
 | |
|         naTmp[2] = RwRealToFixed((v).z);        \
 | |
|                                                 \
 | |
|         if (naTmp[0] >= RwFixedCast(1))         \
 | |
|         {                                       \
 | |
|             naTmp[0] = RwFixedCast(1)-1;        \
 | |
|         }                                       \
 | |
|         if (naTmp[0] <= RwFixedCast(-1))        \
 | |
|         {                                       \
 | |
|             naTmp[0] = RwFixedCast(-1)+1;       \
 | |
|         }                                       \
 | |
|         if (naTmp[1] >= RwFixedCast(1))         \
 | |
|         {                                       \
 | |
|             naTmp[1] = RwFixedCast(1)-1;        \
 | |
|         }                                       \
 | |
|         if (naTmp[1] <= RwFixedCast(-1))        \
 | |
|         {                                       \
 | |
|             naTmp[1] = RwFixedCast(-1)+1;       \
 | |
|         }                                       \
 | |
|         if (naTmp[2] >= RwFixedCast(1))         \
 | |
|         {                                       \
 | |
|             naTmp[2] = RwFixedCast(1)-1;        \
 | |
|         }                                       \
 | |
|         if (naTmp[2] <= RwFixedCast(-1))        \
 | |
|         {                                       \
 | |
|             naTmp[2] = RwFixedCast(-1)+1;       \
 | |
|         }                                       \
 | |
|                                                 \
 | |
|         (n).x = (RwInt8)(naTmp[0]>>9);          \
 | |
|         (n).y = (RwInt8)(naTmp[1]>>9);          \
 | |
|         (n).z = (RwInt8)(naTmp[2]>>9);          \
 | |
|     }
 | |
| 
 | |
| /* RpCollSector access macros - for pre v304 data */
 | |
| #define RWCOLLSECTORGETTYPE(sect) \
 | |
|     ((sect).cType&0x80)
 | |
| 
 | |
| #define RWCOLLSECTORGETPLANE(sect) \
 | |
|     ((((sect).cType)>>3)&0xc)
 | |
| 
 | |
| #define RWCOLLSECTORGETON(sect) \
 | |
|     (((sect).cType)&0x1f)
 | |
| 
 | |
| #define RWCOLLSECTORGETVERTEX(sect) \
 | |
|     (sect).vertex
 | |
| 
 | |
| #define RWCOLLSECTORGETSTART(sect) \
 | |
|     (sect).start
 | |
| 
 | |
| #define RWCOLLSECTORGETNOPOLYS(sect) \
 | |
|     (sect).cType
 | |
| 
 | |
| #define RWCOLLSECTORSETPOLYGONS(sect,no,st) \
 | |
|     (sect).cType = (RwUInt8)(no); \
 | |
|     (sect).start = (RwUInt8)(st)
 | |
| 
 | |
| #define rwMAXCOLLISIONCUTS 7
 | |
| 
 | |
| /****************************************************************************
 | |
|  Global types
 | |
|  */
 | |
| 
 | |
| typedef struct RpVertexNormal RpVertexNormal;
 | |
| 
 | |
| struct RpVertexNormal
 | |
| {
 | |
|     RwInt8          x;
 | |
|     RwInt8          y;
 | |
|     RwInt8          z;
 | |
|     RwUInt8         pad; /* pad character to force alignment */
 | |
| };
 | |
| 
 | |
| typedef struct RpPolygon RpPolygon;
 | |
| 
 | |
| struct RpPolygon
 | |
| {
 | |
|     RwUInt16        matIndex;
 | |
|     RwUInt16        vertIndex[3];
 | |
| };
 | |
| 
 | |
| /* RpCollSector - for pre v304 data */
 | |
| #define RWCOLLSECTORSETPLANE(sect,plane,vert,no,st) \
 | |
|     (sect).cType = (RwUInt8)(0x80|((plane)<<3)|(no)); \
 | |
|     (sect).vertex = (RwUInt8)(vert); \
 | |
|     (sect).start = (RwUInt8)(st)
 | |
| 
 | |
| typedef struct RpCollSector RpCollSector;
 | |
| 
 | |
| struct RpCollSector
 | |
| {
 | |
|     RwUInt8 cType;    /* Bit 7   - 1 plane */
 | |
|                       /*           0 polygons */
 | |
|                       /* Bit 6-5 - plane */
 | |
|                       /* Bit 4-0 - amount ON plane */
 | |
|     RwUInt8 vertex;   /* Vertex index used for the split */
 | |
|     RwUInt8 start;    /* Starting polygon */
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * \ingroup rpworlddatatypes
 | |
|  * \typedef RpWorldSector
 | |
|  * World Sector object. This should be
 | |
|  * considered an opaque type. Use the RpWorldSector API functions to access.
 | |
|  */
 | |
| typedef struct RpWorldSector RpWorldSector;
 | |
| 
 | |
| #if (!defined(DOXYGEN))
 | |
| struct RpWorldSector
 | |
| {
 | |
|     RwInt32                 type;
 | |
| 
 | |
|     RpPolygon               *polygons;              /* Polygons themselves */
 | |
| 
 | |
|     RwV3d                   *vertices;              /* Vertex positions */
 | |
|     RpVertexNormal          *normals;               /* Vertex normals */
 | |
| 
 | |
|     RwTexCoords             *texCoords[rwMAXTEXTURECOORDS]; /* Texture coordinates */
 | |
| 
 | |
|     RwRGBA                  *preLitLum;             /* Pre lit luminances */
 | |
| 
 | |
|     /* Pointer to memory allocated for vertex and poly pointers */
 | |
|     RwResEntry              *repEntry;
 | |
| 
 | |
|     /* Atomics in this sectors */
 | |
|     /* The pointers are frigged so they look like they are pointing to
 | |
|        Atomics when they are pointing to here */
 | |
|     RwLinkList              collAtomicsInWorldSector;       /* Coll priority */
 | |
|     RwLinkList              noCollAtomicsInWorldSector;     /* No Coll priority */
 | |
| 
 | |
|     /* Lights in an atomic sector */
 | |
|     RwLinkList              lightsInWorldSector;
 | |
| 
 | |
|     /* Outer bounding box of sector based on BSP planes */
 | |
|     RwBBox                  boundingBox;
 | |
| 
 | |
|     /* Bounding box tightly enclosing geometry */
 | |
|     RwBBox                  tightBoundingBox;
 | |
| 
 | |
|     /* The root of the bsp collision tree for pre v304 data */
 | |
|     RpCollSector            *colSectorRoot;
 | |
| 
 | |
|     /* The mesh which groups same material polygons together */
 | |
|     RpMeshHeader            *mesh;
 | |
| 
 | |
|     /* The WorldSector object pipeline for this WorldSector */
 | |
|     RxPipeline    *pipeline;
 | |
| 
 | |
|     /* Material list window base
 | |
|      * (triangles in a given sector can "see"
 | |
|      * the 256 materials from
 | |
|      * MatList[matListWindowBase] -> MatList[matListWindowBase + 255])
 | |
|      */
 | |
|     RwUInt16                matListWindowBase;
 | |
| 
 | |
|     RwUInt16                numVertices;            /* Num vertices */
 | |
|     RwUInt16                numPolygons;            /* Num polygons */
 | |
|     RwUInt16                pad;
 | |
| };
 | |
| #endif /* (!defined(DOXYGEN)) */
 | |
| 
 | |
| /**
 | |
|  * \ingroup rpworlddatatypes
 | |
|  * \typedef RpWorldSectorCallBack
 | |
|  \ref RpWorldSectorCallBack
 | |
|  * represents the function called from \ref RpWorldForAllWorldSectors,
 | |
|  * \ref RpAtomicForAllWorldSectors and \ref RpLightForAllWorldSectors for all
 | |
|  * world sectors in a given world or world sectors a given atomic or light lies
 | |
|  * in. This function should return a pointer to the current world sector to
 | |
|  * indicate success. The callback may return NULL to terminate further
 | |
|  * callbacks on the atomic or light.
 | |
|  *
 | |
|  * \return Pointer to the current world sector.
 | |
|  *
 | |
|  * \param  sector   Pointer to the current world sector
 | |
|  * \param  data  Pointer to developer-defined data structure.
 | |
|  */
 | |
| typedef RpWorldSector *(*RpWorldSectorCallBack)(RpWorldSector *worldSector, void *data);
 | |
| 
 | |
| typedef struct RpSector RpSector;
 | |
| 
 | |
| struct RpSector
 | |
| {
 | |
|     RwInt32                 type;
 | |
| };
 | |
| 
 | |
| /* NOTE: The left and right pointers can point to an RpPlaneSector or
 | |
|  *       an RpWorldSector
 | |
|  * This is determined what the type is via the type value
 | |
|  */
 | |
| 
 | |
| typedef struct RpPlaneSector RpPlaneSector;
 | |
| 
 | |
| struct RpPlaneSector
 | |
| {
 | |
|     RwInt32                 type;
 | |
| 
 | |
|     RwReal                  value;
 | |
|     RpSector                *leftSubTree;   /* Sector 'left' (less) of the plane */
 | |
|     RpSector                *rightSubTree;  /* Sector 'right' (more) of the plane */
 | |
|     RwReal                  leftValue;
 | |
|     RwReal                  rightValue;
 | |
| };
 | |
| 
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| extern RwPluginRegistry sectorTKList;
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| #define RpWorldSectorGetBBoxMacro(_sctr)      (&((_sctr)->boundingBox))
 | |
| #define RpWorldSectorGetTightBBoxMacro(_sctr) (&((_sctr)->tightBoundingBox))
 | |
| 
 | |
| #if ((!defined(RWDEBUG)) && (!defined(RWSUPPRESSINLINE)))
 | |
| 
 | |
| #define RpWorldSectorGetBBox      RpWorldSectorGetBBoxMacro
 | |
| #define RpWorldSectorGetTightBBox RpWorldSectorGetTightBBoxMacro
 | |
| 
 | |
| #endif /* (defined(RWDEBUG) || defined(RWSUPPRESSINLINE)) */
 | |
| 
 | |
| /****************************************************************************
 | |
|  Function prototypes
 | |
|  */
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /* Get info from atomic sectors */
 | |
| extern RwInt32 RpWorldSectorGetNumPolygons(const RpWorldSector *Sector);
 | |
| extern RwInt32 RpWorldSectorGetNumVertices(const RpWorldSector *Sector);
 | |
| 
 | |
| /* Instancing and deinstancing sectors */
 | |
| extern RpWorldSector * RpWorldSectorRender(RpWorldSector *worldSector);
 | |
| 
 | |
| extern const RpWorldSector *RpWorldSectorForAllMeshes(const RpWorldSector *sector,
 | |
|                                                       RpMeshCallBack fpCallBack,
 | |
|                                                       void *pData);
 | |
| 
 | |
| 
 | |
| #if (defined(RWDEBUG) || defined(RWSUPPRESSINLINE))
 | |
| 
 | |
| extern const RwBBox *RpWorldSectorGetBBox(const RpWorldSector *sector);
 | |
| extern const RwBBox *RpWorldSectorGetTightBBox(const RpWorldSector *sector);
 | |
| 
 | |
| #endif /* (defined(RWDEBUG) || defined(RWSUPPRESSINLINE)) */
 | |
| 
 | |
| /* Plugins */
 | |
| extern RwInt32 RpWorldSectorRegisterPlugin(RwInt32 size, RwUInt32 pluginID,
 | |
|                                            RwPluginObjectConstructor constructCB,
 | |
|                                            RwPluginObjectDestructor destructCB,
 | |
|                                            RwPluginObjectCopy copyCB);
 | |
| extern RwInt32 RpWorldSectorRegisterPluginStream(RwUInt32 pluginID,
 | |
|                                                  RwPluginDataChunkReadCallBack readCB,
 | |
|                                                  RwPluginDataChunkWriteCallBack writeCB,
 | |
|                                                  RwPluginDataChunkGetSizeCallBack getSizeCB);
 | |
| extern RwInt32 RpWorldSectorSetStreamAlwaysCallBack(
 | |
|                     RwUInt32 pluginID,
 | |
|                     RwPluginDataChunkAlwaysCallBack alwaysCB);
 | |
| extern RwInt32 RpWorldSectorSetStreamRightsCallBack(RwUInt32 pluginID,
 | |
|                                       RwPluginDataChunkRightsCallBack rightsCB);
 | |
| extern RwInt32 RpWorldSectorGetPluginOffset(RwUInt32 pluginID);
 | |
| extern RwBool RpWorldSectorValidatePlugins(const RpWorldSector *sector);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| /*--- Automatically derived from: c:/daily/rwsdk/world/bameshop.h ---*/
 | |
| 
 | |
| /****************************************************************************
 | |
|  Defines
 | |
|  */
 | |
| 
 | |
| /**
 | |
|  * \ingroup rpworlddatatypes
 | |
|  * \typedef RpTriStripMeshCallBack
 | |
|  * \ref RpTriStripMeshCallBack is the callback to generate triangle strips
 | |
|  * when the triangle stripped geometries or world sectors are unlocked.
 | |
|  *
 | |
|  * \param buildMesh pointer to the mesh which the triangle strip will be
 | |
|  * generated from.
 | |
|  * \param data  pointer to user-supplied data to pass to the callback
 | |
|  * function.
 | |
|  *
 | |
|  * \return a pointer to the constructed mesh header.
 | |
|  *
 | |
|  */
 | |
| typedef RpMeshHeader *
 | |
| (*RpTriStripMeshCallBack) (RpBuildMesh *buildMesh, void *data);
 | |
| 
 | |
| 
 | |
| /****************************************************************************
 | |
|  Global types
 | |
|  */
 | |
| 
 | |
| 
 | |
| /****************************************************************************
 | |
|  Global Variables 
 | |
|  */
 | |
| 
 | |
| 
 | |
| /****************************************************************************
 | |
|  Function prototypes
 | |
|  */
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /* Callback mesh generating functions */
 | |
| extern RpMeshHeader *
 | |
| RpBuildMeshGenerateTrivialTriStrip(RpBuildMesh *buildMesh, void *data);
 | |
| 
 | |
| extern RpMeshHeader *
 | |
| RpBuildMeshGenerateDefaultTriStrip(RpBuildMesh *buildmesh, void *data);
 | |
| 
 | |
| extern RpMeshHeader *
 | |
| RpBuildMeshGeneratePreprocessTriStrip(RpBuildMesh *buildmesh, void *data);
 | |
| 
 | |
| extern RpMeshHeader *
 | |
| RpBuildMeshGenerateExhaustiveTriStrip(RpBuildMesh *buildmesh, void *data);
 | |
| 
 | |
| extern RpMeshHeader *
 | |
| RpBuildMeshGenerateDefaultIgnoreWindingTriStrip(RpBuildMesh *buildmesh, 
 | |
|                                                 void *data);
 | |
| 
 | |
| extern RpMeshHeader *
 | |
| RpBuildMeshGeneratePreprocessIgnoreWindingTriStrip(RpBuildMesh *buildmesh, 
 | |
|                                                    void *data);
 | |
| 
 | |
| extern RpMeshHeader *
 | |
| RpBuildMeshGenerateExhaustiveIgnoreWindingTriStrip(RpBuildMesh *buildmesh, 
 | |
|                                                    void *data);
 | |
| 
 | |
| /* Functions to set and get the global mesh tristrip algorithm */
 | |
| extern RwBool
 | |
| RpMeshSetTriStripMethod(RpTriStripMeshCallBack callback, void *data);
 | |
| 
 | |
| extern RwBool
 | |
| RpMeshGetTriStripMethod(RpTriStripMeshCallBack *callback, void **data);
 | |
| 
 | |
| 
 | |
| extern RpMeshHeader *
 | |
| _rpTriListMeshGenerate(RpBuildMesh *buildMesh, void *data);
 | |
| 
 | |
| /* 
 | |
|  * Optimise the mesh ordering 
 | |
|  * (sort on material and place transparent materials last)
 | |
|  */
 | |
| extern RpMeshHeader *
 | |
| _rpMeshOptimise(RpBuildMesh *buildmesh, RwUInt32 flags);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| 
 | |
| #define _rpTriStripMeshTrivialGenerate(_buildMesh, _data)      \
 | |
|     RpBuildMeshGenerateTrivialTriStrip(_buildMesh, _data)
 | |
| 
 | |
| #define _rpTriStripMeshDefaultGenerate(_buildmesh, _data)      \
 | |
|     RpBuildMeshGenerateDefaultTriStrip(_buildmesh, _data)
 | |
| 
 | |
| #define _rpTriStripMeshPreprocessGenerate(_buildmesh, _data)   \
 | |
|     RpBuildMeshGeneratePreprocessTriStrip(_buildmesh, _data)
 | |
| 
 | |
| #define _rpTriStripMeshExhaustiveGenerate(_buildmesh, _data)   \
 | |
|     RpBuildMeshGenerateExhaustiveTriStrip(_buildmesh, _data)
 | |
| 
 | |
| #define _rpMeshSetTristripMethod(_callback, _data)             \
 | |
|     RpMeshSetTriStripMethod(_callback, _data)
 | |
| 
 | |
| #define _rpMeshGetTristripMethod(_callback, _data)             \
 | |
|     RpMeshGetTriStripMethod(_callback, _data)
 | |
| 
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: c:/daily/rwsdk/world/balight.h ---*/
 | |
| 
 | |
| /*
 | |
|  * Lighting 3D objects.
 | |
|  * Lights are used to illuminate atomics and worlds
 | |
|  *
 | |
|  * Copyright (c) 1998 Criterion Software Ltd.
 | |
|  */
 | |
| 
 | |
| 
 | |
| /****************************************************************************
 | |
|  Defines
 | |
|  */
 | |
| 
 | |
| /* Binary Light */
 | |
| typedef struct RpLightChunkInfo RpLightChunkInfo;
 | |
| typedef struct RpLightChunkInfo _rpLight;
 | |
| 
 | |
| struct RpLightChunkInfo
 | |
| {
 | |
|         RwReal              radius; /**< radius */
 | |
|         RwReal              red; /**< red */
 | |
|         RwReal              green; /**< green */
 | |
|         RwReal              blue; /**< blue */
 | |
|         RwReal              minusCosAngle; /**< minusCosAngle */
 | |
|         RwUInt32            typeAndFlags; /**< typeAndFlags */
 | |
| };
 | |
| 
 | |
| /* Type ID */
 | |
| #define rpLIGHT 3
 | |
| 
 | |
| /* Beyond this the lights must be positioned */
 | |
| #define rpLIGHTPOSITIONINGSTART 0x80
 | |
| 
 | |
| /**
 | |
|  * \ingroup rpworlddatatypes
 | |
|  * \ref RpLightType are
 | |
|  * light sub types.  This type represents the different 
 | |
|  * types of light source that can be created using the API function \ref RpLightCreate.  
 | |
|  * Note that lights of types rpLIGHTPOINT, rpLIGHTSPOT and rpLIGHTSPOTSOFT have linear 
 | |
|  * intensity fall-off with distance from the source, reducing to zero at the light's radius:*/
 | |
| enum RpLightType
 | |
| {
 | |
|     rpNALIGHTTYPE = 0,
 | |
| 
 | |
|     /* These don't take part in the tie mechanism (no position) */
 | |
|     rpLIGHTDIRECTIONAL, /**<Directional Light */
 | |
|     rpLIGHTAMBIENT, /**<Ambient Light */
 | |
| 
 | |
|     /* These do take part in the tie mechanism (do have position) */
 | |
|     rpLIGHTPOINT = rpLIGHTPOSITIONINGSTART, /**<Point Light */
 | |
|     rpLIGHTSPOT, /**<Spot Light */
 | |
|     rpLIGHTSPOTSOFT, /**<Soft Spot Light */
 | |
|     rpLIGHTTYPEFORCEENUMSIZEINT = RWFORCEENUMSIZEINT
 | |
| };
 | |
| typedef enum RpLightType RpLightType;
 | |
| 
 | |
| #define rpLIGHTMINCONEANGLE ((RwReal)0.0f)
 | |
| #if ((defined(XBOX_DRVMODEL_H)) || (defined(OPENGL_DRVMODEL_H)) || (defined(GCN_DRVMODEL_H)))
 | |
| /* XBox has Micro$oft-penned drivers, no wonder it crashes... */
 | |
| /* OpenGL and GCN clamp to 90 internally, so we mirror that behaviour */
 | |
| #define rpLIGHTMAXCONEANGLE ((RwReal)89.9999f)
 | |
| #else
 | |
| #define rpLIGHTMAXCONEANGLE ((RwReal)180.0f)
 | |
| #endif
 | |
| 
 | |
| /*************/
 | |
| 
 | |
| /*** FLAGS ***/
 | |
| 
 | |
| /*************/
 | |
| 
 | |
| /**
 | |
|  * \ingroup rpworlddatatypes
 | |
|  * \ref RpLightFlag defines what geometry is influenced by the light. 
 | |
|  * The bit-field RpLightFlag specifies the options available for controlling the scope 
 | |
|  * of a light source (see API function \ref RpLightSetFlags):*/
 | |
| enum RpLightFlag
 | |
| {
 | |
|     rpLIGHTLIGHTATOMICS = 0x01, /**<The light source illuminates all atomics in a world */
 | |
|     rpLIGHTLIGHTWORLD = 0x02, /**<The light source illuminates all static geometry in a world */
 | |
|     rpLIGHTFLAGFORCEENUMSIZEINT = RWFORCEENUMSIZEINT
 | |
| };
 | |
| typedef enum RpLightFlag RpLightFlag;
 | |
| 
 | |
| /* rpLIGHTPRIVATENOCHROMA - turns on optimisations to do with
 | |
|  *                          lights which are a shade of grey
 | |
|  */
 | |
| enum rpLightPrivateFlag
 | |
| {
 | |
|     rpLIGHTPRIVATENOCHROMA = 0x01,
 | |
|     rpLIGHTPRIVATEFLAGFORCEENUMSIZEINT = RWFORCEENUMSIZEINT
 | |
| };
 | |
| typedef enum rpLightPrivateFlag rpLightPrivateFlag;
 | |
| 
 | |
| /*********************/
 | |
| 
 | |
| 
 | |
| #define RWMINUSCOSFROMTAN(_minusCosAngle, _tanAngle)                  \
 | |
| MACRO_START                                                           \
 | |
| {                                                                     \
 | |
|    const RwReal TanAngle2 = (_tanAngle) * (_tanAngle);                \
 | |
|    const RwReal CosAngle2 = ((RwReal)1) / ( ((RwReal)1) + TanAngle2); \
 | |
|    RwReal CosAngle;                                                   \
 | |
|    rwSqrtMacro(&CosAngle, CosAngle2);                                 \
 | |
|    (_minusCosAngle) = - CosAngle;                                     \
 | |
| }                                                                     \
 | |
| MACRO_STOP
 | |
| 
 | |
| #define RWTANFROMMINUSCOS(_tanAngle, _minusCosAngle)                    \
 | |
| MACRO_START                                                             \
 | |
| {                                                                       \
 | |
|     const RwReal CosAngle2 = (_minusCosAngle) * (_minusCosAngle);       \
 | |
|     const RwReal TanAngle2 = (((RwReal)1) - (CosAngle2)) / (CosAngle2); \
 | |
|     rwSqrtMacro(&_tanAngle, TanAngle2);                                 \
 | |
| }                                                                       \
 | |
| MACRO_STOP
 | |
| 
 | |
| 
 | |
| /**
 | |
|  * \ingroup rpworlddatatypes
 | |
|  * \typedef RpLight 
 | |
|  * Light. This should be 
 | |
|  * considered an opaque type. User the RpLight API functions to access.
 | |
|  */
 | |
| typedef struct RpLight RpLight;
 | |
| 
 | |
| #if (!defined(DOXYGEN))
 | |
| struct RpLight
 | |
| {
 | |
|         RwObjectHasFrame    object; /**< object */
 | |
|         RwReal              radius; /**< radius */
 | |
|         RwRGBAReal          color; /**< color */  /* Light color */
 | |
|         RwReal              minusCosAngle; /**< minusCosAngle */  
 | |
|         RwLinkList          WorldSectorsInLight; /**< WorldSectorsInLight */
 | |
|         RwLLLink            inWorld; /**< inWorld */
 | |
|         RwUInt16            lightFrame; /**< lightFrame */
 | |
|         RwUInt16            pad;
 | |
| };
 | |
| #endif /* (!defined(DOXYGEN)) */
 | |
| 
 | |
| /**
 | |
|  * \ingroup rpworlddatatypes
 | |
|  * \typedef RpLightCallBack
 | |
|  * \ref RpLightCallBack 
 | |
|  * represents the function called from \ref RpWorldForAllLights and 
 | |
|  * \ref RpWorld SectorForAllLights for all lights in a given world or world 
 | |
|  * sector. This function should return a pointer to the current light to 
 | |
|  * indicate success. The callback may return NULL to terminate further 
 | |
|  * callbacks on the world sector.
 | |
|  *
 | |
|  * \return Pointer to the current light.
 | |
|  * 
 | |
|  * \param  light   Pointer to the current light in the world 
 | |
|  * sector.
 | |
|  * \param  data  Pointer to developer-defined data structure.
 | |
|  */
 | |
| typedef RpLight    *(*RpLightCallBack) (RpLight * light, void *data);
 | |
| 
 | |
| typedef struct RpLightTie RpLightTie;
 | |
| 
 | |
| struct RpLightTie
 | |
| {
 | |
|     /* Information for an atomic sector */
 | |
|     RwLLLink            lightInWorldSector; /* Lights IN this ATOMIC SECTOR */
 | |
|     RpLight            *light;
 | |
| 
 | |
|     /* Information for a atomic */
 | |
|     RwLLLink            WorldSectorInLight; /* Atomic sectors HOLDING this Light */
 | |
|     RpWorldSector      *sect;
 | |
| };
 | |
| 
 | |
| 
 | |
| /****************************************************************************
 | |
|  <macro/inline functionality
 | |
|  */
 | |
| 
 | |
| #define RpLightGetRadiusMacro(_light)                       \
 | |
|     ((_light)->radius)
 | |
| 
 | |
| #define RpLightGetColorMacro(_light)                        \
 | |
|     (&((_light)->color))
 | |
| 
 | |
| #define RpLightSetFrameMacro(_light, _frame)                \
 | |
|     (rwObjectHasFrameSetFrame((_light), (_frame)), (_light))
 | |
| 
 | |
| #define RpLightGetFrameMacro(_light)                        \
 | |
|     ((RwFrame *)rwObjectGetParent((_light)))
 | |
| 
 | |
| #define RpLightGetTypeMacro(_light)                         \
 | |
|     ((RpLightType)rwObjectGetSubType((_light)))
 | |
| 
 | |
| #define RpLightSetFlagsMacro(_light, _flags)                \
 | |
|     ((rwObjectSetFlags((_light), (_flags))), (_light))
 | |
| 
 | |
| #define RpLightGetFlagsMacro(_light)                        \
 | |
|     (rwObjectGetFlags((_light)))
 | |
| 
 | |
| 
 | |
| #if !(defined(RWDEBUG) || defined(RWSUPPRESSINLINE))
 | |
| 
 | |
| #define RpLightGetRadius(_light)                            \
 | |
|     RpLightGetRadiusMacro(_light)
 | |
| 
 | |
| #define RpLightGetColor(_light)                             \
 | |
|     RpLightGetColorMacro(_light)
 | |
| 
 | |
| #define RpLightSetFrame(_light, _frame)                     \
 | |
|     RpLightSetFrameMacro(_light, _frame)
 | |
| 
 | |
| #define RpLightGetFrame(_light)                             \
 | |
|     RpLightGetFrameMacro(_light)
 | |
| 
 | |
| #define RpLightGetType(_light)                              \
 | |
|     RpLightGetTypeMacro(_light)
 | |
| 
 | |
| #define RpLightSetFlags(_light, _flags)                     \
 | |
|     RpLightSetFlagsMacro(_light, _flags)
 | |
| 
 | |
| #define RpLightGetFlags(_light)                             \
 | |
|     RpLightGetFlagsMacro(_light)
 | |
| 
 | |
| #endif /* !(defined(RWDEBUG) || defined(RWSUPPRESSINLINE)) */
 | |
| 
 | |
| 
 | |
| /****************************************************************************
 | |
|  Function prototypes
 | |
|  */
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern              "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| 
 | |
| #if (defined(RWDEBUG) || defined(RWSUPPRESSINLINE))
 | |
| extern RwReal RpLightGetRadius(const RpLight *light);
 | |
| extern const RwRGBAReal *RpLightGetColor(const RpLight *light);
 | |
| extern RpLight *RpLightSetFrame(RpLight *light, RwFrame *frame);
 | |
| extern RwFrame *RpLightGetFrame(const RpLight *light);
 | |
| extern RpLightType RpLightGetType(const RpLight *light);
 | |
| extern RpLight *RpLightSetFlags(RpLight *light, RwUInt32 flags);
 | |
| extern RwUInt32 RpLightGetFlags(const RpLight *light);
 | |
| #endif /* (defined(RWDEBUG) || defined(RWSUPPRESSINLINE)) */
 | |
| 
 | |
| /* API Functions */
 | |
| extern RpLight *RpLightCreate(RwInt32 type);
 | |
| extern RwBool RpLightDestroy(RpLight *light);
 | |
| extern RpLight *RpLightSetRadius(RpLight *light, RwReal radius);
 | |
| extern RpLight *RpLightSetColor(RpLight *light, const RwRGBAReal *color);
 | |
| extern RwReal RpLightGetConeAngle(const RpLight *light);
 | |
| extern RpLight *RpLightSetConeAngle(RpLight * ight, RwReal angle);
 | |
| extern RwUInt32 RpLightStreamGetSize(const RpLight *light);
 | |
| extern RpLight *RpLightStreamRead(RwStream *stream);
 | |
| extern const RpLight *RpLightStreamWrite(const RpLight *light,
 | |
|                                          RwStream *stream);
 | |
| extern RpLightChunkInfo *_rpLightChunkInfoRead(RwStream *stream,
 | |
|                                                RpLightChunkInfo *lightChunkInfo,
 | |
|                                                RwInt32 *bytesRead);
 | |
| 
 | |
| /* Attaching toolkits */
 | |
| extern RwInt32 RpLightRegisterPlugin(RwInt32 size,
 | |
|                                      RwUInt32 pluginID,
 | |
|                                      RwPluginObjectConstructor constructCB,
 | |
|                                      RwPluginObjectDestructor destructCB,
 | |
|                                      RwPluginObjectCopy copyCB);
 | |
| extern RwInt32 RpLightRegisterPluginStream(RwUInt32 pluginID,
 | |
|                                            RwPluginDataChunkReadCallBack readCB,
 | |
|                                            RwPluginDataChunkWriteCallBack writeCB,
 | |
|                                            RwPluginDataChunkGetSizeCallBack getSizeCB);
 | |
| extern RwInt32 RpLightSetStreamAlwaysCallBack(RwUInt32 pluginID,
 | |
|                                               RwPluginDataChunkAlwaysCallBack alwaysCB);
 | |
| extern RwInt32 RpLightGetPluginOffset(RwUInt32 pluginID);
 | |
| extern RwBool RpLightValidatePlugins(const RpLight * light);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| #define RpLightChunkInfoRead(stream, lightChunkInfo, bytesRead) \
 | |
|        _rpLightChunkInfoRead(stream, lightChunkInfo, bytesRead)
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/world/pipe/p2/d3d8/D3D8lights.h ---*/
 | |
| /**
 | |
|  * \ingroup rplightd3d8
 | |
|  * \typedef RpD3D8AttenuationParams
 | |
|  * typedef for struct RpD3D8AttenuationParams
 | |
|  */
 | |
| typedef struct RpD3D8AttenuationParams RpD3D8AttenuationParams;
 | |
| /**
 | |
|  * \ingroup rplightd3d8
 | |
|  * \struct RpD3D8AttenuationParams
 | |
|  *  This type represents the attenuation model of a spot or point light.
 | |
|  */
 | |
| struct RpD3D8AttenuationParams
 | |
| {
 | |
|     RwReal constant;    /**< Constant attenuation coefficient */
 | |
|     RwReal linear;      /**< Linear attenuation coefficient */
 | |
|     RwReal quadratic;   /**< Quadratic attenuation coefficient */
 | |
| };
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| extern void
 | |
| RpD3D8LightSetAttenuationParams(RpLight *light,
 | |
|                                 const RpD3D8AttenuationParams *params);
 | |
| 
 | |
| extern void
 | |
| RpD3D8LightGetAttenuationParams(const RpLight *light,
 | |
|                                 RpD3D8AttenuationParams *params);
 | |
| 
 | |
| extern RwBool
 | |
| _rwD3D8LightsOpen(void);
 | |
| 
 | |
| extern RwBool
 | |
| _rwD3D8LightsGlobalEnable(RpLightFlag flags);
 | |
| 
 | |
| extern RwBool
 | |
| _rwD3D8LightDirectionalEnable(RpLight *light);
 | |
| 
 | |
| extern RwBool
 | |
| _rwD3D8LightLocalEnable(RpLight *light);
 | |
| 
 | |
| extern void
 | |
| _rwD3D8LightsEnable(RwBool enable, RwUInt32 type);
 | |
| 
 | |
| extern void
 | |
| _rwD3D8LightsClose(void);
 | |
| 
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/world/pipe/p2/p2stdclsw.h ---*/
 | |
| typedef RpLight *RxLight;
 | |
| #ifdef    __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| extern RxClusterDefinition RxClLights; /* Uses the RxLight type (see above) */
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: c:/daily/rwsdk/world/bageomet.h ---*/
 | |
| 
 | |
| /*
 | |
|  * Handling atomic's geometry
 | |
|  * Geometry describe objects, and are the building blocks for atomics
 | |
|  *
 | |
|  * Copyright (c) 1998 Criterion Software Ltd.
 | |
| */
 | |
| 
 | |
| 
 | |
| /****************************************************************************
 | |
|  Defines
 | |
|  */
 | |
| 
 | |
| /* Type ID */
 | |
| #define rpGEOMETRY 8
 | |
| 
 | |
| /**
 | |
|  * \ingroup rpworlddatatypes
 | |
|  * RpGeometryFlag
 | |
|  * Geometry type flags 
 | |
|  *
 | |
|  * When creating a geometry, these flags can be OR'ed together to
 | |
|  * specify the format along with the rpGEOMETRYTEXCOORDSETS(n) macro if more
 | |
|  * than two sets of texture coordinates are required. See \ref RpGeometryCreate
 | |
|  * for more details.
 | |
|  *
 | |
|  * \see RpGeometryCreate().
 | |
|  */
 | |
| enum RpGeometryFlag
 | |
| {
 | |
|     rpGEOMETRYTRISTRIP  = 0x00000001, /**<This geometry's meshes can be
 | |
|                                           rendered as strips.
 | |
|                                           \ref RpMeshSetTriStripMethod is
 | |
|                                           used to change this method.*/
 | |
|     rpGEOMETRYPOSITIONS = 0x00000002, /**<This geometry has positions */  
 | |
|     rpGEOMETRYTEXTURED  = 0x00000004, /**<This geometry has only one set of
 | |
|                                           texture coordinates. Texture
 | |
|                                           coordinates are specified on a per
 | |
|                                           vertex basis */
 | |
|     rpGEOMETRYPRELIT    = 0x00000008, /**<This geometry has pre-light colors */
 | |
|     rpGEOMETRYNORMALS   = 0x00000010, /**<This geometry has vertex normals */
 | |
|     rpGEOMETRYLIGHT     = 0x00000020, /**<This geometry will be lit */
 | |
|     rpGEOMETRYMODULATEMATERIALCOLOR = 0x00000040, /**<Modulate material color 
 | |
|                                                       with vertex colors
 | |
|                                                       (pre-lit + lit) */
 | |
| 
 | |
|     rpGEOMETRYTEXTURED2 = 0x00000080, /**<This geometry has at least 2 sets of
 | |
|                                           texture coordinates. */
 | |
| 
 | |
|     /*
 | |
|      * These above flags were stored in the flags field in an RwObject, they
 | |
|      * are now stored in the flags file of the RpGeometry.
 | |
|      */
 | |
| 
 | |
|     rpGEOMETRYNATIVE            = 0x01000000,
 | |
|     rpGEOMETRYNATIVEINSTANCE    = 0x02000000,
 | |
| 
 | |
|     rpGEOMETRYFLAGSMASK         = 0x000000FF,
 | |
|     rpGEOMETRYNATIVEFLAGSMASK   = 0x0F000000,
 | |
| 
 | |
|     rpGEOMETRYFLAGFORCEENUMSIZEINT = RWFORCEENUMSIZEINT
 | |
| };
 | |
| typedef enum RpGeometryFlag RpGeometryFlag;
 | |
| 
 | |
| /* Multi texture coordinate format specifier for RpGeometryCreate() */
 | |
| #define rpGEOMETRYTEXCOORDSETS(_num) ((_num & 0xff) << 16)
 | |
| 
 | |
| /**
 | |
|  * \ingroup rpworlddatatypes
 | |
|  * RpGeometryLockMode
 | |
|  * Geometry lock flags 
 | |
|  */
 | |
| enum RpGeometryLockMode
 | |
| {
 | |
|     rpGEOMETRYLOCKPOLYGONS   =   0x01, /**<Lock the polygons (triangle list) */
 | |
|     rpGEOMETRYLOCKVERTICES   =   0x02, /**<Lock the vertex positional data */
 | |
|     rpGEOMETRYLOCKNORMALS    =   0x04, /**<Lock the vertex normal data */
 | |
|     rpGEOMETRYLOCKPRELIGHT   =   0x08, /**<Lock the pre-light values */
 | |
|     rpGEOMETRYLOCKTEXCOORDS  =   0x10, /**<Lock the texture coordinates set 1*/
 | |
|     rpGEOMETRYLOCKTEXCOORDS1 =   0x10, /**<Lock the texture coordinates set 1*/
 | |
|     rpGEOMETRYLOCKTEXCOORDS2 =   0x20, /**<Lock the texture coordinates set 2*/
 | |
|     rpGEOMETRYLOCKTEXCOORDS3 =   0x40, /**<Lock the texture coordinates set 3*/
 | |
|     rpGEOMETRYLOCKTEXCOORDS4 =   0x80, /**<Lock the texture coordinates set 4*/
 | |
|     rpGEOMETRYLOCKTEXCOORDS5 = 0x0100, /**<Lock the texture coordinates set 5*/
 | |
|     rpGEOMETRYLOCKTEXCOORDS6 = 0x0200, /**<Lock the texture coordinates set 6*/
 | |
|     rpGEOMETRYLOCKTEXCOORDS7 = 0x0400, /**<Lock the texture coordinates set 7*/
 | |
|     rpGEOMETRYLOCKTEXCOORDS8 = 0x0800, /**<Lock the texture coordinates set 8*/
 | |
|     rpGEOMETRYLOCKTEXCOORDSALL = 0x0ff0, /**<Lock all texture coordinate sets*/
 | |
|     rpGEOMETRYLOCKALL        = 0x0fff, /**<Combination of all the above */
 | |
| 
 | |
|     rpGEOMETRYLOCKMODEFORCEENUMSIZEINT = RWFORCEENUMSIZEINT
 | |
| };
 | |
| typedef enum RpGeometryLockMode RpGeometryLockMode;
 | |
| 
 | |
| /* Convenience macro for generating a tex coord lock flag */
 | |
| #define rpGEOMETRYLOCKTEXCOORDSIDX(_idx) (rpGEOMETRYLOCKTEXCOORDS1 << (_idx))
 | |
| 
 | |
| 
 | |
| /****************************************************************************
 | |
|  Global Types
 | |
|  */
 | |
| 
 | |
| typedef struct rpGeometryGlobals rpGeometryGlobals;
 | |
| struct rpGeometryGlobals
 | |
| {
 | |
|         RwFreeList         *geomFreeList;
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * \ingroup rpworlddatatypes
 | |
|  * \typedef RpGeometry 
 | |
|  * Geometry object. This should be considered an opaque type. 
 | |
|  * Use the RpGeometry API functions to access.
 | |
|  */
 | |
| typedef struct RpGeometry RpGeometry;
 | |
| 
 | |
| /**
 | |
|  * \ingroup rpworlddatatypes
 | |
|  * \typedef RpMorphTarget 
 | |
|  * Morph target -- vertex positions and normals. 
 | |
|  * This should be considered an opaque type. 
 | |
|  * Use RpMorphTarget API functions to access.
 | |
|  */
 | |
| typedef struct RpMorphTarget RpMorphTarget;
 | |
| 
 | |
| #if (!defined(DOXYGEN))
 | |
| struct RpMorphTarget
 | |
| {
 | |
|         RpGeometry *parentGeom; 
 | |
|         RwSphere   boundingSphere;
 | |
|         RwV3d      *verts;
 | |
|         RwV3d      *normals;
 | |
| };
 | |
| #endif /* (!defined(DOXYGEN)) */
 | |
| 
 | |
| typedef struct RpTriangle RpTriangle;
 | |
| 
 | |
| /**
 | |
|  * \ingroup rpworlddatatypes
 | |
|  * \struct RpTriangle 
 | |
|  * This type represents a triangle in a geometry specified 
 | |
|  * by three indices into the geometry's vertex list (vertIndex)
 | |
|  * together with an  index in to the geometry's 
 | |
|  * material list (matIndex) (see API function \ref RpGeometryGetTriangles)
 | |
|  */
 | |
| struct RpTriangle
 | |
| {
 | |
|     RwUInt16            vertIndex[3]; /**< vertex indices */
 | |
|     RwInt16             matIndex; /**< Index into material list */
 | |
| };
 | |
| 
 | |
| #if (!defined(DOXYGEN))
 | |
| struct RpGeometry
 | |
| {
 | |
|     RwObject            object;     /* Generic type */
 | |
| 
 | |
|     RwUInt32            flags;      /* Geometry flags */
 | |
| 
 | |
|     RwUInt16            lockedSinceLastInst; /* What has been locked since we last instanced - for re-instancing */
 | |
|     RwInt16             refCount;   /* Reference count (for keeping track of atomics referencing geometry) */
 | |
| 
 | |
|     RwInt32             numTriangles; /* Quantity of various things (polys, verts and morph targets) */
 | |
|     RwInt32             numVertices;
 | |
|     RwInt32             numMorphTargets;
 | |
|     RwInt32             numTexCoordSets;
 | |
| 
 | |
|     RpMaterialList      matList;
 | |
| 
 | |
|     RpTriangle         *triangles;  /* The triangles */
 | |
| 
 | |
|     RwRGBA             *preLitLum;  /* The pre-lighting values */
 | |
| 
 | |
|     RwTexCoords        *texCoords[rwMAXTEXTURECOORDS]; /* Texture coordinates */
 | |
| 
 | |
|     RwSurfaceProperties ignoredSurfaceProps; /* Not used in pp rendering, but present
 | |
|                                               * so if pipe1 files are read and written these
 | |
|                                               * values are not lost
 | |
|                                               */
 | |
| 
 | |
|     RpMeshHeader       *mesh;   /* The mesh - groups polys of the same material */
 | |
| 
 | |
|     RwResEntry         *repEntry;       /* Information for an instance */
 | |
| 
 | |
|     RpMorphTarget      *morphTarget;    /* The Morph Target */
 | |
| };
 | |
| #endif /* (!defined(DOXYGEN)) */
 | |
| 
 | |
| typedef struct RpGeometryChunkInfo RpGeometryChunkInfo;
 | |
| typedef struct RpGeometryChunkInfo _rpGeometry;
 | |
| 
 | |
| struct RpGeometryChunkInfo
 | |
| {
 | |
|     RwInt32             format;  /* Compression flags and number of texture coord sets */
 | |
| 
 | |
|     RwInt32             numTriangles;
 | |
|     RwInt32             numVertices;
 | |
| 
 | |
|     RwInt32             numMorphTargets;
 | |
| 
 | |
|     RwSurfaceProperties ignoredSurfaceProps;
 | |
| };
 | |
| 
 | |
| /* Callbacks */
 | |
| 
 | |
| /**
 | |
|  * \ingroup rpworlddatatypes
 | |
|  * \typedef RpGeometryCallBack 
 | |
|  * \ref RpGeometryCallBack represents the simple callback function for the \ref RpGeometry object.
 | |
|  * The callback may return NULL to terminate further callbacks on 
 | |
|  * the geometry.
 | |
|  * 
 | |
|  * \param  geometry   Pointer to the current geometry, supplied by iterator.
 | |
|  * \param  data  Pointer to developer-defined data structure.
 | |
|  */
 | |
| typedef RpGeometry *(*RpGeometryCallBack)(RpGeometry *geometry, void *data);
 | |
| 
 | |
| /**
 | |
|  * \ingroup rpworlddatatypes
 | |
|  * \typedef RpGeometrySortByMaterialCallBack 
 | |
|  * \ref RpGeometrySortByMaterialCallBack is used by
 | |
|  * \ref RpGeometrySortByMaterial in order to preserve the validity of plugin
 | |
|  * data when the vertices in an \ref RpGeometry are sorted (and some possibly
 | |
|  * duplicated).
 | |
|  *
 | |
|  * A vertex map table is provided to the callback - this contains, for each
 | |
|  * vertex in the new geometry, the index of the corresponding vertex in the
 | |
|  * original geometry.
 | |
|  *
 | |
|  * \param  oldGeom   Pointer to the source geometry.
 | |
|  * \param  newGeom   Pointer to the new, sorted geometry.
 | |
|  * \param  remapTable   pointer to the vertex map table
 | |
|  * \param  numberOfEntries   Number of vertices in the new 
 | |
|  * geometry (size of the map table)
 | |
|  */
 | |
| typedef void (*RpGeometrySortByMaterialCallBack)(const RpGeometry *oldGeom,
 | |
|                                                  RpGeometry *newGeom,
 | |
|                                                  RwUInt16 *remapTable,
 | |
|                                                  RwUInt16 numberOfEntries);
 | |
| 
 | |
| 
 | |
| /****************************************************************************
 | |
|  <macro/inline functionality
 | |
|  */
 | |
| 
 | |
| #define RpMorphTargetSetBoundingSphereMacro(_mt, _sphere)       \
 | |
|     (RwSphereAssign(&((_mt)->boundingSphere), (_sphere)), (_mt))
 | |
| 
 | |
| #define RpMorphTargetGetBoundingSphereMacro(_mt)                \
 | |
|     (&((_mt)->boundingSphere))
 | |
| 
 | |
| #define RpGeometryGetNumMorphTargetsMacro(_geometry)            \
 | |
|     ((_geometry)->numMorphTargets)
 | |
| 
 | |
| #define RpGeometryGetMorphTargetMacro(_geometry, _index)        \
 | |
|     (&((_geometry)->morphTarget[(_index)]))
 | |
| 
 | |
| #define RpGeometryGetPreLightColorsMacro(_geometry)             \
 | |
|     ((_geometry)->preLitLum)
 | |
| 
 | |
| #define RpGeometryGetVertexTexCoordsMacro(_geometry, _uvIndex)    \
 | |
|     ((_geometry)->texCoords[(_uvIndex) - 1])
 | |
| 
 | |
| #define RpGeometryGetNumTexCoordSetsMacro(_geometry)            \
 | |
|     ((_geometry)->numTexCoordSets)
 | |
| 
 | |
| #define RpGeometryGetNumVerticesMacro(_geometry)                \
 | |
|     ((_geometry)->numVertices)
 | |
| 
 | |
| #define RpMorphTargetGetVerticesMacro(_mt)                      \
 | |
|     ((_mt)->verts)
 | |
| 
 | |
| #define RpMorphTargetGetVertexNormalsMacro(_mt)                 \
 | |
|     ((_mt)->normals)
 | |
| 
 | |
| #define RpGeometryGetTrianglesMacro(_geometry)                  \
 | |
|     ((_geometry)->triangles)
 | |
| 
 | |
| #define RpGeometryGetNumTrianglesMacro(_geometry)               \
 | |
|     ((_geometry)->numTriangles)
 | |
| 
 | |
| #define RpGeometryGetMaterialMacro(_geometry, _num)             \
 | |
|     (((_geometry)->matList.materials)[(_num)])
 | |
| 
 | |
| #define RpGeometryGetNumMaterialsMacro(_geometry)               \
 | |
|     ((_geometry)->matList.numMaterials)
 | |
| 
 | |
| #define RpGeometryGetFlagsMacro(_geometry)                      \
 | |
|     ((_geometry)->flags)
 | |
| 
 | |
| #define RpGeometrySetFlagsMacro(_geometry, _flags)              \
 | |
|     (((_geometry)->flags = (_flags)), (_geometry))
 | |
| 
 | |
| 
 | |
| #if !(defined(RWDEBUG) || defined(RWSUPPRESSINLINE))
 | |
| 
 | |
| #define RpMorphTargetSetBoundingSphere(_geometry, _sphere)      \
 | |
|     RpMorphTargetSetBoundingSphereMacro(_geometry, _sphere)
 | |
| 
 | |
| #define RpMorphTargetGetBoundingSphere(_geometry)               \
 | |
|     RpMorphTargetGetBoundingSphereMacro(_geometry)
 | |
| 
 | |
| #define RpGeometryGetNumMorphTargets(_geometry)                 \
 | |
|     RpGeometryGetNumMorphTargetsMacro(_geometry)
 | |
| 
 | |
| #define RpGeometryGetMorphTarget(_geometry, _index)             \
 | |
|     RpGeometryGetMorphTargetMacro(_geometry, _index)
 | |
| 
 | |
| #define RpGeometryGetPreLightColors(_geometry)                  \
 | |
|     RpGeometryGetPreLightColorsMacro(_geometry)
 | |
| 
 | |
| #define RpGeometryGetVertexTexCoords(_geometry, _uvIndex)       \
 | |
|     RpGeometryGetVertexTexCoordsMacro(_geometry, _uvIndex)
 | |
| 
 | |
| #define RpGeometryGetNumTexCoordSets(_geometry)                 \
 | |
|     RpGeometryGetNumTexCoordSetsMacro(_geometry)
 | |
| 
 | |
| #define RpGeometryGetNumVertices(_geometry)                     \
 | |
|     RpGeometryGetNumVerticesMacro(_geometry)
 | |
| 
 | |
| #define RpMorphTargetGetVertices(_mt)                           \
 | |
|     RpMorphTargetGetVerticesMacro(_mt)
 | |
| 
 | |
| #define RpMorphTargetGetVertexNormals(_mt)                      \
 | |
|     RpMorphTargetGetVertexNormalsMacro(_mt)
 | |
| 
 | |
| #define RpGeometryGetTriangles(_geometry)                       \
 | |
|     RpGeometryGetTrianglesMacro(_geometry)
 | |
| 
 | |
| #define RpGeometryGetNumTriangles(_geometry)                    \
 | |
|     RpGeometryGetNumTrianglesMacro(_geometry)
 | |
| 
 | |
| #define RpGeometryGetMaterial(_geometry, _num)                  \
 | |
|     RpGeometryGetMaterialMacro(_geometry, _num)
 | |
| 
 | |
| #define RpGeometryGetNumMaterials(_geometry)                    \
 | |
|     RpGeometryGetNumMaterialsMacro(_geometry)
 | |
| 
 | |
| #define RpGeometryGetFlags(_geometry)                           \
 | |
|     RpGeometryGetFlagsMacro(_geometry)
 | |
| 
 | |
| #define RpGeometrySetFlags(_geometry, _flags)                   \
 | |
|     RpGeometrySetFlagsMacro(_geometry, _flags)
 | |
| 
 | |
| #endif /* !(defined(RWDEBUG) || defined(RWSUPPRESSINLINE)) */
 | |
| 
 | |
| 
 | |
| /****************************************************************************
 | |
|  Function prototypes
 | |
|  */
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern              "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /* Transforms geometry morph target vertices */
 | |
| 
 | |
| extern RpGeometry  *
 | |
| RpGeometryTransform(RpGeometry *geometry,
 | |
|                     const RwMatrix *matrix);
 | |
| 
 | |
| /* Create geometry for a 'space' marker */
 | |
| 
 | |
| extern RpGeometry  *
 | |
| RpGeometryCreateSpace(RwReal radius);
 | |
| 
 | |
| /* Morph targets - Accessing geometry contents */
 | |
| 
 | |
| #if (defined(RWDEBUG) || defined(RWSUPPRESSINLINE))
 | |
| 
 | |
| extern RpMorphTarget  *
 | |
| RpMorphTargetSetBoundingSphere(RpMorphTarget *morphTarget,
 | |
|                                const RwSphere *boundingSphere);
 | |
| 
 | |
| extern RwSphere  *
 | |
| RpMorphTargetGetBoundingSphere(RpMorphTarget *morphTarget);
 | |
| 
 | |
| #endif /* (defined(RWDEBUG) || defined(RWSUPPRESSINLINE)) */
 | |
| 
 | |
| extern const RpMorphTarget  *
 | |
| RpMorphTargetCalcBoundingSphere(const RpMorphTarget *morphTarget,
 | |
|                                 RwSphere *boundingSphere);
 | |
| 
 | |
| extern RwInt32
 | |
| RpGeometryAddMorphTargets(RpGeometry *geometry,
 | |
|                           RwInt32 mtcount);
 | |
| 
 | |
| extern RwInt32
 | |
| RpGeometryAddMorphTarget(RpGeometry *geometry);
 | |
| 
 | |
| extern RpGeometry  *
 | |
| RpGeometryRemoveMorphTarget(RpGeometry *geometry,
 | |
|                             RwInt32 morphTarget);
 | |
| 
 | |
| #if (defined(RWDEBUG) || defined(RWSUPPRESSINLINE))
 | |
| extern RwInt32
 | |
| RpGeometryGetNumMorphTargets(const RpGeometry *geometry);
 | |
| 
 | |
| extern RpMorphTarget  *
 | |
| RpGeometryGetMorphTarget(const RpGeometry *geometry,
 | |
|                          RwInt32 morphTarget);
 | |
| 
 | |
| extern RwRGBA  *
 | |
| RpGeometryGetPreLightColors(const RpGeometry *geometry);
 | |
| 
 | |
| extern RwTexCoords  *
 | |
| RpGeometryGetVertexTexCoords(const RpGeometry *geometry,
 | |
|                              RwTextureCoordinateIndex uvIndex);
 | |
| 
 | |
| extern RwInt32
 | |
| RpGeometryGetNumTexCoordSets(const RpGeometry *geometry);
 | |
| 
 | |
| extern RwInt32
 | |
| RpGeometryGetNumVertices (const RpGeometry *geometry);
 | |
| 
 | |
| extern RwV3d  *
 | |
| RpMorphTargetGetVertices(const RpMorphTarget *morphTarget);
 | |
| 
 | |
| extern RwV3d  *
 | |
| RpMorphTargetGetVertexNormals(const RpMorphTarget *morphTarget);
 | |
| 
 | |
| extern RpTriangle  *
 | |
| RpGeometryGetTriangles(const RpGeometry *geometry);
 | |
| 
 | |
| extern RwInt32
 | |
| RpGeometryGetNumTriangles(const RpGeometry *geometry);
 | |
| 
 | |
| extern RpMaterial  *
 | |
| RpGeometryGetMaterial(const RpGeometry *geometry,
 | |
|                       RwInt32 matNum);
 | |
| 
 | |
| #endif /* (defined(RWDEBUG) || defined(RWSUPPRESSINLINE)) */
 | |
| 
 | |
| extern const RpGeometry  *
 | |
| RpGeometryTriangleSetVertexIndices(const RpGeometry *geometry,
 | |
|                                    RpTriangle *triangle,
 | |
|                                    RwUInt16 vert1,
 | |
|                                    RwUInt16 vert2,
 | |
|                                    RwUInt16 vert3);
 | |
| 
 | |
| extern RpGeometry  *
 | |
| RpGeometryTriangleSetMaterial(RpGeometry *geometry,
 | |
|                               RpTriangle *triangle,
 | |
|                               RpMaterial *material);
 | |
| 
 | |
| extern const RpGeometry  *
 | |
| RpGeometryTriangleGetVertexIndices(const RpGeometry *geometry,
 | |
|                                    const RpTriangle *triangle,
 | |
|                                    RwUInt16 *vert1,
 | |
|                                    RwUInt16 *vert2,
 | |
|                                    RwUInt16 *vert3);
 | |
| 
 | |
| extern RpMaterial   *
 | |
| RpGeometryTriangleGetMaterial(const RpGeometry *geometry,
 | |
|                               const RpTriangle *triangle);
 | |
| 
 | |
| #if (defined(RWDEBUG) || defined(RWSUPPRESSINLINE))
 | |
| extern RwInt32
 | |
| RpGeometryGetNumMaterials(const RpGeometry *geometry);
 | |
| 
 | |
| #endif /* (defined(RWDEBUG) || defined(RWSUPPRESSINLINE)) */
 | |
| 
 | |
| extern RpGeometry  *
 | |
| RpGeometryForAllMaterials(RpGeometry *geometry,
 | |
|                           RpMaterialCallBack fpCallBack,
 | |
|                           void *pData);
 | |
| 
 | |
| /* Accessing the inards of geometry */
 | |
| extern RpGeometry  *
 | |
| RpGeometryLock(RpGeometry *geometry,
 | |
|                RwInt32 lockMode);
 | |
| 
 | |
| extern RpGeometry  *
 | |
| RpGeometryUnlock(RpGeometry *geometry);
 | |
| 
 | |
| extern const RpGeometry  *
 | |
| RpGeometryForAllMeshes(const RpGeometry *geometry,
 | |
|                        RpMeshCallBack fpCallBack,
 | |
|                        void *pData);
 | |
| 
 | |
| /* Creation and destruction */
 | |
| extern RpGeometry  *
 | |
| RpGeometryCreate(RwInt32 numVert,
 | |
|                  RwInt32 numTriangles,
 | |
|                  RwUInt32 format);
 | |
| 
 | |
| extern RwBool
 | |
| RpGeometryDestroy(RpGeometry *geometry);
 | |
| 
 | |
| extern RpGeometry *
 | |
| _rpGeometryAddRef(RpGeometry *geometry);
 | |
| 
 | |
| /* Attaching toolkits */
 | |
| extern RwInt32
 | |
| RpGeometryRegisterPlugin(RwInt32 size,
 | |
|                          RwUInt32 pluginID,
 | |
|                          RwPluginObjectConstructor constructCB,
 | |
|                          RwPluginObjectDestructor destructCB,
 | |
|                          RwPluginObjectCopy copyCB);
 | |
| 
 | |
| extern RwInt32
 | |
| RpGeometryRegisterPluginStream(RwUInt32 pluginID,
 | |
|                                RwPluginDataChunkReadCallBack readCB,
 | |
|                                RwPluginDataChunkWriteCallBack writeCB,
 | |
|                                RwPluginDataChunkGetSizeCallBack getSizeCB);
 | |
| 
 | |
| extern RwInt32
 | |
| RpGeometrySetStreamAlwaysCallBack(RwUInt32 pluginID,
 | |
|                                   RwPluginDataChunkAlwaysCallBack alwaysCB);
 | |
| 
 | |
| extern RwInt32
 | |
| RpGeometryGetPluginOffset(RwUInt32 pluginID);
 | |
| 
 | |
| extern RwBool
 | |
| RpGeometryValidatePlugins(const RpGeometry *geometry);
 | |
| 
 | |
| /* Binary format */
 | |
| extern RwUInt32
 | |
| RpGeometryStreamGetSize(const RpGeometry *geometry);
 | |
| 
 | |
| extern const RpGeometry  *
 | |
| RpGeometryStreamWrite(const RpGeometry *geometry,
 | |
|                       RwStream *stream);
 | |
| 
 | |
| extern RpGeometry  *
 | |
| RpGeometryStreamRead(RwStream *stream);
 | |
| 
 | |
| extern RpGeometryChunkInfo *
 | |
| _rpGeometryChunkInfoRead(RwStream *stream,
 | |
|                          RpGeometryChunkInfo *geometryChunkInfo,
 | |
|                          RwInt32 *bytesRead);
 | |
| 
 | |
| #if (defined(RWDEBUG) || defined(RWSUPPRESSINLINE))
 | |
| /* Flags */
 | |
| extern RwUInt32
 | |
| RpGeometryGetFlags(const RpGeometry *geometry);
 | |
| 
 | |
| extern RpGeometry  *
 | |
| RpGeometrySetFlags(RpGeometry *geometry,
 | |
|                    RwUInt32 flags);
 | |
| 
 | |
| #endif
 | |
| 
 | |
| /* Lighting characteristics */
 | |
| 
 | |
| extern const RwSurfaceProperties *
 | |
| _rpGeometryGetSurfaceProperties(const RpGeometry *geometry);
 | |
| 
 | |
| extern RpGeometry *
 | |
| _rpGeometrySetSurfaceProperties(RpGeometry *geometry,
 | |
|                                 const RwSurfaceProperties *surfaceProperties);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| #define RpGeometryGetSurfaceProperties(_geometry) \
 | |
|     _rpGeometryGetSurfaceProperties(_geometry)
 | |
| 
 | |
| #define RpGeometrySetSurfaceProperties(_geometry, _surfaceProperties) \
 | |
|     _rpGeometrySetSurfaceProperties(_geometry, _surfaceProperties)
 | |
| 
 | |
| #define rpGeometryAddRef(_geometry) \
 | |
|     _rpGeometryAddRef(_geometry) 
 | |
| 
 | |
| #define RpGeometryChunkInfoRead(stream, geometryChunkInfo, bytesRead) \
 | |
|        _rpGeometryChunkInfoRead(stream, geometryChunkInfo, bytesRead)
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: c:/daily/rwsdk/world/baclump.h ---*/
 | |
| 
 | |
| /*
 | |
|  * Clump and atomic handling.
 | |
|  * Clumps and atomics are the movable rendered objects in the world
 | |
|  *
 | |
|  * Copyright (c) 1998 Criterion Software Ltd.
 | |
|  */
 | |
| 
 | |
| 
 | |
| /****************************************************************************
 | |
|  Defines
 | |
|  */
 | |
| 
 | |
| /****************************** Object type ID ******************************/
 | |
| 
 | |
| /* Type IDs */
 | |
| 
 | |
| #define rpATOMIC 1
 | |
| #define rpCLUMP 2
 | |
| 
 | |
| /* Interpolator flags */
 | |
| enum RpInterpolatorFlag
 | |
| {
 | |
|     rpINTERPOLATORDIRTYINSTANCE = 0x01,
 | |
|     rpINTERPOLATORDIRTYSPHERE = 0x02,
 | |
|     rpINTERPOLATORNOFRAMEDIRTY = 0x04,
 | |
|     rpINTERPOLATORFLAGFORCEENUMSIZEINT = RWFORCEENUMSIZEINT
 | |
| };
 | |
| typedef enum RpInterpolatorFlag rpInterpolatorFlag;
 | |
| 
 | |
| /**
 | |
|  * \ingroup rpworlddatatypes
 | |
|  * The bit-field type RpAtomicFlag specifies the options available for
 | |
|  * controlling the behavior of atomics. See API function \ref RpAtomicSetFlags.
 | |
|  *
 | |
|  * \see RpAtomicSetFlags
 | |
|  * \see RpAtomicGetFlags
 | |
|  * \see RpWorldSectorForAllCollisionAtomics
 | |
|  */
 | |
| 
 | |
| enum RpAtomicFlag
 | |
| {
 | |
|     rpATOMICCOLLISIONTEST = 0x01, /**<A generic collision flag to indicate
 | |
|                                    * that the atomic should be considered
 | |
|                                    * in collision tests.
 | |
|                                    */
 | |
|     rpATOMICRENDER = 0x04,      /**<The atomic is rendered if it is
 | |
|                                  * in the view frustum.
 | |
|                                  */
 | |
| 
 | |
|     rpATOMICFLAGFORCEENUMSIZEINT = RWFORCEENUMSIZEINT
 | |
| };
 | |
| typedef enum RpAtomicFlag RpAtomicFlag;
 | |
| 
 | |
| /**
 | |
|  * \ingroup rpworlddatatypes
 | |
|  * \ref RpAtomicSetGeomFlag defines how an atomic references a new geometry
 | |
|  *
 | |
|  * \see RpAtomicSetGeometry
 | |
|  */
 | |
| enum RpAtomicSetGeomFlag
 | |
| {
 | |
|     rpATOMICSAMEBOUNDINGSPHERE = 0x01, /**<The bounding-sphere for the
 | |
|                                         * new geometry is assumed to be the
 | |
|                                         * same as the old one, if any, and
 | |
|                                         * should not be recalculated.
 | |
|                                         */
 | |
| 
 | |
|     rpATOMICSETGEOMFLAGFORCEENUMSIZEINT = RWFORCEENUMSIZEINT
 | |
| };
 | |
| typedef enum RpAtomicSetGeomFlag RpAtomicSetGeomFlag;
 | |
| 
 | |
| enum RpAtomicPrivateFlag
 | |
| {
 | |
|     rpATOMICPRIVATEWORLDBOUNDDIRTY = 0x01,
 | |
|     rpATOMICPRIVATEFLAGFORCEENUMSIZEINT = RWFORCEENUMSIZEINT
 | |
| };
 | |
| typedef enum RpAtomicPrivateFlag rpAtomicPrivateFlag;
 | |
| 
 | |
| 
 | |
| /**
 | |
|  * \ingroup rpworlddatatypes
 | |
|  * \typedef RpAtomic
 | |
|  * Atomic Geometry object. This should be
 | |
|  * considered an opaque type. Use the RpAtomic API functions to access.
 | |
|  */
 | |
| typedef struct RpAtomic RpAtomic;
 | |
| 
 | |
| /**
 | |
|  * \ingroup rpworlddatatypes
 | |
|  * \typedef RpInterpolator
 | |
|  * Morph Target Interpolator.
 | |
|  * This should be considered an opaque type.
 | |
|  * Use the RpInterpolator API functions to access.
 | |
|  */
 | |
| typedef struct RpInterpolator RpInterpolator;
 | |
| 
 | |
| #if (!defined(DOXYGEN))
 | |
| struct RpInterpolator
 | |
| {
 | |
|         RwInt32             flags; /**< flags */
 | |
|         RwInt16             startMorphTarget; /**< startMorphTarget */
 | |
|         RwInt16             endMorphTarget; /**< endMorphTarget */
 | |
|         RwReal              time; /**< time */
 | |
|         RwReal              recipTime; /**< recipTime */
 | |
|         RwReal              position; /**< position */
 | |
| };
 | |
| #endif /* (!defined(DOXYGEN)) */
 | |
| 
 | |
| /* More callbacks */
 | |
| 
 | |
| /**
 | |
|  * \ingroup rpworlddatatypes
 | |
|  * \typedef RpClump
 | |
|  * Clump Geometry object. This should be
 | |
|  * considered an opaque type. Use the RpClump API functions to access.
 | |
|  */
 | |
| typedef struct RpClump RpClump;
 | |
| 
 | |
| /**
 | |
|  * \ingroup rpworlddatatypes
 | |
|  * \typedef RpClumpCallBack
 | |
|  * \ref RpClumpCallBack represents the
 | |
|  * function called from \ref RwCameraForAllClumpsInFrustum and
 | |
|  * \ref RwCameraForAllClumpsNotInFrustum when a clump lies inside the current camera's
 | |
|  * view frustum.  It is also called from \ref RpWorldForAllClumps.  This function should
 | |
|  * return a pointer to the current clump to indicate success.  The callback may return
 | |
|  * NULL to terminate further callbacks on the clumps.
 | |
|  *
 | |
|  * \param  clump   Pointer to the current clump, supplied by
 | |
|  * iterator.
 | |
|  * \param  data  Pointer to developer-defined data structure.
 | |
|  *
 | |
|  * \return Pointer to the current clump.
 | |
|  *
 | |
|  * \see RpWorldForAllClumps
 | |
|  * \see RpClumpGetCallBack
 | |
|  * \see RpClumpSetCallBack
 | |
|  * \see RwCameraForAllClumpsInFrustum
 | |
|  * \see RwCameraForAllClumpsNotInFrustum
 | |
|  */
 | |
| typedef RpClump    *(*RpClumpCallBack) (RpClump * clump, void *data);
 | |
| 
 | |
| #if (!defined(DOXYGEN))
 | |
| struct RpClump
 | |
| {
 | |
|         RwObject            object;
 | |
| 
 | |
|         /* Information about all the Atomics */
 | |
|         RwLinkList          atomicList;
 | |
| 
 | |
|         /* Lists of lights and cameras */
 | |
|         RwLinkList          lightList;
 | |
|         RwLinkList          cameraList;
 | |
| 
 | |
|         /* The clump in the world */
 | |
|         RwLLLink            inWorldLink;
 | |
| 
 | |
|         /* Clump callback */
 | |
|         RpClumpCallBack     callback;
 | |
| 
 | |
|         /* Render frame - used to prevent multiple invocations
 | |
|          * of the clump frustum callback
 | |
|          */
 | |
|         RwUInt16            renderFrame;
 | |
|         RwUInt16            pad;
 | |
| };
 | |
| #endif /* (!defined(DOXYGEN)) */
 | |
| 
 | |
| /**
 | |
|  * \ingroup rpworlddatatypes
 | |
|  * \typedef RpAtomicCallBackRender
 | |
|  * \ref RpAtomicCallBackRender represents the function called from
 | |
|  * \ref RpAtomicRender when the specified atomic
 | |
|  * lies inside the current camera's view frustum. The default callback
 | |
|  * initiates execution of the atomic rendering pipeline. This function should
 | |
|  * return a pointer to the atomic to indicate success.
 | |
|  *
 | |
|  * \param  atomic   Pointer to the current atomic, supplied by
 | |
|  * iterator.
 | |
|  *
 | |
|  * \see RpAtomicRender
 | |
|  */
 | |
| typedef RpAtomic   *(*RpAtomicCallBackRender) (RpAtomic * atomic);
 | |
| 
 | |
| #if (!defined(DOXYGEN))
 | |
| struct RpAtomic
 | |
| {
 | |
|     RwObjectHasFrame    object;
 | |
| 
 | |
|     /* Information for an instance */
 | |
|     RwResEntry         *repEntry;
 | |
| 
 | |
|     /* Triangles making the object */
 | |
|     RpGeometry         *geometry;
 | |
| 
 | |
|     /* Interpolated bounding sphere (in object space and world space) */
 | |
|     RwSphere            boundingSphere;
 | |
|     RwSphere            worldBoundingSphere;
 | |
| 
 | |
|     /* Connections to other atomics */
 | |
|     RpClump            *clump;
 | |
|     RwLLLink            inClumpLink;
 | |
| 
 | |
|     /* callbacks */
 | |
|     RpAtomicCallBackRender renderCallBack;
 | |
| 
 | |
|     /* Interpolation animation pointer */
 | |
|     RpInterpolator      interpolator;
 | |
| 
 | |
|     /* Counter for checks of "render has occurred already" */
 | |
|     RwUInt16            renderFrame;
 | |
|     RwUInt16            pad;
 | |
| 
 | |
|     /* Connections to sectors */
 | |
|     RwLinkList          llWorldSectorsInAtomic;
 | |
| 
 | |
|     /* The Atomic object pipeline for this Atomic */
 | |
|     RxPipeline         *pipeline;
 | |
| };
 | |
| #endif /* (!defined(DOXYGEN)) */
 | |
| 
 | |
| /**
 | |
|  * \ingroup rpworlddatatypes
 | |
|  * \typedef RpAtomicCallBack
 | |
|  * \ref RpAtomicCallBack represents the function called from \ref RpWorldSectorForAllAtomics and
 | |
|  * \ref RpClumpForAllAtomics for all atomics in a given world sector or clump.
 | |
|  * This function should return a pointer to the current atomic to indicate
 | |
|  * success. The callback may return NULL to terminate further callbacks on
 | |
|  * the world sector.
 | |
|  *
 | |
|  * \param  atomic   Pointer to the current atomic, supplied by
 | |
|  * iterator.
 | |
|  * \param  data  Pointer to developer-defined data structure.
 | |
|  */
 | |
| typedef RpAtomic   *(*RpAtomicCallBack) (RpAtomic * atomic, void *data);
 | |
| 
 | |
| typedef struct RpTie RpTie;
 | |
| 
 | |
| struct RpTie
 | |
| {
 | |
|     /* Information for an atomic sector */
 | |
|     RwLLLink            lAtomicInWorldSector; /* Atomics IN this ATOMIC SECTOR */
 | |
|     RpAtomic           *apAtom;
 | |
| 
 | |
|     /* Information for a atomic */
 | |
|     RwLLLink            lWorldSectorInAtomic; /* Atomic sectors HOLDING this atomic */
 | |
|     RpWorldSector      *worldSector;
 | |
| };
 | |
| 
 | |
| typedef struct RpClumpChunkInfo RpClumpChunkInfo;
 | |
| typedef struct RpClumpChunkInfo _rpClump;
 | |
| typedef struct RpClumpChunkInfo33000 _rpClump33000;
 | |
| 
 | |
| struct RpClumpChunkInfo
 | |
| {
 | |
|     RwInt32             numAtomics;
 | |
|     RwInt32             numLights;
 | |
|     RwInt32             numCameras;
 | |
| };
 | |
| 
 | |
| struct RpClumpChunkInfo33000
 | |
| {
 | |
|     RwInt32             numAtomics;
 | |
| };
 | |
| 
 | |
| /****************************************************************************
 | |
|  <macro/inline functionality
 | |
| 
 | |
|  */
 | |
| 
 | |
| /* NB "RpAtomicRender(atom++) will break it */
 | |
| #define RpAtomicRenderMacro(_atomic)                                    \
 | |
|     ((_atomic)->renderCallBack(_atomic))
 | |
| 
 | |
| #define RpAtomicGetGeometryMacro(_atomic)                               \
 | |
|     ((_atomic)->geometry)
 | |
| 
 | |
| #if (!defined(RpAtomicSetRenderCallBackMacro))
 | |
| 
 | |
| /* NB "RpAtomicSetRenderCallBack(atom++, callback)" will break it */
 | |
| #define RpAtomicSetRenderCallBackMacro(_atomic, _callback)              \
 | |
| MACRO_START                                                             \
 | |
| {                                                                       \
 | |
|     (_atomic)->renderCallBack = (_callback);                            \
 | |
|     if (!(_atomic)->renderCallBack)                                     \
 | |
|     {                                                                   \
 | |
|         (_atomic)->renderCallBack = AtomicDefaultRenderCallBack;        \
 | |
|     }                                                                   \
 | |
| }                                                                       \
 | |
| MACRO_STOP
 | |
| 
 | |
| #endif /* (!defined(RpAtomicSetRenderCallBackMacro)) */
 | |
| 
 | |
| #define RpAtomicGetRenderCallBackMacro(_atomic)                         \
 | |
|     ((_atomic)->renderCallBack)
 | |
| 
 | |
| #define RpAtomicGetInterpolatorMacro(_atomic)                         \
 | |
|     (&((_atomic)->interpolator))
 | |
| 
 | |
| #define RpInterpolatorGetStartMorphTargetMacro(_intrp)                  \
 | |
|     ((_intrp)->startMorphTarget)
 | |
| 
 | |
| #define RpInterpolatorGetEndMorphTargetMacro(_intrp)                    \
 | |
|     ((_intrp)->endMorphTarget)
 | |
| 
 | |
| #define RpInterpolatorGetValueMacro(_intrp)                             \
 | |
|     ((_intrp)->position)
 | |
| 
 | |
| #define RpInterpolatorGetScaleMacro(_intrp)                             \
 | |
|     ((_intrp)->time)
 | |
| 
 | |
| /* NB "RpInterpolatorSetStartMorphTarget(interp++, target)" will break it */
 | |
| #define RpInterpolatorSetStartMorphTargetMacro(_intrp, _target, _atomic)\
 | |
|     ((_intrp)->startMorphTarget = (RwInt16) (_target),                  \
 | |
|      (_intrp)->flags |= (RwInt32)(rpINTERPOLATORDIRTYINSTANCE |         \
 | |
|                                   rpINTERPOLATORDIRTYSPHERE     ),      \
 | |
|      ((!((_intrp)->flags & rpINTERPOLATORNOFRAMEDIRTY))?                \
 | |
|          ((RpAtomicGetFrame(_atomic))?                                  \
 | |
|             (RwFrameUpdateObjects(RpAtomicGetFrame(_atomic))):          \
 | |
|             (0)):                                                       \
 | |
|          (0)),                                                          \
 | |
|      (_intrp))
 | |
| 
 | |
| /* NB "RpInterpolatorSetEndMorphTarget(interp++, target)" will break it */
 | |
| #define RpInterpolatorSetEndMorphTargetMacro(_intrp, _target, _atomic)  \
 | |
|     ((_intrp)->endMorphTarget = (RwInt16) (_target),                    \
 | |
|      (_intrp)->flags |= (RwInt32)(rpINTERPOLATORDIRTYINSTANCE |         \
 | |
|                                   rpINTERPOLATORDIRTYSPHERE     ),      \
 | |
|      ((!((_intrp)->flags & rpINTERPOLATORNOFRAMEDIRTY))?                \
 | |
|          ((RpAtomicGetFrame(_atomic))?                                  \
 | |
|             (RwFrameUpdateObjects(RpAtomicGetFrame(_atomic))):          \
 | |
|             (0)):                                                       \
 | |
|          (0)),                                                          \
 | |
|      (_intrp))
 | |
| 
 | |
| /* NB "RpInterpolatorSetValue(interp++, value)" will break it */
 | |
| #define RpInterpolatorSetValueMacro(_intrp, _value, _atomic)            \
 | |
|     ((_intrp)->position = (_value),                                     \
 | |
|      (_intrp)->flags |= (RwInt32)(rpINTERPOLATORDIRTYINSTANCE |         \
 | |
|                                   rpINTERPOLATORDIRTYSPHERE     ),      \
 | |
|      ((!((_intrp)->flags & rpINTERPOLATORNOFRAMEDIRTY))?                \
 | |
|          ((RpAtomicGetFrame(_atomic))?                                  \
 | |
|             (RwFrameUpdateObjects(RpAtomicGetFrame(_atomic))):          \
 | |
|             (0)):                                                       \
 | |
|          (0)),                                                          \
 | |
|      (_intrp))
 | |
| 
 | |
| /* NB "RpInterpolatorSetScale(interp++, *(scale++))" will break it */
 | |
| #define RpInterpolatorSetScaleMacro(_intrp, _scale, _atomic)            \
 | |
|     ((_intrp)->time = (_scale),                                         \
 | |
|      (_intrp)->recipTime = (RwReal) (1.0) / (_scale),                   \
 | |
|      (_intrp)->flags |= (RwInt32)(rpINTERPOLATORDIRTYINSTANCE |         \
 | |
|                                   rpINTERPOLATORDIRTYSPHERE     ),      \
 | |
|      ((!((_intrp)->flags & rpINTERPOLATORNOFRAMEDIRTY))?                \
 | |
|          ((RpAtomicGetFrame(_atomic))?                                  \
 | |
|             (RwFrameUpdateObjects(RpAtomicGetFrame(_atomic))):          \
 | |
|             (0)):                                                       \
 | |
|          (0)),                                                          \
 | |
|      (_intrp))
 | |
| 
 | |
| #define RpAtomicGetClumpMacro(_atomic)                                  \
 | |
|     ((_atomic)->clump)
 | |
| 
 | |
| /* NB "RpAtomicGetBoundingSphere(atomic++)" will break it */
 | |
| #define RpAtomicGetBoundingSphereMacro(_atomic)                         \
 | |
|     ((((_atomic)->interpolator.flags & rpINTERPOLATORDIRTYSPHERE)?      \
 | |
|       _rpAtomicResyncInterpolatedSphere(_atomic), 0: 0),                \
 | |
|       &((_atomic)->boundingSphere))
 | |
| #define RpAtomicGetFrameMacro(_atomic)                                  \
 | |
|     ((RwFrame *) rwObjectGetParent(_atomic))
 | |
| 
 | |
| /* NB "RpClumpSetFrame(clump++, frame)" will break it */
 | |
| #if (!defined(RpClumpSetFrameMacro))
 | |
| #define RpClumpSetFrameMacro(_clump, _frame)                            \
 | |
|     (rwObjectSetParent(_clump, _frame),                                 \
 | |
|      (_clump))
 | |
| #endif /* (!defined(RpClumpSetFrameMacro)) */
 | |
| 
 | |
| #if (!defined(RpClumpSetFrameVoidMacro))
 | |
| #define RpClumpSetFrameVoidMacro(_clump, _frame)                        \
 | |
| MACRO_START                                                             \
 | |
| {                                                                       \
 | |
|     rwObjectSetParent(_clump, _frame);                                  \
 | |
| }                                                                       \
 | |
| MACRO_STOP
 | |
| #endif /* (!defined(RpClumpSetFrameVoidMacro)) */
 | |
| 
 | |
| #define RpClumpGetFrameMacro(_clump)                                    \
 | |
|     ((RwFrame *) rwObjectGetParent(_clump))
 | |
| 
 | |
| /* NB "RpAtomicSetFlags(atomic++, flags)" will break it */
 | |
| #if (!defined(RpAtomicSetFlagsMacro))
 | |
| #define RpAtomicSetFlagsMacro(_atomic, _flags)                          \
 | |
|     (rwObjectSetFlags(_atomic, _flags),                                 \
 | |
|      (_atomic))
 | |
| #endif /* (!defined(RpAtomicSetFlagsMacro)) */
 | |
| 
 | |
| #define RpAtomicGetFlagsMacro(_atomic)                                  \
 | |
|     (rwObjectGetFlags(_atomic))
 | |
| 
 | |
| #if (! ( defined(RWDEBUG) || defined(RWSUPPRESSINLINE) ))
 | |
| 
 | |
| #define RpAtomicRender(_atomic) \
 | |
|     RpAtomicRenderMacro(_atomic)
 | |
| 
 | |
| #define RpAtomicGetGeometry(_atomic) \
 | |
|     RpAtomicGetGeometryMacro(_atomic)
 | |
| 
 | |
| #define RpAtomicSetRenderCallBack(_atomic, _callback) \
 | |
|     RpAtomicSetRenderCallBackMacro(_atomic, _callback)
 | |
| 
 | |
| #define RpAtomicGetRenderCallBack(_atomic) \
 | |
|     RpAtomicGetRenderCallBackMacro(_atomic)
 | |
| 
 | |
| #define RpAtomicGetInterpolator(_atomic) \
 | |
|     RpAtomicGetInterpolatorMacro(_atomic)
 | |
| 
 | |
| #define RpInterpolatorGetStartMorphTarget(_intrp) \
 | |
|     RpInterpolatorGetStartMorphTargetMacro(_intrp)
 | |
| 
 | |
| #define RpInterpolatorGetEndMorphTarget(_intrp) \
 | |
|     RpInterpolatorGetEndMorphTargetMacro(_intrp)
 | |
| 
 | |
| #define RpInterpolatorGetValue(_intrp) \
 | |
|     RpInterpolatorGetValueMacro(_intrp)
 | |
| 
 | |
| #define RpInterpolatorGetScale(_intrp) \
 | |
|     RpInterpolatorGetScaleMacro(_intrp)
 | |
| 
 | |
| #define RpInterpolatorSetStartMorphTarget(_intrp, _target, _atomic) \
 | |
|     RpInterpolatorSetStartMorphTargetMacro(_intrp, _target, _atomic)
 | |
| 
 | |
| #define RpInterpolatorSetEndMorphTarget(_intrp, _target, _atomic) \
 | |
|     RpInterpolatorSetEndMorphTargetMacro(_intrp, _target, _atomic)
 | |
| 
 | |
| #define RpInterpolatorSetValue(_intrp, _value, _atomic) \
 | |
|     RpInterpolatorSetValueMacro(_intrp, _value, _atomic)
 | |
| 
 | |
| #define RpInterpolatorSetScale(_intrp, _scale, _atomic) \
 | |
|     RpInterpolatorSetScaleMacro(_intrp, _scale, _atomic)
 | |
| 
 | |
| #define RpAtomicGetClump(_atomic) \
 | |
|     RpAtomicGetClumpMacro(_atomic)
 | |
| 
 | |
| #define RpAtomicGetBoundingSphere(_atomic) \
 | |
|     RpAtomicGetBoundingSphereMacro(_atomic)
 | |
| 
 | |
| #define RpAtomicGetFrame(_atomic) \
 | |
|     RpAtomicGetFrameMacro(_atomic)
 | |
| 
 | |
| #define RpClumpSetFrame(_clump, _frame) \
 | |
|     RpClumpSetFrameMacro(_clump, _frame)
 | |
| 
 | |
| #define RpClumpGetFrame(_clump) \
 | |
|     RpClumpGetFrameMacro(_clump)
 | |
| 
 | |
| #define RpAtomicSetFlags(_atomic, _flags) \
 | |
|     RpAtomicSetFlagsMacro(_atomic, _flags)
 | |
| 
 | |
| #define RpAtomicGetFlags(_atomic) \
 | |
|     RpAtomicGetFlagsMacro(_atomic)
 | |
| 
 | |
| #endif /* (! ( defined(RWDEBUG) || defined(RWSUPPRESSINLINE) )) */
 | |
| 
 | |
| /****************************************************************************
 | |
|  Function prototypes
 | |
|  */
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern              "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /* Macro version of RpAtomicSetRenderCallBack needs this */
 | |
| extern RpAtomic *
 | |
| AtomicDefaultRenderCallBack(RpAtomic * atomic);
 | |
| 
 | |
| extern void
 | |
| _rpAtomicResyncInterpolatedSphere(RpAtomic * atomic);
 | |
| 
 | |
| extern const RwSphere *
 | |
| RpAtomicGetWorldBoundingSphere(RpAtomic *  atomic);
 | |
| 
 | |
| /* Enumeration */
 | |
| extern RpClump *
 | |
| RpClumpForAllAtomics(RpClump * clump,
 | |
|                      RpAtomicCallBack callback,
 | |
|                      void *pData);
 | |
| 
 | |
| extern RpClump *
 | |
| RpClumpForAllLights(RpClump * clump,
 | |
|                     RpLightCallBack callback,
 | |
|                     void *pData);
 | |
| 
 | |
| extern RpClump *
 | |
| RpClumpForAllCameras(RpClump * clump,
 | |
|                      RwCameraCallBack callback,
 | |
|                      void *pData);
 | |
| 
 | |
| /* Frames */
 | |
| extern RpAtomic *
 | |
| RpAtomicSetFrame(RpAtomic * atomic,
 | |
|                  RwFrame * frame);
 | |
| 
 | |
| /* Create a space marking clump */
 | |
| extern RpClump *
 | |
| RpClumpCreateSpace(const RwV3d * position,
 | |
|                    RwReal radius);
 | |
| 
 | |
| /* Instancing and rendering */
 | |
| extern RpClump *
 | |
| RpClumpRender(RpClump * clump);
 | |
| 
 | |
| extern RpClump *
 | |
| RpClumpRemoveAtomic(RpClump * clump,
 | |
|                     RpAtomic * atomic);
 | |
| 
 | |
| extern RpClump *
 | |
| RpClumpAddAtomic(RpClump * clump,
 | |
|                  RpAtomic * atomic);
 | |
| 
 | |
| extern RpClump *
 | |
| RpClumpRemoveLight(RpClump * clump,
 | |
|                    RpLight * light);
 | |
| 
 | |
| extern RpClump *
 | |
| RpClumpAddLight(RpClump * clump,
 | |
|                 RpLight * light);
 | |
| 
 | |
| extern RpClump *
 | |
| RpClumpRemoveCamera(RpClump * clump,
 | |
|                     RwCamera * camera);
 | |
| 
 | |
| extern RpClump *
 | |
| RpClumpAddCamera(RpClump * clump,
 | |
|                  RwCamera * camera);
 | |
| 
 | |
| /* Creation and destruction of clumps */
 | |
| extern RwBool
 | |
| RpClumpDestroy(RpClump * clump);
 | |
| 
 | |
| extern RpClump *
 | |
| RpClumpCreate(void);
 | |
| 
 | |
| extern RpClump *
 | |
| RpClumpClone(RpClump * clump);
 | |
| 
 | |
| /* Creation and destruction of atomics*/
 | |
| extern RwBool
 | |
| RpAtomicDestroy(RpAtomic * atomic);
 | |
| 
 | |
| extern RpAtomic *
 | |
| RpAtomicClone(RpAtomic * atomic);
 | |
| 
 | |
| extern RpAtomic *
 | |
| RpAtomicCreate(void);
 | |
| 
 | |
| /* Setting and getting geometry for an atomic */
 | |
| extern RpAtomic *
 | |
| RpAtomicSetGeometry(RpAtomic * atomic,
 | |
|                     RpGeometry * geometry,
 | |
|                     RwUInt32 flags);
 | |
| 
 | |
| /* Frustum callbacks */
 | |
| extern RpClump *
 | |
| RpClumpSetCallBack(RpClump * clump,
 | |
|                    RpClumpCallBack callback);
 | |
| 
 | |
| extern RpClumpCallBack
 | |
| RpClumpGetCallBack(const RpClump * clump);
 | |
| 
 | |
| /* The number of atomics in a clump */
 | |
| extern RwInt32
 | |
| RpClumpGetNumAtomics(RpClump * clump);
 | |
| 
 | |
| extern RwInt32
 | |
| RpClumpGetNumLights(RpClump * clump);
 | |
| 
 | |
| extern RwInt32
 | |
| RpClumpGetNumCameras(RpClump * clump);
 | |
| 
 | |
| /* Light and camera extensions */
 | |
| extern RpClump *
 | |
| RpLightGetClump(const RpLight *light);
 | |
| 
 | |
| extern RpClump *
 | |
| RwCameraGetClump(const RwCamera *camera);
 | |
| 
 | |
| /* Binary format */
 | |
| extern RwUInt32
 | |
| RpAtomicStreamGetSize(RpAtomic * atomic);
 | |
| 
 | |
| extern RpAtomic *
 | |
| RpAtomicStreamRead(RwStream * stream);
 | |
| 
 | |
| extern RpAtomic *
 | |
| RpAtomicStreamWrite(RpAtomic * atomic,
 | |
|                     RwStream * stream);
 | |
| 
 | |
| extern RwUInt32
 | |
| RpClumpStreamGetSize(RpClump * clump);
 | |
| 
 | |
| extern RpClump *
 | |
| RpClumpStreamRead(RwStream * stream);
 | |
| 
 | |
| extern RpClump *
 | |
| RpClumpStreamWrite(RpClump * clump,
 | |
|                    RwStream * stream);
 | |
| 
 | |
| extern RpClumpChunkInfo *
 | |
| _rpClumpChunkInfoRead(RwStream * stream,
 | |
|                       RpClumpChunkInfo * clumpChunkInfo,
 | |
|                       RwInt32 * bytesRead);
 | |
| 
 | |
| /* Attaching toolkits */
 | |
| extern RwInt32
 | |
| RpAtomicRegisterPlugin(RwInt32 size,
 | |
|                        RwUInt32 pluginID,
 | |
|                        RwPluginObjectConstructor constructCB,
 | |
|                        RwPluginObjectDestructor destructCB,
 | |
|                        RwPluginObjectCopy copyCB);
 | |
| 
 | |
| extern RwInt32
 | |
| RpClumpRegisterPlugin(RwInt32 size,
 | |
|                       RwUInt32 pluginID,
 | |
|                       RwPluginObjectConstructor constructCB,
 | |
|                       RwPluginObjectDestructor destructCB,
 | |
|                       RwPluginObjectCopy copyCB);
 | |
| 
 | |
| extern RwInt32
 | |
| RpAtomicRegisterPluginStream(RwUInt32 pluginID,
 | |
|                              RwPluginDataChunkReadCallBack
 | |
|                              readCB,
 | |
|                              RwPluginDataChunkWriteCallBack
 | |
|                              writeCB,
 | |
|                              RwPluginDataChunkGetSizeCallBack
 | |
|                              getSizeCB);
 | |
| 
 | |
| extern RwInt32
 | |
| RpAtomicSetStreamAlwaysCallBack(RwUInt32 pluginID,
 | |
|                                      RwPluginDataChunkAlwaysCallBack alwaysCB);
 | |
| 
 | |
| extern RwInt32
 | |
| RpAtomicSetStreamRightsCallBack(RwUInt32 pluginID,
 | |
|                                      RwPluginDataChunkRightsCallBack rightsCB);
 | |
| 
 | |
| extern RwInt32
 | |
| RpClumpRegisterPluginStream(RwUInt32 pluginID,
 | |
|                             RwPluginDataChunkReadCallBack  readCB,
 | |
|                             RwPluginDataChunkWriteCallBack writeCB,
 | |
|                             RwPluginDataChunkGetSizeCallBack getSizeCB);
 | |
| 
 | |
| extern RwInt32
 | |
| RpClumpSetStreamAlwaysCallBack(RwUInt32 pluginID,
 | |
|                                     RwPluginDataChunkAlwaysCallBack alwaysCB);
 | |
| 
 | |
| extern RwInt32
 | |
| RpAtomicGetPluginOffset(RwUInt32 pluginID);
 | |
| 
 | |
| extern RwInt32
 | |
| RpClumpGetPluginOffset(RwUInt32 pluginID);
 | |
| 
 | |
| extern RwBool
 | |
| RpAtomicValidatePlugins(const RpAtomic * atomic);
 | |
| 
 | |
| extern RwBool
 | |
| RpClumpValidatePlugins(const RpClump * clump);
 | |
| 
 | |
| #if ( defined(RWDEBUG) || defined(RWSUPPRESSINLINE) )
 | |
| extern RwFrame *
 | |
| RpAtomicGetFrame(const RpAtomic * atomic);
 | |
| 
 | |
| extern RwFrame *
 | |
| RpClumpGetFrame(const RpClump * clump);
 | |
| 
 | |
| extern RpClump *
 | |
| RpClumpSetFrame(RpClump * clump,
 | |
|                 RwFrame * frame);
 | |
| 
 | |
| /* Flags */
 | |
| extern RpAtomic *
 | |
| RpAtomicSetFlags(RpAtomic * atomic,
 | |
|                  RwUInt32 flags);
 | |
| 
 | |
| extern RwUInt32
 | |
| RpAtomicGetFlags(const RpAtomic * atomic);
 | |
| 
 | |
| extern RwSphere *
 | |
| RpAtomicGetBoundingSphere(RpAtomic * atomic);
 | |
| 
 | |
| extern RwInt32
 | |
| RpInterpolatorGetEndMorphTarget(const RpInterpolator * interpolator);
 | |
| 
 | |
| extern RwInt32
 | |
| RpInterpolatorGetStartMorphTarget(const RpInterpolator * interpolator);
 | |
| 
 | |
| extern RwReal
 | |
| RpInterpolatorGetValue(const RpInterpolator * interpolator);
 | |
| 
 | |
| extern RwReal
 | |
| RpInterpolatorGetScale(const RpInterpolator * interpolator);
 | |
| 
 | |
| extern RpInterpolator *
 | |
| RpInterpolatorSetEndMorphTarget(RpInterpolator * interpolator,
 | |
|                                 RwInt32 morphTarget,
 | |
|                                 RpAtomic * atomic);
 | |
| 
 | |
| extern RpInterpolator *
 | |
| RpInterpolatorSetStartMorphTarget(RpInterpolator * interpolator,
 | |
|                                   RwInt32 morphTarget,
 | |
|                                   RpAtomic * atomic);
 | |
| 
 | |
| extern RpInterpolator *
 | |
| RpInterpolatorSetValue(RpInterpolator *  interpolator,
 | |
|                        RwReal value,
 | |
|                        RpAtomic *atomic);
 | |
| 
 | |
| extern RpInterpolator *
 | |
| RpInterpolatorSetScale(RpInterpolator * interpolator,
 | |
|                        RwReal scale,
 | |
|                        RpAtomic *atomic);
 | |
| 
 | |
| extern RpAtomic *
 | |
| RpAtomicRender(RpAtomic * atomic);
 | |
| 
 | |
| /* Building clumps */
 | |
| extern RpClump *
 | |
| RpAtomicGetClump(const RpAtomic * atomic);
 | |
| 
 | |
| extern RpInterpolator *
 | |
| RpAtomicGetInterpolator(RpAtomic * atomic);
 | |
| 
 | |
| extern RpGeometry *
 | |
| RpAtomicGetGeometry(const RpAtomic * atomic);
 | |
| 
 | |
| extern void
 | |
| RpAtomicSetRenderCallBack(RpAtomic * atomic,
 | |
|                           RpAtomicCallBackRender callback);
 | |
| 
 | |
| extern RpAtomicCallBackRender
 | |
| RpAtomicGetRenderCallBack(const RpAtomic * atomic);
 | |
| 
 | |
| #endif
 | |
| 
 | |
| /* ( defined(RWDEBUG) || defined(RWSUPPRESSINLINE) ) */
 | |
| 
 | |
| extern RwBool RpAtomicInstance(RpAtomic *atomic);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| #define RpClumpChunkInfoRead(stream, clumpChunkInfo, bytesRead) \
 | |
|        _rpClumpChunkInfoRead(stream, clumpChunkInfo, bytesRead)
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: c:/daily/rwsdk/world/baworld.h ---*/
 | |
| 
 | |
| /*
 | |
|  * World handling.
 | |
|  * World give objects scope, and provide a mechanism for
 | |
|  * efficiency static object rendering.
 | |
|  *
 | |
|  * Copyright (c) 1998 Criterion Software Ltd.
 | |
|  *
 | |
|  */
 | |
| 
 | |
| /****************************************************************************
 | |
|  Defines
 | |
|  */
 | |
| 
 | |
| /* Type ID */
 | |
| #define rpWORLD 7
 | |
| 
 | |
| /* RpWorld private flags (in RwObject) */
 | |
| enum RpWorldPrivateFlag
 | |
| {
 | |
|     rpWORLDSINGLEMALLOC = 0x01,
 | |
|     rpWORLDPRIVATEFLAGFORCEENUMSIZEINT = RWFORCEENUMSIZEINT
 | |
| };
 | |
| typedef enum RpWorldPrivateFlag RpWorldPrivateFlag;
 | |
| 
 | |
| /**
 | |
|  * \ingroup rpworlddatatypes
 | |
|  * The bit-field type \ref RpWorldFlag specifies the options available
 | |
|  * for creating the static geometry component of a world (see API function \ref RpWorldSetFlags):
 | |
|  */
 | |
| enum RpWorldFlag
 | |
| {
 | |
|     rpWORLDTRISTRIP  = 0x01, /**<This world's meshes can be rendered
 | |
|                                  as tri strips */
 | |
|     rpWORLDPOSITIONS = 0x02, /**<This world has positions */
 | |
|     rpWORLDTEXTURED  = 0x04, /**<This world has only one set of texture coordinates */
 | |
|     rpWORLDPRELIT    = 0x08, /**<This world has luminance values */
 | |
|     rpWORLDNORMALS   = 0x10, /**<This world has normals */
 | |
|     rpWORLDLIGHT     = 0x20, /**<This world will be lit */
 | |
|     rpWORLDMODULATEMATERIALCOLOR = 0x40, 
 | |
|                              /**<Modulate material color with vertex colors 
 | |
|                                  (pre-lit + lit) */
 | |
|     rpWORLDTEXTURED2 = 0x80, /**<This world has 2 or more sets of texture coordinates */
 | |
| 
 | |
|     /*
 | |
|      * These above flags were stored in the flags field in an RwObject, they
 | |
|      * are now stored in the flags file of the RpWorld.
 | |
|      */
 | |
| 
 | |
|     rpWORLDNATIVE               = 0x01000000,
 | |
|     rpWORLDNATIVEINSTANCE       = 0x02000000,
 | |
| 
 | |
|     rpWORLDFLAGSMASK            = 0x000000FF,
 | |
|     rpWORLDNATIVEFLAGSMASK      = 0x0F000000,
 | |
| 
 | |
|     rpWORLDSECTORSOVERLAP       = 0x40000000,
 | |
| 
 | |
|     rpWORLDFLAGFORCEENUMSIZEINT = RWFORCEENUMSIZEINT
 | |
| };
 | |
| typedef enum RpWorldFlag RpWorldFlag;
 | |
| 
 | |
| /* Multi texture coordinate format specifier */
 | |
| #define rpWORLDTEXCOORDSETS(_num)  ((_num & 0xff) << 16)
 | |
| 
 | |
| /* Maximum depth of BSP tree */
 | |
| #define rpWORLDMAXBSPDEPTH 64
 | |
| 
 | |
| 
 | |
| /* macro/inline functionality */
 | |
| #define RpWorldGetBBoxMacro(_world)                         \
 | |
|     (&((_world)->boundingBox))
 | |
| 
 | |
| #define RpWorldGetOriginMacro(_world)                       \
 | |
|     (&((_world)->worldOrigin))
 | |
| 
 | |
| #define RpWorldGetNumMaterialsMacro(_world)                 \
 | |
|     ((_world)->matList.numMaterials)
 | |
| 
 | |
| #define RpWorldGetMaterialMacro(_world, _num)               \
 | |
|     (((_world)->matList.materials)[(_num)])
 | |
| 
 | |
| #define RpWorldGetNumClumpsMacro(_world)                    \
 | |
|     ((_world)->numClumpsInWorld)
 | |
| 
 | |
| #define RpWorldSetRenderOrderMacro(_world, _renderOrder)    \
 | |
|     (((_world)->renderOrder = _renderOrder), (_world))
 | |
| 
 | |
| #define RpWorldGetRenderOrderMacro(_world)                  \
 | |
|     ((_world)->renderOrder)
 | |
| 
 | |
| #define RpWorldSetFlagsMacro(_world, _flags)                \
 | |
|     (((_world)->flags = (_flags)), (_world))
 | |
| 
 | |
| #define RpWorldGetFlagsMacro(_world)                        \
 | |
|     ((_world)->flags)
 | |
| 
 | |
| 
 | |
| #if !(defined(RWDEBUG) || defined(RWSUPPRESSINLINE))
 | |
| 
 | |
| #define RpWorldGetBBox(_world)                              \
 | |
|     RpWorldGetBBoxMacro(_world)
 | |
| 
 | |
| #define RpWorldGetOrigin(_world)                            \
 | |
|     RpWorldGetOriginMacro(_world)
 | |
| 
 | |
| #define RpWorldGetNumMaterials(_world)                      \
 | |
|     RpWorldGetNumMaterialsMacro(_world)
 | |
| 
 | |
| #define RpWorldGetMaterial(_world, _num)                    \
 | |
|     RpWorldGetMaterialMacro(_world, _num)
 | |
| 
 | |
| #define RpWorldGetNumClumps(_world)                         \
 | |
|     RpWorldGetNumClumpsMacro(_world)
 | |
| 
 | |
| #define RpWorldSetRenderOrder(_world, _renderOrder)         \
 | |
|     RpWorldSetRenderOrderMacro(_world, _renderOrder)
 | |
| 
 | |
| #define RpWorldGetRenderOrder(_world)                       \
 | |
|     RpWorldGetRenderOrderMacro(_world)
 | |
| 
 | |
| #define RpWorldSetFlags(_world, _flags)                     \
 | |
|     RpWorldSetFlagsMacro(_world, _flags)
 | |
| 
 | |
| #define RpWorldGetFlags(_world)                             \
 | |
|     RpWorldGetFlagsMacro(_world)
 | |
| 
 | |
| #endif /* !(defined(RWDEBUG) || defined(RWSUPPRESSINLINE)) */
 | |
| 
 | |
| 
 | |
| /****************************************************************************
 | |
|  Global types
 | |
|  */
 | |
| 
 | |
| 
 | |
| /**
 | |
|  * \ingroup rpworlddatatypes
 | |
|  * \ref RpWorldRenderOrder
 | |
|  * represents the options available for
 | |
|  * the rendering order of world sectors in the camera's view frustum (see
 | |
|  * API function \ref RpWorldSetRenderOrder).
 | |
|  */
 | |
| enum RpWorldRenderOrder
 | |
| {
 | |
|     rpWORLDRENDERNARENDERORDER = 0,
 | |
|     rpWORLDRENDERFRONT2BACK,  /**<Renders nearest sectors first */
 | |
|     rpWORLDRENDERBACK2FRONT, /**<Renders furthest sectors first */
 | |
|     rpWORLDRENDERORDERFORCEENUMSIZEINT = RWFORCEENUMSIZEINT
 | |
| };
 | |
| typedef enum RpWorldRenderOrder RpWorldRenderOrder;
 | |
| 
 | |
| /**
 | |
|  * \ingroup rpworlddatatypes
 | |
|  * \typedef RpWorldSectorCallBackRender
 | |
|  * \ref RpWorldSectorCallBackRender represents the function called from
 | |
|  * \ref RpWorldSectorRender when the specified world sector lies inside the
 | |
|  * current camera's view frustum. The default callback initiates execution of
 | |
|  * the world sector rendering pipeline. This function should return a pointer
 | |
|  * to the world sector to indicate success
 | |
|  *
 | |
|  * \return Pointer to the world sector.
 | |
|  *
 | |
|  * \param  worldSector   Pointer to the world sector to be
 | |
|  * rendered
 | |
|  */
 | |
| typedef RpWorldSector *(*RpWorldSectorCallBackRender) (RpWorldSector *
 | |
|                                                        worldSector);
 | |
| 
 | |
| /**
 | |
|  * \ingroup rpworlddatatypes
 | |
|  * \typedef RpWorld
 | |
|  * World object. This should be considered an opaque type.
 | |
|  * Use the RpWorld API functions to access.
 | |
|  */
 | |
| typedef struct RpWorld RpWorld;
 | |
| 
 | |
| #if (!defined(DOXYGEN))
 | |
| struct RpWorld
 | |
| {
 | |
|     RwObject            object;
 | |
| 
 | |
|     RwUInt32            flags;
 | |
| 
 | |
|     RpWorldRenderOrder  renderOrder;
 | |
| 
 | |
|     /* Materials */
 | |
|     RpMaterialList      matList;
 | |
| 
 | |
|     /* The world stored as a BSP tree */
 | |
|     RpSector           *rootSector;
 | |
| 
 | |
|     /* The number of texture coordinate sets in each sector */
 | |
|     RwInt32             numTexCoordSets;
 | |
| 
 | |
|     /* Render frame used when last rendered */
 | |
|     RwInt32             numClumpsInWorld;
 | |
|     RwLLLink           *currentClumpLink;
 | |
| 
 | |
|     /* All the clumps in the world */
 | |
|     RwLinkList          clumpList;
 | |
| 
 | |
|     /* All of the lights in the world */
 | |
|     RwLinkList          lightList;
 | |
| 
 | |
|     /* Directional lights in the world */
 | |
|     RwLinkList          directionalLightList;
 | |
| 
 | |
|     /* The worlds origin offset */
 | |
|     RwV3d               worldOrigin;
 | |
| 
 | |
|     /* Bounding box around the whole world */
 | |
|     RwBBox              boundingBox;
 | |
| 
 | |
|     /* Surface properties */
 | |
|     RwSurfaceProperties surfaceProps;
 | |
| 
 | |
|     /* The callbacks functions */
 | |
|     RpWorldSectorCallBackRender renderCallBack;
 | |
| 
 | |
|     RxPipeline         *pipeline;
 | |
| };
 | |
| #endif /* (!defined(DOXYGEN)) */
 | |
| 
 | |
| /****************************************************************************
 | |
|  Global Variables
 | |
|  */
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern              "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| extern RwPluginRegistry worldTKList;
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| /****************************************************************************
 | |
|  Function prototypes
 | |
|  */
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern              "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| extern RwBool       _rpWorldFindBBox(RpWorld * world,
 | |
|                                     RwBBox * boundingBox);
 | |
| 
 | |
| /* Generate sector bounding boxes from BSP planes (not tight boxes) */
 | |
| extern RpWorld      *_rpWorldSetupSectorBoundingBoxes(RpWorld *world);
 | |
| 
 | |
| 
 | |
| /* These stealth-API */
 | |
| extern RwBool       _rpWorldForAllGlobalLights(RpLightCallBack callBack,
 | |
|                                               void *pData);
 | |
| extern RpWorldSector *_rpWorldSectorForAllLocalLights(RpWorldSector *
 | |
|                                                      sector,
 | |
|                                                      RpLightCallBack
 | |
|                                                      callBack,
 | |
|                                                      void *pData);
 | |
| 
 | |
| extern RpWorldSector *_rpSectorDefaultRenderCallBack(RpWorldSector *
 | |
|                                                     sector);
 | |
| 
 | |
| /* Accessing worlds geometry */
 | |
| extern RpWorld     *RpWorldLock(RpWorld * world);
 | |
| extern RpWorld     *RpWorldUnlock(RpWorld * world);
 | |
| 
 | |
| /* Managing a list of the worlds */
 | |
| extern void         _rpWorldRegisterWorld(RpWorld * world,
 | |
|                                          RwUInt32 memorySize);
 | |
| extern void         _rpWorldUnregisterWorld(RpWorld * world);
 | |
| 
 | |
| /* Hook into world management */
 | |
| extern RwBool       RpWorldPluginAttach(void);
 | |
| 
 | |
| /* Enumerating objects in the world */
 | |
| extern RpWorld     *RpWorldForAllClumps(RpWorld * world,
 | |
|                                         RpClumpCallBack fpCallBack,
 | |
|                                         void *pData);
 | |
| extern RpWorld     *RpWorldForAllMaterials(RpWorld * world,
 | |
|                                            RpMaterialCallBack fpCallBack,
 | |
|                                            void *pData);
 | |
| extern RpWorld     *RpWorldForAllLights(RpWorld * world,
 | |
|                                         RpLightCallBack fpCallBack,
 | |
|                                         void *pData);
 | |
| extern RpWorld     *RpWorldForAllWorldSectors(RpWorld * world,
 | |
|                                               RpWorldSectorCallBack
 | |
|                                               fpCallBack, void *pData);
 | |
| 
 | |
| /* Rendering */
 | |
| extern RpWorld     *RpWorldRender(RpWorld * world);
 | |
| 
 | |
| /* Creation/destruction */
 | |
| extern RwBool       RpWorldDestroy(RpWorld * world);
 | |
| extern RpWorld     *RpWorldCreate(RwBBox * boundingBox);
 | |
| extern RwBool       RpWorldInstance(RpWorld *world);
 | |
| 
 | |
| /* Getting/setting */
 | |
| extern RpWorld     *_rpWorldSetSurfaceProperties(RpWorld * world,
 | |
|                                                 const RwSurfaceProperties
 | |
|                                                 * surface);
 | |
| extern const RwSurfaceProperties *
 | |
|    _rpWorldGetSurfaceProperties(const RpWorld *world);
 | |
| 
 | |
| /* Sector callbacks */
 | |
| extern RpWorld     *RpWorldSetSectorRenderCallBack(RpWorld * world,
 | |
|                                                    RpWorldSectorCallBackRender
 | |
|                                                    fpCallBack);
 | |
| extern RpWorldSectorCallBackRender RpWorldGetSectorRenderCallBack(const
 | |
|                                                                   RpWorld
 | |
|                                                                   *
 | |
|                                                                   world);
 | |
| 
 | |
| /* Getting world from sector */
 | |
| extern RpWorld     *RpWorldSectorGetWorld(const RpWorldSector * sector);
 | |
| 
 | |
| extern RwInt32      RpWorldRegisterPlugin(RwInt32 size, RwUInt32 pluginID,
 | |
|                                           RwPluginObjectConstructor
 | |
|                                           constructCB,
 | |
|                                           RwPluginObjectDestructor
 | |
|                                           destructCB,
 | |
|                                           RwPluginObjectCopy copyCB);
 | |
| extern RwInt32      RpWorldRegisterPluginStream(RwUInt32 pluginID,
 | |
|                                                 RwPluginDataChunkReadCallBack
 | |
|                                                 readCB,
 | |
|                                                 RwPluginDataChunkWriteCallBack
 | |
|                                                 writeCB,
 | |
|                                                 RwPluginDataChunkGetSizeCallBack
 | |
|                                                 getSizeCB);
 | |
| extern RwInt32      RpWorldSetStreamAlwaysCallBack(
 | |
|                         RwUInt32 pluginID,
 | |
|                         RwPluginDataChunkAlwaysCallBack alwaysCB);
 | |
| extern RwInt32      RpWorldSetStreamRightsCallBack(RwUInt32 pluginID,
 | |
|                                      RwPluginDataChunkRightsCallBack rightsCB);
 | |
| extern RwInt32      RpWorldGetPluginOffset(RwUInt32 pluginID);
 | |
| extern RwBool       RpWorldValidatePlugins(RpWorld * world);
 | |
| 
 | |
| 
 | |
| #if (defined(RWDEBUG) || defined(RWSUPPRESSINLINE))
 | |
| 
 | |
| /* Getting/setting */
 | |
| extern const RwBBox *RpWorldGetBBox(const RpWorld *world);
 | |
| extern const RwV3d *RpWorldGetOrigin(const RpWorld *world);
 | |
| 
 | |
| /* Accessing a worlds materials */
 | |
| extern RwInt32 RpWorldGetNumMaterials(const RpWorld *world);
 | |
| extern RpMaterial *RpWorldGetMaterial(const RpWorld *world, RwInt32 matNum);
 | |
| 
 | |
| /* Clumps */
 | |
| extern RwInt32 RpWorldGetNumClumps(RpWorld *world);
 | |
| 
 | |
| /* Render order */
 | |
| extern RpWorld *RpWorldSetRenderOrder(RpWorld *world,
 | |
|                                       RpWorldRenderOrder renderOrder);
 | |
| extern RpWorldRenderOrder RpWorldGetRenderOrder(const RpWorld *world);
 | |
| 
 | |
| /* Flags */
 | |
| extern RpWorld *RpWorldSetFlags(RpWorld *world, RwUInt32 flags);
 | |
| extern RwUInt32 RpWorldGetFlags(const RpWorld *world);
 | |
| 
 | |
| #endif /* (defined(RWDEBUG) || defined(RWSUPPRESSINLINE)) */
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| #define RpWorldSetSurfaceProperties(_world, _surface) \
 | |
|     _rpWorldSetSurfaceProperties(_world, _surface)
 | |
| 
 | |
| #define RpWorldGetSurfaceProperties(_world) \
 | |
|     _rpWorldGetSurfaceProperties(_world)
 | |
| 
 | |
| #define rpWorldFindBBox(_world, _boundingBox) \
 | |
|     _rpWorldFindBBox(_world, _boundingBox)
 | |
| 
 | |
| #define rpWorldForAllGlobalLights(_callBack, _pData) \
 | |
|     _rpWorldForAllGlobalLights(_callBack, _pData)
 | |
| 
 | |
| #define rpWorldSectorForAllLocalLights(_sector, _callBack, _pData) \
 | |
|     _rpWorldSectorForAllLocalLights(_sector, _callBack, _pData)
 | |
| 
 | |
| #define _rpWorldLock(_world) \
 | |
|     RpWorldLock(_world)
 | |
| 
 | |
| #define _rpWorldUnlock(_world) \
 | |
|     RpWorldUnlock(_world)
 | |
| 
 | |
| #define rpWorldLock(_world) \
 | |
|     RpWorldLock(_world)
 | |
| 
 | |
| #define rpWorldUnlock(_world) \
 | |
|     RpWorldUnlock(_world)
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/world/pipe/p2/d3d8/D3D8pipe.h ---*/
 | |
| 
 | |
| typedef struct RxD3D8ResEntryHeader RxD3D8ResEntryHeader;
 | |
| /**
 | |
|  * \ingroup rpworldd3d8
 | |
|  * \struct RxD3D8ResEntryHeader
 | |
|  * This structure contains D3D8 resource specific components.
 | |
|  */
 | |
| struct RxD3D8ResEntryHeader
 | |
| {
 | |
|     RwUInt16    serialNumber;   /**< The mesh headers serial number */
 | |
|     RwUInt16    numMeshes;      /**< The number of meshes */
 | |
| };
 | |
| 
 | |
| /* This is what I keep in memory as part of the instance data setup */
 | |
| typedef struct RxD3D8InstanceData RxD3D8InstanceData;
 | |
| /**
 | |
|  * \ingroup rpworldd3d8
 | |
|  * \struct RxD3D8InstanceData
 | |
|  * This structure contains D3D8 resource specific components.
 | |
|  */
 | |
| struct RxD3D8InstanceData
 | |
| {
 | |
|     RwUInt32        minVert;        /**< The vertex index where the
 | |
|                                          meshes vertices begin. Needed for
 | |
|                                          reinstancing, not for rendering */
 | |
| 
 | |
|     RwInt32         stride;         /**< Stride of vertex */
 | |
| 
 | |
|     RwInt32         numVertices;    /**< Number of vertices in the vertex buffer */
 | |
|     RwInt32         numIndices;     /**< Number of indices to render the primitive */
 | |
| 
 | |
|     RpMaterial      *material;      /**< The material for this instanced data */
 | |
| 
 | |
|     RwUInt32        vertexShader;   /**< Vertex shader or FVF flags */
 | |
| 
 | |
|     RwUInt32        primType;       /**< Primitive type */
 | |
|     
 | |
|     void            *indexBuffer;   /**< Index buffer */
 | |
|     void            *vertexBuffer;  /**< Vertex buffer */
 | |
| 
 | |
|     RwUInt32        baseIndex;      /**< Needed if we share the vertex buffer */
 | |
| 
 | |
|     RwUInt8         vertexAlpha;    /**< The prelight data contains alpha */
 | |
|     RwUInt8         managed;        /**< Created by the Vertex Buffer Manager */
 | |
|     RwUInt8         remapped;       /**< Vertices where remapped to save VB space */
 | |
| };
 | |
| 
 | |
| /**
 | |
|  * \ingroup rpworldd3d8
 | |
|  * \ref RxD3D8AllInOneInstanceCallBack callback function.
 | |
|  * 
 | |
|  * \param object Pointer to the object.
 | |
|  * \param instancedData Pointer to \ref RxD3D8InstanceData.
 | |
|  * \param reinstance Boolean whether to reinstance.
 | |
|  *
 | |
|  * \see RxD3D8AllInOneSetInstanceCallBack
 | |
|  * \see RxD3D8AllInOneGetInstanceCallBack
 | |
|  * \see RxNodeDefinitionGetD3D8AtomicAllInOne
 | |
|  * \see RxNodeDefinitionGetD3D8WorldSectorAllInOne
 | |
|  */
 | |
| typedef RwBool (*RxD3D8AllInOneInstanceCallBack)(void *object,
 | |
|                                                  RxD3D8InstanceData *instancedData,
 | |
|                                                  RwBool reinstance);
 | |
| 
 | |
| /**
 | |
|  * \ingroup rpworldd3d8
 | |
|  * \ref RxD3D8AllInOneReinstanceCallBack callback function.
 | |
|  * 
 | |
|  * \param object Pointer to the object.
 | |
|  * \param meshHeader Const pointer to \ref RpMeshHeader.
 | |
|  * \param resEntry Pointer to \ref RxD3D8ResEntryHeader.
 | |
|  * \param instanceCallback Pointer to \ref RxD3D8AllInOneInstanceCallBack.
 | |
|  *
 | |
|  * \see RxD3D8AllInOneSetReinstanceCallBack
 | |
|  * \see RxD3D8AllInOneGetReinstanceCallBack
 | |
|  * \see RxNodeDefinitionGetD3D8AtomicAllInOne
 | |
|  * \see RxNodeDefinitionGetD3D8WorldSectorAllInOne
 | |
|  */
 | |
| typedef RwBool (*RxD3D8AllInOneReinstanceCallBack)(void *object,
 | |
|                                                    RwResEntry *resEntry,
 | |
|                                                    const RpMeshHeader *meshHeader,
 | |
|                                                    RxD3D8AllInOneInstanceCallBack instanceCallback);
 | |
| 
 | |
| /**
 | |
|  * \ingroup rpworldd3d8
 | |
|  * \ref RxD3D8AllInOneLightingCallBack callback function.
 | |
|  * 
 | |
|  * \param object Void pointer to the object.
 | |
|  *
 | |
|  * \see RxD3D8AllInOneSetLightingCallBack
 | |
|  * \see RxD3D8AllInOneGetLightingCallBack
 | |
|  * \see RxNodeDefinitionGetD3D8AtomicAllInOne
 | |
|  * \see RxNodeDefinitionGetD3D8WorldSectorAllInOne
 | |
|  */
 | |
| typedef void (*RxD3D8AllInOneLightingCallBack)(void *object);
 | |
| 
 | |
| /**
 | |
|  * \ingroup rpworldd3d8
 | |
|  * \ref RxD3D8AllInOneRenderCallBack callback function.
 | |
|  * 
 | |
|  * \param repEntry Pointer to a resource entry.
 | |
|  * \param object Pointer to a object that the resource entry belongs to.
 | |
|  * \param type rpATOMIC or rwSECTORATOMIC.
 | |
|  * \param flags \ref RpGeometryFlag's or \ref RpWorldFlag's.
 | |
|  *
 | |
|  * \see RxD3D8AllInOneSetRenderCallBack
 | |
|  * \see RxD3D8AllInOneGetRenderCallBack
 | |
|  * \see RxNodeDefinitionGetD3D8AtomicAllInOne
 | |
|  * \see RxNodeDefinitionGetD3D8WorldSectorAllInOne
 | |
|  */
 | |
| typedef void (*RxD3D8AllInOneRenderCallBack)(RwResEntry *repEntry,
 | |
|                                              void *object,
 | |
|                                              RwUInt8 type,
 | |
|                                              RwUInt32 flags);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif /* __cplusplus */
 | |
| extern void
 | |
| RxD3D8AllInOneSetInstanceCallBack(RxPipelineNode *node,
 | |
|                                   RxD3D8AllInOneInstanceCallBack callback);
 | |
| 
 | |
| extern RxD3D8AllInOneInstanceCallBack
 | |
| RxD3D8AllInOneGetInstanceCallBack(RxPipelineNode *node);
 | |
| 
 | |
| extern void
 | |
| RxD3D8AllInOneSetReinstanceCallBack(RxPipelineNode *node,
 | |
|                                   RxD3D8AllInOneReinstanceCallBack callback);
 | |
| 
 | |
| extern RxD3D8AllInOneReinstanceCallBack
 | |
| RxD3D8AllInOneGetReinstanceCallBack(RxPipelineNode *node);
 | |
| 
 | |
| extern void
 | |
| RxD3D8AllInOneSetLightingCallBack(RxPipelineNode *node,
 | |
|                                   RxD3D8AllInOneLightingCallBack callback);
 | |
| 
 | |
| extern RxD3D8AllInOneLightingCallBack
 | |
| RxD3D8AllInOneGetLightingCallBack(RxPipelineNode *node);
 | |
| 
 | |
| extern void
 | |
| RxD3D8AllInOneSetRenderCallBack(RxPipelineNode *node,
 | |
|                                 RxD3D8AllInOneRenderCallBack callback);
 | |
| 
 | |
| extern RxD3D8AllInOneRenderCallBack
 | |
| RxD3D8AllInOneGetRenderCallBack(RxPipelineNode *node);
 | |
| 
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| /*--- Automatically derived from: C:/daily/rwsdk/world/pipe/p2/bapipew.h ---*/
 | |
| 
 | |
| #define RpWorldGetGenericSectorPipelineMacro() \
 | |
|     (RXPIPELINEGLOBAL(genericWorldSectorPipeline))
 | |
| 
 | |
| #define RpWorldGetDefaultSectorPipelineMacro() \
 | |
|     (RXPIPELINEGLOBAL(currentWorldSectorPipeline))
 | |
| 
 | |
| #define RpWorldSetSectorPipelineMacro(_world, _pipeline) \
 | |
|     ( ((_world)->pipeline = _pipeline), _world )
 | |
| 
 | |
| #define RpWorldGetSectorPipelineMacro(_world, _pipeline) \
 | |
|     ( (*(_pipeline) = (_world)->pipeline), _world )
 | |
| 
 | |
| #define RpWorldSectorSetPipelineMacro(_sector, _pipeline) \
 | |
|     ( ((_sector)->pipeline = _pipeline), _sector )
 | |
| 
 | |
| #define RpWorldSectorGetPipelineMacro(_sector, _pipeline) \
 | |
|     ( (*(_pipeline) = (_sector)->pipeline), _sector )
 | |
| 
 | |
| #define RpAtomicGetGenericPipelineMacro() \
 | |
|     (RXPIPELINEGLOBAL(genericAtomicPipeline))
 | |
| 
 | |
| #define RpAtomicGetDefaultPipelineMacro() \
 | |
|     (RXPIPELINEGLOBAL(currentAtomicPipeline))
 | |
| 
 | |
| #define RpAtomicSetPipelineMacro(_atomic, _pipeline) \
 | |
|     ( ((_atomic)->pipeline = _pipeline), _atomic )
 | |
| 
 | |
| #define RpAtomicGetPipelineMacro(_atomic, _pipeline) \
 | |
|     ( (*(_pipeline) = (_atomic)->pipeline), _atomic )
 | |
| 
 | |
| #define RpMaterialGetGenericPipelineMacro() \
 | |
|     (RXPIPELINEGLOBAL(genericMaterialPipeline))
 | |
| 
 | |
| #define RpMaterialGetDefaultPipelineMacro() \
 | |
|     (RXPIPELINEGLOBAL(currentMaterialPipeline))
 | |
| 
 | |
| #define RpMaterialSetPipelineMacro(_material, _pipeline) \
 | |
|     ( ((_material)->pipeline = _pipeline), _material )
 | |
| 
 | |
| #define RpMaterialGetPipelineMacro(_material, _pipeline) \
 | |
|     ( (*(_pipeline) = (_material)->pipeline), _material )
 | |
| 
 | |
| 
 | |
| #if !(defined(RWDEBUG) || defined(RWSUPPRESSINLINE))
 | |
| 
 | |
| #define RpWorldGetGenericSectorPipeline RpWorldGetGenericSectorPipelineMacro
 | |
| #define RpWorldGetDefaultSectorPipeline RpWorldGetDefaultSectorPipelineMacro
 | |
| #define RpWorldSetSectorPipeline        RpWorldSetSectorPipelineMacro
 | |
| #define RpWorldGetSectorPipeline        RpWorldGetSectorPipelineMacro
 | |
| #define RpWorldSectorSetPipeline        RpWorldSectorSetPipelineMacro
 | |
| #define RpWorldSectorGetPipeline        RpWorldSectorGetPipelineMacro
 | |
| 
 | |
| #define RpAtomicGetGenericPipeline      RpAtomicGetGenericPipelineMacro
 | |
| #define RpAtomicGetDefaultPipeline      RpAtomicGetDefaultPipelineMacro
 | |
| #define RpAtomicSetPipeline             RpAtomicSetPipelineMacro
 | |
| #define RpAtomicGetPipeline             RpAtomicGetPipelineMacro
 | |
| 
 | |
| #define RpMaterialGetGenericPipeline    RpMaterialGetGenericPipelineMacro
 | |
| #define RpMaterialGetDefaultPipeline    RpMaterialGetDefaultPipelineMacro
 | |
| #define RpMaterialSetPipeline           RpMaterialSetPipelineMacro
 | |
| #define RpMaterialGetPipeline           RpMaterialGetPipelineMacro
 | |
| 
 | |
| #endif /* !(defined(RWDEBUG) || defined(RWSUPPRESSINLINE)) */
 | |
| 
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| extern RxPipeline       *RpWorldSetDefaultSectorPipeline(RxPipeline *pipeline);
 | |
| extern RxPipeline       *RpAtomicSetDefaultPipeline(RxPipeline *pipeline);
 | |
| extern RxPipeline       *RpMaterialSetDefaultPipeline(RxPipeline *pipeline);
 | |
| 
 | |
| #if (defined(RWDEBUG) || defined(RWSUPPRESSINLINE))
 | |
| 
 | |
| extern RxPipeline       *RpWorldGetGenericSectorPipeline(void);
 | |
| extern RxPipeline       *RpWorldGetDefaultSectorPipeline(void);
 | |
| extern RpWorld          *RpWorldSetSectorPipeline(RpWorld       *world,
 | |
|                                                   RxPipeline    *pipeline);
 | |
| extern RpWorld          *RpWorldGetSectorPipeline(RpWorld       *world,
 | |
|                                                   RxPipeline   **pipeline);
 | |
| extern RpWorldSector    *RpWorldSectorSetPipeline(RpWorldSector *sector,
 | |
|                                                   RxPipeline    *pipeline);
 | |
| extern RpWorldSector    *RpWorldSectorGetPipeline(RpWorldSector *sector,
 | |
|                                                   RxPipeline   **pipeline);
 | |
| 
 | |
| extern RxPipeline       *RpAtomicGetGenericPipeline(void);
 | |
| extern RxPipeline       *RpAtomicGetDefaultPipeline(void);
 | |
| extern RpAtomic         *RpAtomicSetPipeline(RpAtomic             *atomic,
 | |
|                                              RxPipeline           *pipeline);
 | |
| extern const RpAtomic   *RpAtomicGetPipeline(const RpAtomic *const atomic, 
 | |
|                                              RxPipeline          **pipeline);
 | |
| 
 | |
| extern RxPipeline       *RpMaterialGetGenericPipeline(void);
 | |
| extern RxPipeline       *RpMaterialGetDefaultPipeline(void);
 | |
| extern RpMaterial       *RpMaterialSetPipeline(RpMaterial  *material,
 | |
|                                                RxPipeline  *pipeline);
 | |
| extern RpMaterial       *RpMaterialGetPipeline(RpMaterial  *material,
 | |
|                                                RxPipeline **pipeline);
 | |
| 
 | |
| #endif /* (defined(RWDEBUG) || defined(RWSUPPRESSINLINE)) */
 | |
| 
 | |
| extern const RpGeometry *RpGeometryIsCorrectlySorted(const RpGeometry * geometry,
 | |
|                                                      RwBool * result);
 | |
| extern RpGeometry       *RpGeometrySortByMaterial(const RpGeometry * geometry,
 | |
|                                                   RpGeometrySortByMaterialCallBack  callback);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif /* __cplusplus */
 | |
| 
 | |
| /* LEGACY-SUPPORT macros */
 | |
| #define RpWorldGetGenericSectorInstancePipeline RpWorldGetGenericSectorPipeline
 | |
| #define RpWorldSetDefaultSectorInstancePipeline RpWorldSetDefaultSectorPipeline
 | |
| #define RpWorldGetDefaultSectorInstancePipeline RpWorldGetDefaultSectorPipeline
 | |
| #define RpWorldSetSectorInstancePipeline        RpWorldSetSectorPipeline
 | |
| #define RpWorldGetSectorInstancePipeline        RpWorldGetSectorPipeline
 | |
| #define RpWorldSectorSetInstancePipeline        RpWorldSectorSetPipeline
 | |
| #define RpWorldSectorGetInstancePipeline        RpWorldSectorGetPipeline
 | |
| 
 | |
| #define RpAtomicGetGenericInstancePipeline      RpAtomicGetGenericPipeline
 | |
| #define RpAtomicGetDefaultInstancePipeline      RpAtomicGetDefaultPipeline
 | |
| #define RpAtomicSetDefaultInstancePipeline      RpAtomicSetDefaultPipeline
 | |
| #define RpAtomicSetInstancePipeline             RpAtomicSetPipeline
 | |
| #define RpAtomicGetInstancePipeline             RpAtomicGetPipeline
 | |
| 
 | |
| #define RpMaterialGetGenericRenderPipeline      RpMaterialGetGenericPipeline
 | |
| #define RpMaterialSetDefaultRenderPipeline      RpMaterialSetDefaultPipeline
 | |
| #define RpMaterialGetDefaultRenderPipeline      RpMaterialGetDefaultPipeline
 | |
| #define RpMaterialSetRenderPipeline             RpMaterialSetPipeline
 | |
| #define RpMaterialGetRenderPipeline             RpMaterialGetPipeline
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: c:/daily/rwsdk/world/baworobj.h ---*/
 | |
| /****************************************************************************
 | |
|  Function prototypes
 | |
|  */
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| /* Adding and removing cameras to/from the world */
 | |
| extern RpWorld *RpWorldRemoveCamera(RpWorld *world, RwCamera *camera);
 | |
| extern RpWorld *RpWorldAddCamera(RpWorld *world, RwCamera *camera);
 | |
| extern RpWorld *RwCameraGetWorld(const RwCamera *camera);
 | |
| 
 | |
| /* Adding and removing atomics to/from the world */
 | |
| extern RpWorld *RpWorldRemoveAtomic(RpWorld *world, RpAtomic *atomic);
 | |
| extern RpWorld *RpWorldAddAtomic(RpWorld *world, RpAtomic *atomic);
 | |
| extern RpWorld *RpAtomicGetWorld(const RpAtomic *atomic);
 | |
| 
 | |
| /* Adding and removing clumps to/from the world */
 | |
| extern RpWorld *RpWorldAddClump(RpWorld *world, RpClump *clump);
 | |
| extern RpWorld *RpWorldRemoveClump(RpWorld *world, RpClump *clump);
 | |
| extern RpWorld *RpClumpGetWorld(const RpClump *clump);
 | |
| 
 | |
| /* Adding and removing lights to/from the world */
 | |
| extern RpWorld *RpWorldAddLight(RpWorld *world, RpLight *light);
 | |
| extern RpWorld *RpWorldRemoveLight(RpWorld *world, RpLight *light);
 | |
| extern RpWorld *RpLightGetWorld(const RpLight *light);
 | |
| 
 | |
| /* Finding whats in the view frustum */
 | |
| extern RwCamera *RwCameraForAllClumpsInFrustum(RwCamera *camera, void *data);
 | |
| extern RwCamera *RwCameraForAllClumpsNotInFrustum(RwCamera *camera,
 | |
|                                                     RwInt32 numClumps, void *data);
 | |
| extern RwCamera *RwCameraForAllSectorsInFrustum(RwCamera *camera,
 | |
|                                                 RpWorldSectorCallBack callBack,
 | |
|                                                 void *pData);
 | |
| 
 | |
| /* Enumeration involving the world sectors */
 | |
| extern RpLight *RpLightForAllWorldSectors(RpLight *light,
 | |
|                                           RpWorldSectorCallBack callback,
 | |
|                                           void *data);
 | |
| extern RpAtomic *RpAtomicForAllWorldSectors(RpAtomic *atomic,
 | |
|                                             RpWorldSectorCallBack callback,
 | |
|                                             void *data);
 | |
| extern RpWorldSector *RpWorldSectorForAllAtomics(RpWorldSector *sector,
 | |
|                                                  RpAtomicCallBack callback,
 | |
|                                                  void *data);
 | |
| extern RpWorldSector *RpWorldSectorForAllCollisionAtomics(RpWorldSector *sector,
 | |
|                                                  RpAtomicCallBack callback,
 | |
|                                                  void *data);
 | |
| extern RpWorldSector *RpWorldSectorForAllLights(RpWorldSector *sector,
 | |
|                                                 RpLightCallBack callback,
 | |
|                                                 void *data);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| 
 | |
| /*--- Automatically derived from: c:/daily/rwsdk/world/babinwor.h ---*/
 | |
| /****************************************************************************
 | |
|  Global types
 | |
|  */
 | |
| 
 | |
| /* Binary Representation
 | |
|  *
 | |
|  */
 | |
| typedef struct RpWorldChunkInfoSector RpWorldSectorChunkInfo;
 | |
| typedef struct RpWorldChunkInfoSector _rpWorldSector;
 | |
| 
 | |
| struct RpWorldChunkInfoSector
 | |
| {
 | |
|     RwInt32 matListWindowBase;
 | |
|     RwInt32 numPolygons;
 | |
|     RwInt32 numVertices;
 | |
|     RwV3d inf;
 | |
|     RwV3d sup;
 | |
|     RwBool collSectorPresent;
 | |
|     RwBool unused;
 | |
| };
 | |
| 
 | |
| typedef struct RpPlaneSectorChunkInfo RpPlaneSectorChunkInfo;
 | |
| typedef struct RpPlaneSectorChunkInfo _rpPlaneSector;
 | |
| 
 | |
| struct RpPlaneSectorChunkInfo
 | |
| {
 | |
|     RwInt32 type;
 | |
|     RwReal value;    
 | |
|     RwBool leftIsWorldSector;
 | |
|     RwBool rightIsWorldSector;
 | |
|     RwReal leftValue;
 | |
|     RwReal rightValue;
 | |
| };
 | |
| 
 | |
| typedef struct RpWorldChunkInfo RpWorldChunkInfo;
 | |
| typedef struct RpWorldChunkInfo _rpWorld;
 | |
| 
 | |
| struct RpWorldChunkInfo
 | |
| {
 | |
|     RwBool rootIsWorldSector;
 | |
| 
 | |
|     RwV3d invWorldOrigin;
 | |
| 
 | |
|     RwSurfaceProperties surfaceProps;
 | |
| 
 | |
|     RwInt32 numPolygons;
 | |
|     RwInt32 numVertices;
 | |
|     RwInt32 numPlaneSectors;
 | |
|     RwInt32 numWorldSectors;
 | |
|     RwInt32 colSectorSize;    
 | |
| 
 | |
|     RwInt32 format;  /* Flags about the world */
 | |
| };
 | |
| 
 | |
| /****************************************************************************
 | |
|  Function prototypes
 | |
|  */
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| extern "C"
 | |
| {
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| /* Binary format */
 | |
| extern RwUInt32 RpWorldStreamGetSize(const RpWorld *world);
 | |
| extern RpWorld *RpWorldStreamRead(RwStream *stream);
 | |
| extern const RpWorld *RpWorldStreamWrite(const RpWorld *world,
 | |
|                                          RwStream *stream);
 | |
| extern RpWorldSectorChunkInfo *
 | |
| _rpWorldSectorChunkInfoRead(RwStream *stream,
 | |
|                             RpWorldSectorChunkInfo *worldSectorChunkInfo,
 | |
|                             RwInt32 *bytesRead);
 | |
| extern RpPlaneSectorChunkInfo *
 | |
| _rpPlaneSectorChunkInfoRead(RwStream *stream,
 | |
|                             RpPlaneSectorChunkInfo *planeSectorChunkInfo,
 | |
|                             RwInt32 *bytesRead);
 | |
| extern RpWorldChunkInfo *
 | |
| _rpWorldChunkInfoRead(RwStream *stream,
 | |
|                       RpWorldChunkInfo *worldChunkInfo,
 | |
|                       RwInt32 *bytesRead);
 | |
| 
 | |
| #ifdef    __cplusplus
 | |
| }
 | |
| #endif                          /* __cplusplus */
 | |
| 
 | |
| #define RpWorldSectorChunkInfoRead(stream, worldSectorChunkInfo, bytesRead) \
 | |
|        _rpWorldSectorChunkInfoRead(stream, worldSectorChunkInfo, bytesRead)
 | |
| 
 | |
| #define RpPlaneSectorChunkInfoRead(stream, planeSectorChunkInfo, bytesRead) \
 | |
|        _rpPlaneSectorChunkInfoRead(stream, planeSectorChunkInfo, bytesRead)
 | |
| 
 | |
| #define RpWorldChunkInfoRead(stream, worldChunkInfo, bytesRead) \
 | |
|        _rpWorldChunkInfoRead(stream, worldChunkInfo, bytesRead)
 | |
| 
 | |
| #endif /* RPWORLD_H */
 |