//===== Copyright © 1996-2008, Valve Corporation, All rights reserved. ======// #include "BaseVSShader.h" #include "convar.h" #include "SDK_splinerope_ps20.inc" #include "SDK_splinerope_ps20b.inc" #include "SDK_splinerope_vs20.inc" // memdbgon must be the last include file in a .cpp file!!! #include "tier0/memdbgon.h" static ConVar rope_min_pixel_diameter( "rope_min_pixel_diameter", "2.0", FCVAR_CHEAT ); DEFINE_FALLBACK_SHADER( SDK_Cable, SDK_Cable_DX9 ) BEGIN_VS_SHADER( SDK_Cable_DX9, "Help for SplineRope" ) BEGIN_SHADER_PARAMS SHADER_PARAM( SHADERSRGBREAD360, SHADER_PARAM_TYPE_BOOL, "0", "Simulate srgb read in shader code") SHADER_PARAM( SHADOWDEPTH, SHADER_PARAM_TYPE_INTEGER, "0", "writing to a shadow depth buffer" ) SHADER_PARAM( BUMPMAP, SHADER_PARAM_TYPE_TEXTURE, "cable/cablenormalmap", "normal map" ) END_SHADER_PARAMS SHADER_INIT_PARAMS() { // srgb read 360 InitIntParam( SHADERSRGBREAD360, params, 0 ); InitIntParam( SHADOWDEPTH, params, 0 ); if ( !params[BUMPMAP]->IsDefined() ) { params[BUMPMAP]->SetStringValue( "cable/cablenormalmap" ); } SET_FLAGS2( MATERIAL_VAR2_IS_SPRITECARD ); // What's this for? } SHADER_FALLBACK { return 0; } SHADER_INIT { SET_FLAGS2( MATERIAL_VAR2_LIGHTING_VERTEX_LIT ); LoadTexture( BASETEXTURE ); LoadBumpMap( BUMPMAP ); } SHADER_DRAW { bool bShaderSrgbRead = ( IsX360() && params[SHADERSRGBREAD360]->GetIntValue() ); bool bShadowDepth = ( params[SHADOWDEPTH]->GetIntValue() != 0 ); SHADOW_STATE { // draw back-facing because of yaw spin pShaderShadow->EnableCulling( false ); if ( bShadowDepth ) { // don't write color and alpha since we only interested in depth for shadow maps. pShaderShadow->EnableColorWrites( false ); pShaderShadow->EnableAlphaWrites( false ); // polyoffset for shadow maps. pShaderShadow->EnablePolyOffset( SHADER_POLYOFFSET_SHADOW_BIAS ); } else { // We need to write to dest alpha for depth feathering. pShaderShadow->EnableAlphaWrites( true ); // base texture pShaderShadow->EnableTexture( SHADER_SAMPLER0, true ); pShaderShadow->EnableSRGBRead( SHADER_SAMPLER0, !bShaderSrgbRead ); // normal map pShaderShadow->EnableTexture( SHADER_SAMPLER1, true ); pShaderShadow->EnableSRGBWrite( true ); FogToFogColor(); } static int s_TexCoordSize[]={ 4, // (worldspace xyz) (radius (diameter?) of spline at this point) for first control point 4, // (worldspace xyz) (radius of spline at this point) for second control point 4, // (worldspace xyz) (radius of spline at this point) for third control point 4, // (worldspace xyz) (radius of spline at this point) for fourth control point }; unsigned int flags = VERTEX_POSITION | VERTEX_COLOR; int numTexCoords = 4; pShaderShadow->VertexShaderVertexFormat( flags, numTexCoords, s_TexCoordSize, 0 ); DECLARE_STATIC_VERTEX_SHADER( sdk_splinerope_vs20 ); SET_STATIC_VERTEX_SHADER( sdk_splinerope_vs20 ); if( g_pHardwareConfig->SupportsPixelShaders_2_b() ) { DECLARE_STATIC_PIXEL_SHADER( sdk_splinerope_ps20b ); SET_STATIC_PIXEL_SHADER_COMBO( SHADER_SRGB_READ, bShaderSrgbRead ); SET_STATIC_PIXEL_SHADER_COMBO( SHADOWDEPTH, bShadowDepth ); SET_STATIC_PIXEL_SHADER( sdk_splinerope_ps20b ); } else { DECLARE_STATIC_PIXEL_SHADER( sdk_splinerope_ps20 ); SET_STATIC_PIXEL_SHADER_COMBO( SHADER_SRGB_READ, bShaderSrgbRead ); SET_STATIC_PIXEL_SHADER_COMBO( SHADOWDEPTH, bShadowDepth ); SET_STATIC_PIXEL_SHADER( sdk_splinerope_ps20 ); } } DYNAMIC_STATE { // We need these only when screen-orienting, which we are always in this shader. LoadModelViewMatrixIntoVertexShaderConstant( VERTEX_SHADER_SHADER_SPECIFIC_CONST_0 ); LoadProjectionMatrixIntoVertexShaderConstant( VERTEX_SHADER_SHADER_SPECIFIC_CONST_3 ); // Get viewport and render target dimensions and set shader constant to do a 2D mad ShaderViewport_t viewport; pShaderAPI->GetViewports( &viewport, 1 ); float c7[4]={ 0.0f, 0.0f, 0.0f, 0.0f }; if ( !g_pHardwareConfig->IsAAEnabled() ) { float flMinPixelDiameter = rope_min_pixel_diameter.GetFloat() / ( float )viewport.m_nWidth; c7[0]= c7[1] = c7[2] = c7[3] = flMinPixelDiameter; } pShaderAPI->SetVertexShaderConstant( VERTEX_SHADER_SHADER_SPECIFIC_CONST_7, c7, 1 ); // bind base texture BindTexture( SHADER_SAMPLER0, BASETEXTURE, FRAME ); // normal map BindTexture( SHADER_SAMPLER1, BUMPMAP ); if ( !bShadowDepth ) { pShaderAPI->SetPixelShaderFogParams( 0 ); float vEyePos[4]; pShaderAPI->GetWorldSpaceCameraPosition( vEyePos ); vEyePos[3] = 0.0f; pShaderAPI->SetPixelShaderConstant( 1, vEyePos, 1 ); } DECLARE_DYNAMIC_VERTEX_SHADER( sdk_splinerope_vs20 ); SET_DYNAMIC_VERTEX_SHADER_COMBO( DOWATERFOG, pShaderAPI->GetSceneFogMode() == MATERIAL_FOG_LINEAR_BELOW_FOG_Z ); SET_DYNAMIC_VERTEX_SHADER( sdk_splinerope_vs20 ); if ( g_pHardwareConfig->SupportsPixelShaders_2_b() ) { DECLARE_DYNAMIC_PIXEL_SHADER( sdk_splinerope_ps20b ); SET_DYNAMIC_PIXEL_SHADER_COMBO( WRITE_DEPTH_TO_DESTALPHA, pShaderAPI->ShouldWriteDepthToDestAlpha() ); //SET_DYNAMIC_PIXEL_SHADER_COMBO( PIXELFOGTYPE, pShaderAPI->GetSceneFogMode() == MATERIAL_FOG_LINEAR_BELOW_FOG_Z ); SET_DYNAMIC_PIXEL_SHADER_COMBO( PIXELFOGTYPE, pShaderAPI->GetPixelFogCombo() ); SET_DYNAMIC_PIXEL_SHADER( sdk_splinerope_ps20b ); } else { DECLARE_DYNAMIC_PIXEL_SHADER( sdk_splinerope_ps20 ); SET_DYNAMIC_PIXEL_SHADER_COMBO( WRITE_DEPTH_TO_DESTALPHA, 0 ); //SET_DYNAMIC_PIXEL_SHADER_COMBO( PIXELFOGTYPE, pShaderAPI->GetSceneFogMode() == MATERIAL_FOG_LINEAR_BELOW_FOG_Z ); SET_DYNAMIC_PIXEL_SHADER_COMBO( PIXELFOGTYPE, pShaderAPI->GetPixelFogCombo() ); SET_DYNAMIC_PIXEL_SHADER( sdk_splinerope_ps20 ); } } Draw( ); } END_SHADER