YoshisWW - issue fixes

This commit is contained in:
getdls 2018-10-31 19:35:13 +01:00
parent 88f8108a18
commit e2d11ab7a2
3 changed files with 300 additions and 231 deletions

View File

@ -2,15 +2,25 @@
#extension GL_ARB_texture_gather : enable
#extension GL_ARB_separate_shader_objects : enable
// shader b5082db8c1a44514
// Used for vertical blur DoF
const float resXScale = ($width/$gameWidth);
const float resYScale = ($height/$gameHeight);
//BGblur vert
const float dither = $dither ;
uniform ivec4 uf_uniformRegisterPS[256];
layout(binding = 0) uniform sampler2D textureUnitPS0;// Tex0 addr 0xf4e14800 res 640x360x1 dim 1 tm: 4 format 001a compSel: 0 1 2 3 mipView: 0x0 (num 0x1) sliceView: 0x0 (num 0x1) Sampler0 ClampX/Y/Z: 2 2 2 border: 0
layout(location = 0) in vec4 passParameterSem0;
layout(location = 0) out vec4 passPixelColor0;
uniform vec2 uf_fragCoordScale;
highp float lineRand(vec2 co)
{
highp float a = 12.9898;
highp float b = 78.233;
highp float c = 43758.5453;
highp float dt = dot(co.xy, vec2(a, b));
highp float sn = mod(dt, 3.14);
return fract(sin(sn) * c);
}
int clampFI32(int v)
{
if( v == 0x7FFFFFFF )
@ -19,7 +29,7 @@ else if( v == 0xFFFFFFFF )
return floatBitsToInt(0.0);
return floatBitsToInt(clamp(intBitsToFloat(v), 0.0, 1.0));
}
float mul_nonIEEE(float a, float b){ if( a == 0.0 || b == 0.0 ) return 0.0; return a*b; }
float mul_nonIEEE(float a, float b){return mix(0.0, a*b, (a != 0.0) && (b != 0.0));}
void main()
{
ivec4 R0i = ivec4(0);
@ -45,6 +55,7 @@ activeMaskStackC[1] = true;
vec3 cubeMapSTM;
int cubeMapFaceId;
R0i = floatBitsToInt(passParameterSem0);
R0i.xy = floatBitsToInt(passParameterSem0.xy- (lineRand(gl_FragCoord.xy)*0.001*dither)).xy;
if( activeMaskStackC[1] == true ) {
R1i.xyzw = floatBitsToInt(texture(textureUnitPS0, intBitsToFloat(R0i.xy)).xyzw);
}
@ -82,8 +93,8 @@ tempResultf = clamp(tempResultf, -256.0, 255.0);
ARi.x = int(tempResultf);
PV1i.x = floatBitsToInt(tempResultf);
// 2
R1i.xyz = floatBitsToInt(vec3(intBitsToFloat(R0i.x),intBitsToFloat(R0i.y),intBitsToFloat(R0i.x)) + vec3(intBitsToFloat(uf_uniformRegisterPS[ARi.x+0].x),intBitsToFloat(uf_uniformRegisterPS[ARi.x+0].y)/resYScale,-(intBitsToFloat(uf_uniformRegisterPS[ARi.x+0].x))));
R1i.w = floatBitsToInt(intBitsToFloat(R0i.y) + -(intBitsToFloat(uf_uniformRegisterPS[ARi.x+0].y)/resYScale));
R1i.xyz = floatBitsToInt(vec3(intBitsToFloat(R0i.x),intBitsToFloat(R0i.y),intBitsToFloat(R0i.x)) + vec3(intBitsToFloat(uf_uniformRegisterPS[ARi.x+0].x),intBitsToFloat(uf_uniformRegisterPS[ARi.x+0].y),-(intBitsToFloat(uf_uniformRegisterPS[ARi.x+0].x))));
R1i.w = floatBitsToInt(intBitsToFloat(R0i.y) + -(intBitsToFloat(uf_uniformRegisterPS[ARi.x+0].y)));
}
if( activeMaskStackC[1] == true ) {
R2i.xyzw = floatBitsToInt(texture(textureUnitPS0, intBitsToFloat(R1i.xy)).xyzw);

View File

@ -2,15 +2,28 @@
#extension GL_ARB_texture_gather : enable
#extension GL_ARB_separate_shader_objects : enable
// shader f1f99f18ae69719b
// Used for horizontal blur DoF
const float resXScale = ($width/$gameWidth);
const float resYScale = ($height/$gameHeight);
//Bg horizontal
const float dither = $dither ;
uniform ivec4 uf_uniformRegisterPS[256];
layout(binding = 0) uniform sampler2D textureUnitPS0;// Tex0 addr 0xf59d2000 res 640x360x1 dim 1 tm: 4 format 001a compSel: 0 1 2 3 mipView: 0x0 (num 0x1) sliceView: 0x0 (num 0x1) Sampler0 ClampX/Y/Z: 2 2 2 border: 0
layout(location = 0) in vec4 passParameterSem0;
layout(location = 0) out vec4 passPixelColor0;
uniform vec2 uf_fragCoordScale;
highp float lineRand(vec2 co)
{
highp float a = 12.9898;
highp float b = 78.233;
highp float c = 43758.5453;
highp float dt = dot(co.xy, vec2(a, b));
highp float sn = mod(dt, 3.14);
return fract(sin(sn) * c);
}
//- (lineRand(R0i.xy )*0.415)
int clampFI32(int v)
{
if( v == 0x7FFFFFFF )
@ -19,7 +32,7 @@ else if( v == 0xFFFFFFFF )
return floatBitsToInt(0.0);
return floatBitsToInt(clamp(intBitsToFloat(v), 0.0, 1.0));
}
float mul_nonIEEE(float a, float b){ if( a == 0.0 || b == 0.0 ) return 0.0; return a*b; }
float mul_nonIEEE(float a, float b){return mix(0.0, a*b, (a != 0.0) && (b != 0.0));}
void main()
{
ivec4 R0i = ivec4(0);
@ -45,6 +58,9 @@ activeMaskStackC[1] = true;
vec3 cubeMapSTM;
int cubeMapFaceId;
R0i = floatBitsToInt(passParameterSem0);
R0i.xy = floatBitsToInt(passParameterSem0.xy- (lineRand(gl_FragCoord.xy)*0.001*dither)).xy;
//R0f.xy = R0f.xy - (lineRand(gl_FragCoord.xy)*0.015);
if( activeMaskStackC[1] == true ) {
R1i.xyzw = floatBitsToInt(texture(textureUnitPS0, intBitsToFloat(R0i.xy)).xyzw);
}
@ -82,7 +98,7 @@ tempResultf = clamp(tempResultf, -256.0, 255.0);
ARi.x = int(tempResultf);
PV1i.x = floatBitsToInt(tempResultf);
// 2
R1i.xyz = floatBitsToInt(vec3(intBitsToFloat(R0i.x),intBitsToFloat(R0i.y),intBitsToFloat(R0i.x)) + vec3(intBitsToFloat(uf_uniformRegisterPS[ARi.x+0].x)/resXScale,intBitsToFloat(uf_uniformRegisterPS[ARi.x+0].y),-(intBitsToFloat(uf_uniformRegisterPS[ARi.x+0].x)/resXScale)));
R1i.xyz = floatBitsToInt(vec3(intBitsToFloat(R0i.x),intBitsToFloat(R0i.y),intBitsToFloat(R0i.x)) + vec3(intBitsToFloat(uf_uniformRegisterPS[ARi.x+0].x),intBitsToFloat(uf_uniformRegisterPS[ARi.x+0].y),-(intBitsToFloat(uf_uniformRegisterPS[ARi.x+0].x))));
R1i.w = floatBitsToInt(intBitsToFloat(R0i.y) + -(intBitsToFloat(uf_uniformRegisterPS[ARi.x+0].y)));
}
if( activeMaskStackC[1] == true ) {

View File

@ -1,32 +1,17 @@
[Definition]
titleIds = 0005000010131F00,0005000010184E00,0005000010184D00
name = Resolution
path = "Yoshi's Woolly World/Graphics/Resolution"
path = "Yoshis Woolly World/Graphics/Resolution"
description = Changes the resolution of the game.
version = 3
[Preset]
name = 1280x720 (Default)
name = 1280x720 Default
$width = 1280
$height = 720
$gameWidth = 1280
$gameHeight = 720
// Performance
[Preset]
name = 256x144
$width = 256
$height = 144
$gameWidth = 1280
$gameHeight = 720
[Preset]
name = 427x240
$width = 427
$height = 240
$gameWidth = 1280
$gameHeight = 720
$dither = 0.1
[Preset]
name = 640x360
@ -34,6 +19,7 @@ $width = 640
$height = 360
$gameWidth = 1280
$gameHeight = 720
$dither = 0.1
[Preset]
name = 854x480
@ -41,6 +27,7 @@ $width = 854
$height = 480
$gameWidth = 1280
$gameHeight = 720
$dither = 0.1
[Preset]
name = 960x540
@ -48,8 +35,7 @@ $width = 960
$height = 540
$gameWidth = 1280
$gameHeight = 720
// Quality
$dither = 0.1
[Preset]
name = 1600x900
@ -57,6 +43,7 @@ $width = 1600
$height = 900
$gameWidth = 1280
$gameHeight = 720
$dither = 0.1
[Preset]
name = 1920x1080
@ -64,6 +51,7 @@ $width = 1920
$height = 1080
$gameWidth = 1280
$gameHeight = 720
$dither = 0.1
[Preset]
name = 2560x1440
@ -71,6 +59,7 @@ $width = 2560
$height = 1440
$gameWidth = 1280
$gameHeight = 720
$dither = 0.5
[Preset]
name = 2732x1536
@ -78,6 +67,7 @@ $width = 2732
$height = 1536
$gameWidth = 1280
$gameHeight = 720
$dither = 0.5
[Preset]
name = 3200x1800
@ -85,6 +75,7 @@ $width = 3200
$height = 1800
$gameWidth = 1280
$gameHeight = 720
$dither = 0.75
[Preset]
name = 3840x2160
@ -92,6 +83,7 @@ $width = 3840
$height = 2160
$gameWidth = 1280
$gameHeight = 720
$dither = 0.85
[Preset]
name = 5120x2880
@ -99,8 +91,7 @@ $width = 5120
$height = 2880
$gameWidth = 1280
$gameHeight = 720
// Enthusiast
$dither = 1.0
[Preset]
name = 7680x4320
@ -108,6 +99,7 @@ $width = 7680
$height = 4320
$gameWidth = 1280
$gameHeight = 720
$dither = 1.25
[Preset]
name = 10240x5760
@ -115,22 +107,72 @@ $width = 10240
$height = 5760
$gameWidth = 1280
$gameHeight = 720
$dither = 1.25
[TextureRedefine] # Game Resolution
[TextureRedefine]
width = 1280
height = 720
#formats = 0x033,0x007,0x01a
formatsExcluded = 0x033
tileModesExcluded = 0x001
overwriteWidth = ($width/$gameWidth) * 1280
overwriteHeight = ($height/$gameHeight) * 720
[TextureRedefine] # Depth of Field Pass
[TextureRedefine] #
width = 1024
height = 1024
#formatsExcluded = 0x431,0x005,0x433,0x431,0x235,0x035,0x034,0x033,0x031,0x005,0x01a
formats = 0x005
overwriteWidth = ($width/$gameWidth) * 1024
overwriteHeight = ($height/$gameHeight) * 1024
[TextureRedefine]
width = 854
height = 480
#formats = 0x034
overwriteWidth = ($width/$gameWidth) * 854
overwriteHeight = ($height/$gameHeight) * 480
[TextureRedefine]
width = 640
height = 368
#formats = 0x816,0x820,0x816,0x80e,0x019,0x001,0x01a
tileModesExcluded = 0x001
overwriteWidth = ($width/$gameWidth) * 640
overwriteHeight = ($height/$gameHeight) * 368
[TextureRedefine] # Depth of Field Pass
[TextureRedefine]
width = 640
height = 360
#formats = 0x816,0x820,0x816,0x80e,0x019,0x001,0x01a
tileModesExcluded = 0x001
overwriteWidth = ($width/$gameWidth) * 640
overwriteHeight = ($height/$gameHeight) * 360
[TextureRedefine]
width = 320
height = 180
#formats = 0x816,0x019,0x01a,0x001
overwriteWidth = ($width/$gameWidth) * 320
overwriteHeight = ($height/$gameHeight) * 180
[TextureRedefine]
width = 160
height = 90
#formats = 0x806,0x007,0x01a
overwriteWidth = ($width/$gameWidth) * 160
overwriteHeight = ($height/$gameHeight) * 90
[TextureRedefine]
width = 80
height = 45
#formats = 0x806,0x01a
overwriteWidth = ($width/$gameWidth) * 80
overwriteHeight = ($height/$gameHeight) * 45
[TextureRedefine]
width = 40
height = 22
#formats = 0x01a
overwriteWidth = ($width/$gameWidth) * 40
overwriteHeight = ($height/$gameHeight) * 22