//========= Copyright Valve Corporation, All rights reserved. ============// #include "common_vs_fxc.h" float Sine( float min, float max, float t ) { return ( sin( t ) * 0.5f + 0.5f ) * ( max - min ) + min; } float3 QuadraticBezier( float3 A, float3 B, float3 C, float t ) { return lerp( lerp( A, B, t ), lerp( B, C, t ), t ); } float3 CubicBezier( float3 A, float3 B, float3 C, float3 D, float t ) { return QuadraticBezier( lerp( A, B, t ), lerp( B, C, t ), lerp( C, D, t ), t ); } void WorldSpaceVertexProcess( in float time, in float3 modelOrigin, inout float3 worldPos, inout float3 worldNormal, inout float3 worldTangentS, inout float3 worldTangentT ) { float myTime = time; myTime = saturate( 1.0f - myTime ); myTime *= myTime; myTime *= myTime; myTime *= myTime; // worldPos.z += 72.0f * myTime; // end float3 A = float3( 0.0f, 0.0f, 1.0f ); float3 B = float3( 1.0f, 1.0f, 1.0f ); float3 C = float3( 0.0f, 0.0f, 1.0f ); float3 D = float3( 0.0f, 0.0f, 1.0f ); // start // float3 modelOrigin = float3( 70.0f, -14.0f, 0.0f ); float t = worldPos.z * ( 1.0f / ( 72.0f ) ); // about 72 inches tall t = saturate( t ); float3 worldPosDelta = ( worldPos - modelOrigin ) * CubicBezier( A, B, C, D, t ); worldPosDelta.z += Sine( 0.0f, 10.0, worldPos.z ); worldPos = lerp( worldPos, worldPosDelta + modelOrigin, myTime ); }