Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix 2D/3D view artifacts on view's border when using fractional zoom #8369

Merged
merged 3 commits into from
Dec 16, 2024
Merged
Show file tree
Hide file tree
Changes from 2 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 2 additions & 2 deletions crates/viewer/re_renderer/shader/composite.wgsl
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ fn main(in: FragmentInput) -> @location(0) vec4f {
// Note that we can't use a simple textureLoad using @builtin(position) here despite the lack of filtering.
// The issue is that positions provided by @builtin(position) are not dependent on the set viewport,
// but are about the location of the texel in the target texture.
var color = textureSample(color_texture, nearest_sampler, in.texcoord);
var color = textureSample(color_texture, nearest_sampler_clamped, in.texcoord);


// TODO(andreas): We assume that the color from the texture does *not* have pre-multiplied alpha.
Expand All @@ -42,7 +42,7 @@ fn main(in: FragmentInput) -> @location(0) vec4f {

// Outlines
{
let closest_positions = textureSample(outline_voronoi_texture, nearest_sampler, in.texcoord);
let closest_positions = textureSample(outline_voronoi_texture, nearest_sampler_clamped, in.texcoord);

let distance_pixel_a = distance(pixel_coordinates, closest_positions.xy);
let distance_pixel_b = distance(pixel_coordinates, closest_positions.zw);
Expand Down
2 changes: 1 addition & 1 deletion crates/viewer/re_renderer/shader/copy_texture.wgsl
Original file line number Diff line number Diff line change
Expand Up @@ -11,5 +11,5 @@ var tex: texture_2d<f32>;

@fragment
fn main(in: FragmentInput) -> @location(0) vec4f {
return textureSample(tex, nearest_sampler, in.texcoord);
return textureSample(tex, nearest_sampler_clamped, in.texcoord);
}
2 changes: 1 addition & 1 deletion crates/viewer/re_renderer/shader/debug_overlay.wgsl
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,7 @@ fn main_vs(@builtin(vertex_index) vertex_index: u32) -> VertexOutput {
@fragment
fn main_fs(in: VertexOutput) -> @location(0) vec4f {
if uniforms.mode == ShowFloatTexture {
return vec4f(textureSample(debug_texture_float, nearest_sampler, in.texcoord).rgb, 1.0);
return vec4f(textureSample(debug_texture_float, nearest_sampler_clamped, in.texcoord).rgb, 1.0);
} else if uniforms.mode == ShowUintTexture {
let coords = vec2i(in.texcoord * vec2f(textureDimensions(debug_texture_uint).xy));
let raw_values = textureLoad(debug_texture_uint, coords, 0);
Expand Down
7 changes: 4 additions & 3 deletions crates/viewer/re_renderer/shader/global_bindings.wgsl
Original file line number Diff line number Diff line change
Expand Up @@ -31,10 +31,11 @@ struct FrameUniformBuffer {
var<uniform> frame: FrameUniformBuffer;

@group(0) @binding(1)
var nearest_sampler: sampler;

var nearest_sampler_repeat: sampler;
@group(0) @binding(2)
var trilinear_sampler: sampler;
var nearest_sampler_clamped: sampler;
@group(0) @binding(3)
var trilinear_sampler_repeat: sampler;

// See config.rs#DeviceTier
const DEVICE_TIER_GLES = 0u;
Expand Down
2 changes: 1 addition & 1 deletion crates/viewer/re_renderer/shader/instanced_mesh.wgsl
Original file line number Diff line number Diff line change
Expand Up @@ -64,7 +64,7 @@ fn vs_main(in_vertex: VertexIn, in_instance: InstanceIn) -> VertexOut {

@fragment
fn fs_main_shaded(in: VertexOut) -> @location(0) vec4f {
let texture = linear_from_srgb(textureSample(albedo_texture, trilinear_sampler, in.texcoord).rgb);
let texture = linear_from_srgb(textureSample(albedo_texture, trilinear_sampler_repeat, in.texcoord).rgb);
let albedo = texture
* in.color.rgb
* material.albedo_factor.rgb
Expand Down
35 changes: 27 additions & 8 deletions crates/viewer/re_renderer/src/global_bindings.rs
Original file line number Diff line number Diff line change
Expand Up @@ -45,8 +45,9 @@ pub struct FrameUniformBuffer {

pub(crate) struct GlobalBindings {
pub(crate) layout: GpuBindGroupLayoutHandle,
nearest_neighbor_sampler: GpuSamplerHandle,
trilinear_sampler: GpuSamplerHandle,
nearest_neighbor_sampler_repeat: GpuSamplerHandle,
nearest_neighbor_sampler_clamped: GpuSamplerHandle,
trilinear_sampler_repeat: GpuSamplerHandle,
}

impl GlobalBindings {
Expand All @@ -73,24 +74,31 @@ impl GlobalBindings {
},
count: None,
},
// Sampler without any filtering.
// Sampler without any filtering, repeat.
wgpu::BindGroupLayoutEntry {
binding: 1,
visibility: wgpu::ShaderStages::FRAGMENT,
ty: wgpu::BindingType::Sampler(wgpu::SamplerBindingType::NonFiltering),
count: None,
},
// Trilinear sampler.
// Sampler without any filtering, clamped.
wgpu::BindGroupLayoutEntry {
binding: 2,
visibility: wgpu::ShaderStages::FRAGMENT,
ty: wgpu::BindingType::Sampler(wgpu::SamplerBindingType::NonFiltering),
count: None,
},
// Trilinear sampler, repeat.
wgpu::BindGroupLayoutEntry {
binding: 3,
visibility: wgpu::ShaderStages::FRAGMENT,
ty: wgpu::BindingType::Sampler(wgpu::SamplerBindingType::Filtering),
count: None,
},
],
},
),
nearest_neighbor_sampler: pools.samplers.get_or_create(
nearest_neighbor_sampler_repeat: pools.samplers.get_or_create(
device,
&SamplerDesc {
label: "GlobalBindings::nearest_neighbor_sampler".into(),
Expand All @@ -100,7 +108,17 @@ impl GlobalBindings {
..Default::default()
},
),
trilinear_sampler: pools.samplers.get_or_create(
nearest_neighbor_sampler_clamped: pools.samplers.get_or_create(
device,
&SamplerDesc {
label: "GlobalBindings::nearest_neighbor_sampler_clamped".into(),
address_mode_u: wgpu::AddressMode::ClampToEdge,
address_mode_v: wgpu::AddressMode::ClampToEdge,
address_mode_w: wgpu::AddressMode::ClampToEdge,
..Default::default()
},
),
trilinear_sampler_repeat: pools.samplers.get_or_create(
device,
&SamplerDesc {
label: "GlobalBindings::trilinear_sampler".into(),
Expand Down Expand Up @@ -131,8 +149,9 @@ impl GlobalBindings {
label: "GlobalBindings::create_bind_group".into(),
entries: smallvec![
frame_uniform_buffer_binding,
BindGroupEntry::Sampler(self.nearest_neighbor_sampler),
BindGroupEntry::Sampler(self.trilinear_sampler),
BindGroupEntry::Sampler(self.nearest_neighbor_sampler_repeat),
BindGroupEntry::Sampler(self.nearest_neighbor_sampler_clamped),
BindGroupEntry::Sampler(self.trilinear_sampler_repeat),
],
layout: self.layout,
},
Expand Down
Loading