update crt-guest-dr-venom shaders and presets

This commit is contained in:
hunterk 2019-12-18 16:00:23 -06:00
parent ef7bbb1b82
commit 492951eb55
5 changed files with 76 additions and 32 deletions

View file

@ -60,10 +60,11 @@ filter_linear8 = false
scale_type8 = source
scale8 = 1.0
float_framebuffer8 = true
alias8 = GlowPass
shader9 = shaders/guest/linearize_scanlines.slang
filter_linear9 = true
scale_type9 = source
scale_type9 - source
scale9 = 1.0
float_framebuffer9 = true
@ -71,4 +72,4 @@ shader10 = shaders/guest/crt-guest-dr-venom.slang
filter_linear10 = true
scale_type10 = viewport
scale_x10 = 1.0
scale_y10 = 1.0
scale_y10 = 1.0

View file

@ -27,7 +27,7 @@ layout(push_constant) uniform Push
{
float TATE, IOS, OS, BLOOM, brightboost, gsl, scanline1, scanline2, beam_min, beam_max, beam_size,
h_sharp, s_sharp, h_smart, csize, bsize, warpX, warpY, glow, shadowMask, masksize, vertmask,
slotmask, slotwidth, double_slot, mcut, maskDark, maskLight, CGWG, GTW, gamma_out;
slotmask, slotwidth, double_slot, mcut, maskDark, maskLight, CGWG, GTW, gamma_out, spike;
} params;
#pragma parameter TATE "TATE Mode" 0.0 0.0 1.0 1.0
@ -92,6 +92,8 @@ layout(push_constant) uniform Push
#define GTW params.GTW // Gamma tweak
#pragma parameter gamma_out "Gamma out" 2.4 1.0 3.5 0.05
#define gamma_out params.gamma_out // output gamma
#pragma parameter spike "Scanline Spike Removal (0.0 - for speedup)" 1.0 0.0 2.0 0.2
#define spike params.spike
#define COMPAT_TEXTURE(c,d) texture(c,d)
#define TEX0 vTexCoord
@ -128,10 +130,12 @@ layout(location = 0) out vec4 FragColor;
layout(set = 0, binding = 2) uniform sampler2D Source;
layout(set = 0, binding = 3) uniform sampler2D LinearizePass;
layout(set = 0, binding = 4) uniform sampler2D AvgLumPass;
layout(set = 0, binding = 5) uniform sampler2D GlowPass;
#define Texture Source
#define PassPrev3Texture LinearizePass
#define PassPrev4Texture AvgLumPass
#define PassPrev5Texture AvgLumPass
#define PassPrev4Texture LinearizePass
#define PassPrev2Texture GlowPass
#define eps 1e-10
@ -331,7 +335,7 @@ vec3 gamma_correct(vec3 color, vec3 tmp)
void main()
{
float lum = COMPAT_TEXTURE(PassPrev4Texture, vec2(0.33,0.33)).a;
float lum = COMPAT_TEXTURE(PassPrev5Texture, vec2(0.33,0.33)).a;
// Calculating texel coordinates
@ -387,8 +391,8 @@ void main()
else
{
// reading differences for smoothing
vec3 diffs_top = COMPAT_TEXTURE(PassPrev4Texture, pC4 ).xyz;
vec3 diffs_bot = COMPAT_TEXTURE(PassPrev4Texture, pC4 + offy).xyz;
vec3 diffs_top = COMPAT_TEXTURE(PassPrev5Texture, pC4 ).xyz;
vec3 diffs_bot = COMPAT_TEXTURE(PassPrev5Texture, pC4 + offy).xyz;
if(TATE > 0.5)
{
@ -416,26 +420,59 @@ void main()
float wtt = 1.0/(twl2+twl1+twct+twr1+twr2);
float wtb = 1.0/(bwl2+bwl1+bwct+bwr1+bwr2);
vec3 l2 = COMPAT_TEXTURE(PassPrev3Texture, pC4 -off2).xyz;
vec3 l1 = COMPAT_TEXTURE(PassPrev3Texture, pC4 -offx).xyz;
vec3 ct = COMPAT_TEXTURE(PassPrev3Texture, pC4 ).xyz;
vec3 r1 = COMPAT_TEXTURE(PassPrev3Texture, pC4 +offx).xyz;
vec3 r2 = COMPAT_TEXTURE(PassPrev3Texture, pC4 +off2).xyz;
vec3 l2 = COMPAT_TEXTURE(PassPrev4Texture, pC4 -off2).xyz;
vec3 l1 = COMPAT_TEXTURE(PassPrev4Texture, pC4 -offx).xyz;
vec3 ct = COMPAT_TEXTURE(PassPrev4Texture, pC4 ).xyz;
vec3 r1 = COMPAT_TEXTURE(PassPrev4Texture, pC4 +offx).xyz;
vec3 r2 = COMPAT_TEXTURE(PassPrev4Texture, pC4 +off2).xyz;
vec3 sl2 = COMPAT_TEXTURE(Texture, pC4 -off2).xyz;
vec3 sl1 = COMPAT_TEXTURE(Texture, pC4 -offx).xyz;
vec3 sct = COMPAT_TEXTURE(Texture, pC4 ).xyz;
vec3 sr1 = COMPAT_TEXTURE(Texture, pC4 +offx).xyz;
vec3 sr2 = COMPAT_TEXTURE(Texture, pC4 +off2).xyz;
vec3 color1 = (l2*twl2 + l1*twl1 + ct*twct + r1*twr1 + r2*twr2)*wtt;
if (sharp) color1 = clamp(color1, min(min(l1,r1),ct), max(max(l1,r1),ct));
l2 = COMPAT_TEXTURE(PassPrev3Texture, pC4 -off2 +offy).xyz;
l1 = COMPAT_TEXTURE(PassPrev3Texture, pC4 -offx +offy).xyz;
ct = COMPAT_TEXTURE(PassPrev3Texture, pC4 +offy).xyz;
r1 = COMPAT_TEXTURE(PassPrev3Texture, pC4 +offx +offy).xyz;
r2 = COMPAT_TEXTURE(PassPrev3Texture, pC4 +off2 +offy).xyz;
vec3 gtmp = vec3(gamma_out*0.1);
vec3 scolor1 = color1;
if (spike > 0.0)
{
scolor1 = (sl2*twl2 + sl1*twl1 + sct*twct + sr1*twr1 + sr2*twr2)*wtt;
if (sharp) scolor1 = clamp(scolor1, min(min(sl1,sr1),sct), max(max(sl1,sr1),sct));
scolor1 = pow(scolor1, gtmp);
scolor1 = mix(color1, scolor1, spike);
}
l2 = COMPAT_TEXTURE(PassPrev4Texture, pC4 -off2 +offy).xyz;
l1 = COMPAT_TEXTURE(PassPrev4Texture, pC4 -offx +offy).xyz;
ct = COMPAT_TEXTURE(PassPrev4Texture, pC4 +offy).xyz;
r1 = COMPAT_TEXTURE(PassPrev4Texture, pC4 +offx +offy).xyz;
r2 = COMPAT_TEXTURE(PassPrev4Texture, pC4 +off2 +offy).xyz;
sl2 = COMPAT_TEXTURE(Texture, pC4 -off2 +offy).xyz;
sl1 = COMPAT_TEXTURE(Texture, pC4 -offx +offy).xyz;
sct = COMPAT_TEXTURE(Texture, pC4 +offy).xyz;
sr1 = COMPAT_TEXTURE(Texture, pC4 +offx +offy).xyz;
sr2 = COMPAT_TEXTURE(Texture, pC4 +off2 +offy).xyz;
vec3 color2 = (l2*bwl2 + l1*bwl1 + ct*bwct + r1*bwr1 + r2*bwr2)*wtb;
if (sharp) color2 = clamp(color2, min(min(l1,r1),ct), max(max(l1,r1),ct));
vec3 scolor2 = color2;
if (spike > 0.0)
{
scolor2 = (sl2*bwl2 + sl1*bwl1 + sct*bwct + sr1*bwr1 + sr2*bwr2)*wtb;
if (sharp) scolor2 = clamp(scolor2, min(min(sl1,sr1),sct), max(max(sl1,sr1),sct));
scolor2 = pow(scolor2, gtmp);
scolor2 = mix(color2, scolor2, spike);
}
// calculating scanlines
float f = (TATE < 0.5) ? fp.y : fp.x;
float shape1 = mix(scanline1, scanline2, f);
@ -443,14 +480,19 @@ void main()
float wt1 = st(f, shape1);
float wt2 = st(1.0-f, shape2);
vec3 color0 = color1*wt1 + color2*wt2;
vec3 scolor0 = scolor1*wt1 + scolor2*wt2;
vec3 ctmp = color0/(wt1+wt2);
vec3 sctmp = scolor0/(wt1+wt2);
vec3 tmp = pow(ctmp, vec3(1.0/gamma_out));
vec3 w1,w2 = vec3(0.0);
vec3 cref1 = mix(ctmp, color1, beam_size);
vec3 cref2 = mix(ctmp, color2, beam_size);
vec3 cref1 = mix(sctmp, scolor1, beam_size);
vec3 cref2 = mix(sctmp, scolor2, beam_size);
vec3 shift = vec3(-vertmask, vertmask, -vertmask);
@ -459,7 +501,7 @@ void main()
if (gsl == 0.0) { w1 = sw0(f1,cref1,shape1); w2 = sw0(f2,cref2,shape2);} else
if (gsl == 1.0) { w1 = sw1(f1,cref1,shape1); w2 = sw1(f2,cref2,shape2);} else
if (gsl == 2.0) { w1 = sw2(f1,cref1,shape1); w2 = sw2(f2,cref2,shape2);}
if (gsl == 2.0) { w1 = sw2(f1,cref1,shape1); w2 = sw2(f2,cref2,shape2);}
vec3 color = color1*w1 + color2*w2;
@ -476,7 +518,7 @@ void main()
color *= (TATE < 0.5) ? SlotMask(gl_FragCoord.xy * 1.000001,tmp) :
SlotMask(gl_FragCoord.yx * 1.000001,tmp);
vec3 Bloom = COMPAT_TEXTURE(Texture, pos).xyz;
vec3 Bloom = COMPAT_TEXTURE(PassPrev2Texture, pos).xyz;
color+=glow*Bloom;

View file

@ -6,12 +6,8 @@ layout(push_constant) uniform Push
vec4 OriginalSize;
vec4 OutputSize;
uint FrameCount;
float SCANLINE_GAMMA;
} params;
#pragma parameter SCANLINE_GAMMA "Scanline Spike Removal" 12.0 1.0 15.0 0.5
#define SCANLINE_GAMMA params.SCANLINE_GAMMA
layout(std140, set = 0, binding = 0) uniform UBO
{
mat4 MVP;
@ -33,7 +29,10 @@ layout(location = 0) in vec2 vTexCoord;
layout(location = 0) out vec4 FragColor;
layout(set = 0, binding = 2) uniform sampler2D AfterglowPass;
#define PassPrev6Texture AfterglowPass
#define COMPAT_TEXTURE(c,d) texture(c,d)
void main()
{
FragColor = vec4(pow(vec3(texture(AfterglowPass, vTexCoord).rgb), vec3(SCANLINE_GAMMA)),1.0/SCANLINE_GAMMA);
}
FragColor = vec4(pow(vec3(COMPAT_TEXTURE(PassPrev6Texture, vTexCoord).rgb), vec3(10.0)),1.0);
}

View file

@ -50,8 +50,9 @@ shader8 = "../crt/shaders/guest/blur_vert.slang"
filter_linear8 = "false"
scale_type8 = "source"
scale8 = "1.000000"
alias8 = GlowPass
shader9 = ../crt/shaders/guest/linearize_scanlines.slang
shader9 = "../crt/shaders/guest/linearize_scanlines.slang"
filter_linear9 = true
scale_type9 = source
scale9 = 1.0

View file

@ -72,6 +72,7 @@ filter_linear9 = false
scale_type9 = source
scale9 = 1.0
float_framebuffer9 = true
alias9 = GlowPass
shader10 = ../crt/shaders/guest/linearize_scanlines.slang
filter_linear10 = true