//========= Copyright © 1996-2005, Valve Corporation, All rights reserved. ============// // // Purpose: // // $Workfile: $ // $Date: $ // $NoKeywords: $ //=============================================================================// #ifndef IDISPINFO_H #define IDISPINFO_H #ifdef _WIN32 #pragma once #endif //============================================================================= #include #include "bspfile.h" #include "mathlib/vmatrix.h" #include "dispnode.h" #include "builddisp.h" #include "utlvector.h" #include "engine/ishadowmgr.h" #include "getintersectingsurfaces_struct.h" #include "surfacehandle.h" struct model_t; struct Ray_t; struct RayDispOutput_t; struct decal_t; class CMeshBuilder; //----------------------------------------------------------------------------- // Handle to decals + shadows on displacements //----------------------------------------------------------------------------- typedef unsigned short DispDecalHandle_t; enum { DISP_DECAL_HANDLE_INVALID = (DispDecalHandle_t)~0 }; typedef unsigned short DispShadowHandle_t; enum { DISP_SHADOW_HANDLE_INVALID = (DispShadowHandle_t)~0 }; //----------------------------------------------------------------------------- // Displacement interface to the engine (and WorldCraft?) //----------------------------------------------------------------------------- abstract_class IDispInfo { public: virtual ~IDispInfo() {} // Builds a list of displacement triangles intersecting the sphere. virtual void GetIntersectingSurfaces( GetIntersectingSurfaces_Struct *pStruct ) = 0; virtual void RenderWireframeInLightmapPage( int pageId ) = 0; virtual void GetBoundingBox( Vector &bbMin, Vector &bbMax ) = 0; // Get and set the parent surfaces. virtual void SetParent( SurfaceHandle_t surfID ) = 0; virtual SurfaceHandle_t GetParent() = 0; // Add dynamic lights to the lightmap for this surface. virtual void AddDynamicLights( struct dlight_t *pLights, unsigned int lightMask ) = 0; // Compute the mask for the lights hitting this surface. virtual unsigned int ComputeDynamicLightMask( struct dlight_t *pLights ) = 0; // Add and remove decals. // flSize is like the radius of the decal so the decal isn't put on any disp faces it's too far away from. virtual DispDecalHandle_t NotifyAddDecal( decal_t *pDecal, float flSize ) = 0; virtual void NotifyRemoveDecal( DispDecalHandle_t h ) = 0; virtual DispShadowHandle_t AddShadowDecal( ShadowHandle_t shadowHandle ) = 0; virtual void RemoveShadowDecal( DispShadowHandle_t handle ) = 0; // Compute shadow fragments for a particular shadow, return the vertex + index count of all fragments virtual bool ComputeShadowFragments( DispShadowHandle_t h, int& vertexCount, int& indexCount ) = 0; // Tag the surface and check if it's tagged. You can untag all the surfaces // with DispInfo_ClearAllTags. Note: it just uses a frame counter to track the // tag state so it's really really fast to call ClearAllTags (just increments // a variable 99.999% of the time). virtual bool GetTag() = 0; virtual void SetTag() = 0; // Cast a ray against this surface virtual bool TestRay( Ray_t const& ray, float start, float end, float& dist, Vector2D* lightmapUV, Vector2D* textureUV ) = 0; // Computes the texture + lightmap coordinate given a displacement uv virtual void ComputeLightmapAndTextureCoordinate( RayDispOutput_t const& uv, Vector2D* luv, Vector2D* tuv ) = 0; }; // ----------------------------------------------------------------------------- // // Adds shadow rendering data to a particular mesh builder // The function will return the new base index // ----------------------------------------------------------------------------- // int DispInfo_AddShadowsToMeshBuilder( CMeshBuilder& meshBuilder, DispShadowHandle_t h, int baseIndex ); typedef void* HDISPINFOARRAY; // Use these to manage a list of IDispInfos. HDISPINFOARRAY DispInfo_CreateArray( int nElements ); void DispInfo_DeleteArray( HDISPINFOARRAY hArray ); IDispInfo* DispInfo_IndexArray( HDISPINFOARRAY hArray, int iElement ); int DispInfo_ComputeIndex( HDISPINFOARRAY hArray, IDispInfo* pInfo ); // Clear the tags for all displacements in the array. void DispInfo_ClearAllTags( HDISPINFOARRAY hArray ); // Call this to render a list of displacements. // If bOrtho is true, then no backface removal is done on dispinfos. void DispInfo_RenderListWorld( class IMatRenderContext *pRenderContext, int nSortGroup, SurfaceHandle_t *pList, int listCount, bool bOrtho, unsigned long flags, int DepthMode ); void DispInfo_RenderListDecalsAndOverlays( class IMatRenderContext *pRenderContext, int nSortGroup, SurfaceHandle_t *pList, int listCount, bool bOrtho, unsigned long flags ); void DispInfo_RenderListDebug( IMatRenderContext *pRenderContext, SurfaceHandle_t *pList, int listCount ); // This should be called from Map_LoadDisplacements (while the map file is open). // It loads the displacement data from the file and prepares the displacements for rendering. // // bRestoring is set to true when just restoring the data from the mapfile // (ie: displacements already are initialized but need new static buffers). bool DispInfo_LoadDisplacements( model_t *pWorld, bool bRestoring ); // Deletes all the static vertex buffers. void DispInfo_ReleaseMaterialSystemObjects( model_t *pWorld ); #endif // IDISPINFO_H