mirror of
https://github.com/nzp-team/fteqw.git
synced 2024-11-14 16:31:38 +00:00
53a7b3d47c
The ragdoll API is potentially usable now, but still really limited. Enabled SQL requests by default using sqlite. Note that you'll need the sqlite dll to use this. MySQL should still be usable, but I didn't try. MySQL requires -DUSE_MYSQL to compile it, and a dll and -mysql argument to enable it. Fixed nacl. NPFTE plugin now invokes an exe to run the game rather than running the game within the browser. externvalue builtin now accepts & prefix to return a pointer instead. Fixed vector autocvars. uri_get, bufstr_add, bufstr_free, now functional. QC debugger can now show asm if line numbers are not available. Added support for QC watchpoints. Use the watchpoint command. gl_specular now give specular even without rtlights, thankfully not as blatently, but its there. android will not crash due to supported audio formats, and gles2 can be selected via a cvar (requires full FTEDroidActivity/program restart). git-svn-id: https://svn.code.sf.net/p/fteqw/code/trunk@4152 fc73d0e0-1445-4013-8a0c-d673dee63da5
52 lines
No EOL
969 B
HLSL
52 lines
No EOL
969 B
HLSL
struct a2v
|
|
{
|
|
float4 pos: POSITION;
|
|
};
|
|
struct v2f
|
|
{
|
|
#ifndef FRAGMENT_SHADER
|
|
float4 pos: POSITION;
|
|
#endif
|
|
float3 vpos: TEXCOORD0;
|
|
};
|
|
|
|
#ifdef VERTEX_SHADER
|
|
float4x4 m_modelviewprojection;
|
|
v2f main (a2v inp)
|
|
{
|
|
v2f outp;
|
|
outp.pos = mul(m_modelviewprojection, inp.pos);
|
|
outp.vpos = inp.pos;
|
|
return outp;
|
|
}
|
|
#endif
|
|
|
|
#ifdef FRAGMENT_SHADER
|
|
float e_time;
|
|
float3 e_eyepos;
|
|
|
|
float l_lightradius;
|
|
float3 l_lightcolour;
|
|
float3 l_lightposition;
|
|
|
|
sampler s_t0; /*diffuse*/
|
|
sampler s_t1; /*normal*/
|
|
sampler s_t2; /*specular*/
|
|
float4 main (v2f inp) : COLOR0
|
|
{
|
|
float2 tccoord;
|
|
|
|
float3 dir = inp.vpos - e_eyepos;
|
|
|
|
dir.z *= 3.0;
|
|
dir.xy /= 0.5*length(dir);
|
|
|
|
tccoord = (dir.xy + e_time*0.03125);
|
|
float4 solid = tex2D(s_t0, tccoord);
|
|
|
|
tccoord = (dir.xy + e_time*0.0625);
|
|
float4 clouds = tex2D(s_t1, tccoord);
|
|
|
|
return float4((solid.rgb*(1.0-clouds.a)) + (clouds.a*clouds.rgb), 1);
|
|
}
|
|
#endif |