mirror of
https://github.com/alliedmodders/hl2sdk.git
synced 2025-01-10 10:59:39 +08:00
128 lines
4.3 KiB
C++
128 lines
4.3 KiB
C++
|
//===== Copyright <20> 1996-2005, Valve Corporation, All rights reserved. ======//
|
|||
|
//
|
|||
|
// Purpose: Responsible for drawing the scene
|
|||
|
//
|
|||
|
//===========================================================================//
|
|||
|
|
|||
|
#include "cbase.h"
|
|||
|
#include "materialsystem/IMaterialSystem.h"
|
|||
|
#include "materialsystem/IMaterialVar.h"
|
|||
|
#include "materialsystem/imaterialsystemhardwareconfig.h"
|
|||
|
#include "rendertexture.h"
|
|||
|
#include "view_scene.h"
|
|||
|
#include "viewrender.h"
|
|||
|
|
|||
|
// memdbgon must be the last include file in a .cpp file!!!
|
|||
|
#include "tier0/memdbgon.h"
|
|||
|
|
|||
|
//-----------------------------------------------------------------------------
|
|||
|
// Convars related to controlling rendering
|
|||
|
//-----------------------------------------------------------------------------
|
|||
|
ConVar r_updaterefracttexture( "r_updaterefracttexture", "1", FCVAR_CHEAT );
|
|||
|
ConVar r_depthoverlay( "r_depthoverlay", "0", FCVAR_CHEAT, "Replaces opaque objects with their grayscaled depth values. r_showz_power scales the output." );
|
|||
|
|
|||
|
|
|||
|
int g_viewscene_refractUpdateFrame = 0;
|
|||
|
bool g_bAllowMultipleRefractUpdatesPerScenePerFrame = false;
|
|||
|
|
|||
|
#if defined( _X360 )
|
|||
|
class CAllowMultipleRefractsLogic : public CAutoGameSystem
|
|||
|
{
|
|||
|
public:
|
|||
|
void LevelInitPreEntity()
|
|||
|
{
|
|||
|
// EP1 core room needs many refract updates per frame to avoid looking broken (ep1_citadel_03)
|
|||
|
// Same with Kleiner's lab (d1_trainstation_05)
|
|||
|
g_bAllowMultipleRefractUpdatesPerScenePerFrame = FStrEq( MapName(), "ep1_citadel_03" ) || FStrEq( MapName(), "d1_trainstation_05" );
|
|||
|
}
|
|||
|
};
|
|||
|
static CAllowMultipleRefractsLogic s_AllowMultipleRefractsLogic;
|
|||
|
#endif
|
|||
|
|
|||
|
void ViewTransform( const Vector &worldSpace, Vector &viewSpace )
|
|||
|
{
|
|||
|
const VMatrix &viewMatrix = engine->WorldToViewMatrix();
|
|||
|
Vector3DMultiplyPosition( viewMatrix, worldSpace, viewSpace );
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
//-----------------------------------------------------------------------------
|
|||
|
// Purpose: UNDONE: Clean this up some, handle off-screen vertices
|
|||
|
// Input : *point -
|
|||
|
// *screen -
|
|||
|
// Output : int
|
|||
|
//-----------------------------------------------------------------------------
|
|||
|
int ScreenTransform( const Vector& point, Vector& screen )
|
|||
|
{
|
|||
|
// UNDONE: Clean this up some, handle off-screen vertices
|
|||
|
float w;
|
|||
|
const VMatrix &worldToScreen = engine->WorldToScreenMatrix();
|
|||
|
|
|||
|
screen.x = worldToScreen[0][0] * point[0] + worldToScreen[0][1] * point[1] + worldToScreen[0][2] * point[2] + worldToScreen[0][3];
|
|||
|
screen.y = worldToScreen[1][0] * point[0] + worldToScreen[1][1] * point[1] + worldToScreen[1][2] * point[2] + worldToScreen[1][3];
|
|||
|
// z = worldToScreen[2][0] * point[0] + worldToScreen[2][1] * point[1] + worldToScreen[2][2] * point[2] + worldToScreen[2][3];
|
|||
|
w = worldToScreen[3][0] * point[0] + worldToScreen[3][1] * point[1] + worldToScreen[3][2] * point[2] + worldToScreen[3][3];
|
|||
|
|
|||
|
// Just so we have something valid here
|
|||
|
screen.z = 0.0f;
|
|||
|
|
|||
|
bool behind;
|
|||
|
if( w < 0.001f )
|
|||
|
{
|
|||
|
behind = true;
|
|||
|
screen.x *= 100000;
|
|||
|
screen.y *= 100000;
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
behind = false;
|
|||
|
float invw = 1.0f / w;
|
|||
|
screen.x *= invw;
|
|||
|
screen.y *= invw;
|
|||
|
}
|
|||
|
|
|||
|
return behind;
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
void UpdateFullScreenDepthTexture( void )
|
|||
|
{
|
|||
|
if ( g_pMaterialSystemHardwareConfig->GetDXSupportLevel() <= 90 )
|
|||
|
return;
|
|||
|
|
|||
|
ITexture *pDepthTex = GetFullFrameDepthTexture();
|
|||
|
CMatRenderContextPtr pRenderContext( materials );
|
|||
|
|
|||
|
Rect_t viewportRect;
|
|||
|
pRenderContext->GetViewport( viewportRect.x, viewportRect.y, viewportRect.width, viewportRect.height );
|
|||
|
|
|||
|
if ( IsX360() )
|
|||
|
{
|
|||
|
pRenderContext->CopyRenderTargetToTextureEx( pDepthTex, -1, &viewportRect, &viewportRect );
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
pRenderContext->CopyRenderTargetToTextureEx( pDepthTex, 0, NULL, NULL );
|
|||
|
}
|
|||
|
|
|||
|
pRenderContext->SetFullScreenDepthTextureValidityFlag( true );
|
|||
|
|
|||
|
if ( r_depthoverlay.GetBool() )
|
|||
|
{
|
|||
|
IMaterial *pMaterial = materials->FindMaterial( "debug/showz", TEXTURE_GROUP_OTHER, true );
|
|||
|
IMaterialVar *BaseTextureVar = pMaterial->FindVar( "$basetexture", NULL, false );
|
|||
|
IMaterialVar *pDepthInAlpha = NULL;
|
|||
|
if( IsPC() )
|
|||
|
{
|
|||
|
pDepthInAlpha = pMaterial->FindVar( "$ALPHADEPTH", NULL, false );
|
|||
|
pDepthInAlpha->SetIntValue( 1 );
|
|||
|
}
|
|||
|
|
|||
|
BaseTextureVar->SetTextureValue( pDepthTex );
|
|||
|
|
|||
|
pRenderContext->OverrideDepthEnable( true, false ); //don't write to depth, or else we'll never see translucents
|
|||
|
pRenderContext->DrawScreenSpaceQuad( pMaterial );
|
|||
|
pRenderContext->OverrideDepthEnable( false, true );
|
|||
|
}
|
|||
|
}
|