Divergent/mods/Screen Space Shaders/gamedata/shaders/r3/deffer_tree_branch_flat.vs

88 lines
2.9 KiB
Plaintext
Raw Permalink Normal View History

2024-03-17 20:18:03 -04:00
#include "common.h"
float4 benders_pos[32];
float4 benders_setup;
uniform float3x4 m_xform;
uniform float3x4 m_xform_v;
uniform float4 consts; // {1/quant,1/quant,???,???}
uniform float4 c_scale,c_bias,wind,wave;
uniform float2 c_sun; // x=*, y=+
v2p_flat main (v_tree I)
{
I.Nh = unpack_D3DCOLOR(I.Nh);
I.T = unpack_D3DCOLOR(I.T);
I.B = unpack_D3DCOLOR(I.B);
v2p_flat o;
// Transform to world coords
float3 pos = mul (m_xform, I.P);
//
float base = m_xform._24; // take base height from matrix
float dp = calc_cyclic (wave.w+dot(pos,(float3)wave));
float H = pos.y - base; // height of vertex (scaled, rotated, etc.)
float frac = I.tc.z*consts.x; // fractional (or rigidity)
float inten = H * dp; // intensity
float2 result = calc_xz_wave (wind.xz*inten, frac);
#ifdef USE_TREEWAVE
result = 0;
#endif
float4 f_pos = float4(pos.x+result.x, pos.y, pos.z+result.y, 1);
float2 tc = (I.tc * consts).xy;
// INTERACTIVE GRASS ( Bushes ) - SSS Update 17.1
// https://www.moddb.com/mods/stalker-anomaly/addons/screen-space-shaders/
#if SSFX_INT_GRASS > 0
for (int b = 0; b < SSFX_INT_GRASS + 1; b++)
{
// Direction, Radius & Bending Strength, Distance and Height Limit
float3 dir = benders_pos[b + 16].xyz;
float3 rstr = float3(benders_pos[b].w, benders_pos[b + 16].ww); // .x = Radius | .yz = Str
bool non_dynamic = rstr.x <= 0 ? true : false;
float dist = distance(f_pos.xz, benders_pos[b].xz);
float height_limit = 1.0f - saturate(abs(pos.y - benders_pos[b].y) / ( non_dynamic ? 2.0f : rstr.x ));
height_limit *= (1.0f - tc.y); // Bushes uses UV Coor instead of H to limit displacement
// Adjustments ( Fix Radius or Dynamic Radius )
rstr.x = non_dynamic ? benders_setup.x : rstr.x;
rstr.yz *= non_dynamic ? benders_setup.yz : 1.0f;
// Strength through distance and bending direction.
float bend = 1.0f - saturate(dist / (rstr.x + 0.001f));
float3 bend_dir = normalize(f_pos.xyz - benders_pos[b].xyz) * bend;
float3 dir_limit = dir.y >= -1 ? saturate(dot(bend_dir.xyz, dir.xyz) * 5.0f) : 1.0f; // Limit if nedeed
// Apply direction limit
bend_dir.xz *= dir_limit.xz;
// Apply vertex displacement
f_pos.xz += bend_dir.xz * 2.25f * rstr.yy * height_limit; // Horizontal
f_pos.y -= bend * 0.67f * rstr.z * height_limit * dir_limit.y; // Vertical
}
#endif
// Final xform(s)
// Final xform
float3 Pe = mul (m_V, f_pos );
float hemi = I.Nh.w*c_scale.w + c_bias.w;
//float hemi = I.Nh.w;
o.hpos = mul (m_VP, f_pos );
o.N = normalize(mul((float3x3)m_xform_v, I.P.xyz));
o.tcdh = float4 (tc.xyyy );
o.position = float4 (Pe, hemi );
#if defined(USE_R2_STATIC_SUN) && !defined(USE_LM_HEMI)
float suno = I.Nh.w * c_sun.x + c_sun.y ;
o.tcdh.w = suno; // (,,,dir-occlusion)
#endif
#ifdef USE_TDETAIL
o.tcdbump = o.tcdh*dt_params; // dt tc
#endif
return o;
}
FXVS;