mirror of
https://github.com/X0nk/Bliss-Shader.git
synced 2025-01-04 00:23:41 +08:00
FIX purkinje effect
This commit is contained in:
parent
447419a57c
commit
c39a3fadb4
@ -104,7 +104,6 @@ void main() {
|
|||||||
|
|
||||||
vec3 bloom = texture2D(colortex3, texcoord/clampedRes*vec2(1920.,1080.)*BLOOM_QUALITY).rgb / 2.0 / 7.0;
|
vec3 bloom = texture2D(colortex3, texcoord/clampedRes*vec2(1920.,1080.)*BLOOM_QUALITY).rgb / 2.0 / 7.0;
|
||||||
|
|
||||||
|
|
||||||
float lightScat = clamp(BLOOM_STRENGTH * 0.05 * pow(exposure.a, 0.2) ,0.0,1.0)*vignette;
|
float lightScat = clamp(BLOOM_STRENGTH * 0.05 * pow(exposure.a, 0.2) ,0.0,1.0)*vignette;
|
||||||
|
|
||||||
float VL_abs = texture2D(colortex7,texcoord*RENDER_SCALE).r;
|
float VL_abs = texture2D(colortex7,texcoord*RENDER_SCALE).r;
|
||||||
@ -120,7 +119,7 @@ void main() {
|
|||||||
// // apply exposure
|
// // apply exposure
|
||||||
// col *= exposure.rgb;
|
// col *= exposure.rgb;
|
||||||
|
|
||||||
col = (mix(col,bloom,VL_abs)+bloom * lightScat) * exposure.rgb;
|
col = (mix(col, bloom, VL_abs) + bloom * lightScat) * exposure.rgb;
|
||||||
|
|
||||||
//Purkinje Effect
|
//Purkinje Effect
|
||||||
float lum = dot(col,vec3(0.15,0.3,0.55));
|
float lum = dot(col,vec3(0.15,0.3,0.55));
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
varying vec2 texcoord;
|
varying vec2 texcoord;
|
||||||
flat varying vec4 exposure;
|
flat varying vec4 exposure;
|
||||||
flat varying float rodExposure;
|
flat varying vec2 rodExposureDepth;
|
||||||
uniform sampler2D colortex4;
|
uniform sampler2D colortex4;
|
||||||
|
|
||||||
//////////////////////////////VOID MAIN//////////////////////////////
|
//////////////////////////////VOID MAIN//////////////////////////////
|
||||||
@ -15,6 +15,8 @@ void main() {
|
|||||||
|
|
||||||
gl_Position = ftransform();
|
gl_Position = ftransform();
|
||||||
texcoord = gl_MultiTexCoord0.xy;
|
texcoord = gl_MultiTexCoord0.xy;
|
||||||
exposure=vec4(texelFetch2D(colortex4,ivec2(10,37),0).r*vec3(FinalR,FinalG,FinalB),texelFetch2D(colortex4,ivec2(10,37),0).r);
|
|
||||||
rodExposure = texelFetch2D(colortex4,ivec2(14,37),0).r;
|
exposure = vec4(texelFetch2D(colortex4,ivec2(10,37),0).r*vec3(FinalR,FinalG,FinalB),texelFetch2D(colortex4,ivec2(10,37),0).r);
|
||||||
|
rodExposureDepth = texelFetch2D(colortex4,ivec2(14,37),0).rg;
|
||||||
|
rodExposureDepth.y = sqrt(rodExposureDepth.y/65000.0);
|
||||||
}
|
}
|
@ -151,6 +151,7 @@ vec4 GetVolumetricFog(
|
|||||||
vec3 progressW = gbufferModelViewInverse[3].xyz + cameraPosition;
|
vec3 progressW = gbufferModelViewInverse[3].xyz + cameraPosition;
|
||||||
|
|
||||||
float lightleakfix = clamp(pow(eyeBrightnessSmooth.y/240.,2) ,0.0,1.0);
|
float lightleakfix = clamp(pow(eyeBrightnessSmooth.y/240.,2) ,0.0,1.0);
|
||||||
|
|
||||||
for (int i=0;i<VL_SAMPLES;i++) {
|
for (int i=0;i<VL_SAMPLES;i++) {
|
||||||
float d = (pow(expFactor, float(i+dither)/float(VL_SAMPLES))/expFactor - 1.0/expFactor)/(1-1.0/expFactor);
|
float d = (pow(expFactor, float(i+dither)/float(VL_SAMPLES))/expFactor - 1.0/expFactor)/(1-1.0/expFactor);
|
||||||
float dd = pow(expFactor, float(i+dither)/float(VL_SAMPLES)) * log(expFactor) / float(VL_SAMPLES)/(expFactor-1.0);
|
float dd = pow(expFactor, float(i+dither)/float(VL_SAMPLES)) * log(expFactor) / float(VL_SAMPLES)/(expFactor-1.0);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user