2016-12-07 18:45:25 +00:00
|
|
|
!!permu UPPERLOWER
|
2016-07-26 11:47:59 +00:00
|
|
|
!!samps diffuse upper lower fullbright
|
|
|
|
|
2012-11-27 03:23:19 +00:00
|
|
|
struct a2v
|
|
|
|
{
|
|
|
|
float4 pos: POSITION;
|
2015-09-14 15:20:09 +00:00
|
|
|
float2 tc: TEXCOORD0;
|
2012-11-27 03:23:19 +00:00
|
|
|
float3 normal: NORMAL;
|
|
|
|
};
|
|
|
|
struct v2f
|
|
|
|
{
|
|
|
|
float4 pos: SV_POSITION;
|
|
|
|
float2 tc: TEXCOORD0;
|
|
|
|
float3 light: TEXCOORD1;
|
|
|
|
};
|
|
|
|
|
|
|
|
#include <ftedefs.h>
|
|
|
|
|
|
|
|
#ifdef VERTEX_SHADER
|
|
|
|
//attribute vec2 v_texcoord;
|
|
|
|
//uniform vec3 e_light_dir;
|
|
|
|
//uniform vec3 e_light_mul;
|
|
|
|
//uniform vec3 e_light_ambient;
|
|
|
|
v2f main (a2v inp)
|
|
|
|
{
|
|
|
|
v2f outp;
|
|
|
|
outp.pos = mul(m_model, inp.pos);
|
|
|
|
outp.pos = mul(m_view, outp.pos);
|
|
|
|
outp.pos = mul(m_projection, outp.pos);
|
|
|
|
outp.light = e_light_ambient + (dot(inp.normal,e_light_dir)*e_light_mul);
|
|
|
|
outp.tc = inp.tc.xy;
|
|
|
|
return outp;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#ifdef FRAGMENT_SHADER
|
2015-05-03 19:57:46 +00:00
|
|
|
Texture2D t_diffuse : register(t0);
|
|
|
|
#ifdef UPPER
|
|
|
|
Texture2D t_upper : register(t1);
|
|
|
|
Texture2D t_lower : register(t2);
|
|
|
|
Texture2D t_fullbright : register(t3);
|
|
|
|
#else
|
|
|
|
Texture2D t_fullbright : register(t1);
|
|
|
|
#endif
|
|
|
|
|
2012-11-27 03:23:19 +00:00
|
|
|
SamplerState SampleType;
|
|
|
|
|
|
|
|
float4 main (v2f inp) : SV_TARGET
|
|
|
|
{
|
|
|
|
float4 col;
|
2015-05-03 19:57:46 +00:00
|
|
|
col = t_diffuse.Sample(SampleType, inp.tc);
|
2014-03-30 08:55:06 +00:00
|
|
|
|
|
|
|
#ifdef MASK
|
|
|
|
#ifndef MASKOP
|
|
|
|
#define MASKOP >= //drawn if (alpha OP ref) is true.
|
|
|
|
#endif
|
|
|
|
//support for alpha masking
|
|
|
|
if (!(col.a MASKOP MASK))
|
|
|
|
discard;
|
|
|
|
#endif
|
|
|
|
|
2012-11-27 03:23:19 +00:00
|
|
|
#ifdef UPPER
|
2015-05-03 19:57:46 +00:00
|
|
|
float4 uc = t_upper.Sample(SampleType, inp.tc);
|
2016-12-07 18:45:25 +00:00
|
|
|
col.rgb += uc.rgb*e_uppercolour.rgb*uc.a;
|
2012-11-27 03:23:19 +00:00
|
|
|
#endif
|
|
|
|
#ifdef LOWER
|
2015-05-03 19:57:46 +00:00
|
|
|
float4 lc = t_lower.Sample(SampleType, inp.tc);
|
2016-12-07 18:45:25 +00:00
|
|
|
col.rgb += lc.rgb*e_lowercolour.rgb*lc.a;
|
2012-11-27 03:23:19 +00:00
|
|
|
#endif
|
|
|
|
col.rgb *= inp.light;
|
2015-05-03 19:57:46 +00:00
|
|
|
//#ifdef FULLBRIGHT
|
2017-08-29 02:29:06 +00:00
|
|
|
float4 fb = t_fullbright.Sample(SampleType, inp.tc)*e_glowmod;
|
|
|
|
// col.rgb = lerp(col.rgb, fb.rgb, fb.a); //matches vanilla quake...
|
|
|
|
col.rgb += fb.rgb * fb.a; //but nothing expects it to.
|
2015-05-03 19:57:46 +00:00
|
|
|
//#endif
|
2017-08-29 02:29:06 +00:00
|
|
|
col *= e_colourmod;
|
|
|
|
// col = fog4(col);
|
2012-11-27 03:23:19 +00:00
|
|
|
return col;
|
|
|
|
}
|
|
|
|
#endif
|