From d4f8c1b2bd4a150a33da83d87727aba3e36c76b3 Mon Sep 17 00:00:00 2001 From: Sam Belliveau Date: Mon, 21 Aug 2023 14:20:44 -0400 Subject: [PATCH 1/2] fixed area sampling --- Data/Sys/Shaders/default_pre_post_process.glsl | 17 +++++++++-------- 1 file changed, 9 insertions(+), 8 deletions(-) diff --git a/Data/Sys/Shaders/default_pre_post_process.glsl b/Data/Sys/Shaders/default_pre_post_process.glsl index 795518d616..3481f65a03 100644 --- a/Data/Sys/Shaders/default_pre_post_process.glsl +++ b/Data/Sys/Shaders/default_pre_post_process.glsl @@ -199,15 +199,16 @@ float4 AreaSampling(float3 uvw, float gamma) { // Determine the sizes of the source and target images. float2 source_size = GetResolution(); + float2 target_size = GetWindowResolution(); float2 inverted_target_size = GetInvWindowResolution(); - // Determine the range of the source image that the target pixel will cover. - // Workaround: shift the resolution by 1/4 pixel to align the results with other sampling algorithms, - // otherwise the results would be offsetted, and we'd be sampling from coordinates outside the valid range. - float2 adjusted_source_size = source_size - 0.25; - float2 range = adjusted_source_size * inverted_target_size; - float2 beg = (uvw.xy * adjusted_source_size) - (range * 0.5); - float2 end = beg + range; + // Compute the top-left and bottom-right corners of the target pixel box. + float2 t_beg = floor(uvw.xy * target_size); + float2 t_end = t_beg + float2(1.0, 1.0); + + // Convert the target pixel box to source pixel box. + float2 beg = t_beg * inverted_target_size * source_size; + float2 end = t_end * inverted_target_size * source_size; // Compute the top-left and bottom-right corners of the pixel box. float2 f_beg = floor(beg); @@ -236,7 +237,7 @@ float4 AreaSampling(float3 uvw, float gamma) avg_color += area_ne * QuickSampleByPixel(float2(f_end.x, f_beg.y) + offset, uvw.z, gamma); avg_color += area_sw * QuickSampleByPixel(float2(f_beg.x, f_end.y) + offset, uvw.z, gamma); avg_color += area_se * QuickSampleByPixel(float2(f_end.x, f_end.y) + offset, uvw.z, gamma); - + // Determine the size of the pixel box. int x_range = int(f_end.x - f_beg.x + 0.5); int y_range = int(f_end.y - f_beg.y + 0.5); From 7894b401117dce5e1f0c112e6b3faa39817c5487 Mon Sep 17 00:00:00 2001 From: Sam Belliveau Date: Tue, 14 Nov 2023 12:05:12 -0500 Subject: [PATCH 2/2] Fix inner area sampling loop from going beyond bounds --- Data/Sys/Shaders/default_pre_post_process.glsl | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/Data/Sys/Shaders/default_pre_post_process.glsl b/Data/Sys/Shaders/default_pre_post_process.glsl index 3481f65a03..f6854d11fd 100644 --- a/Data/Sys/Shaders/default_pre_post_process.glsl +++ b/Data/Sys/Shaders/default_pre_post_process.glsl @@ -239,8 +239,8 @@ float4 AreaSampling(float3 uvw, float gamma) avg_color += area_se * QuickSampleByPixel(float2(f_end.x, f_end.y) + offset, uvw.z, gamma); // Determine the size of the pixel box. - int x_range = int(f_end.x - f_beg.x + 0.5); - int y_range = int(f_end.y - f_beg.y + 0.5); + int x_range = int(f_end.x - f_beg.x - 0.5); + int y_range = int(f_end.y - f_beg.y - 0.5); // Workaround to compile the shader with DX11/12. // If this isn't done, it will complain that the loop could have too many iterations. @@ -405,4 +405,4 @@ void main() } SetOutput(color); -} \ No newline at end of file +}