diff options
| author | 2024-02-18 06:12:15 +0100 | |
|---|---|---|
| committer | 2024-02-18 06:12:15 +0100 | |
| commit | 4272090d36caf2937c170d3b28d1be1acc94a440 (patch) | |
| tree | 6dc89750ffcd527c24fc26aa23ec43651bedfe67 /wgpu | |
| parent | c76a9eb2ff08ac242ed27d7fb11f536c1cc4411a (diff) | |
| download | iced-4272090d36caf2937c170d3b28d1be1acc94a440.tar.gz iced-4272090d36caf2937c170d3b28d1be1acc94a440.tar.bz2 iced-4272090d36caf2937c170d3b28d1be1acc94a440.zip | |
[wgpu.image] Workaround WGPU OpenGL heuristics
Diffstat (limited to '')
| -rw-r--r-- | wgpu/src/image/atlas.rs | 8 | 
1 files changed, 6 insertions, 2 deletions
| diff --git a/wgpu/src/image/atlas.rs b/wgpu/src/image/atlas.rs index 789e35b4..0919f6df 100644 --- a/wgpu/src/image/atlas.rs +++ b/wgpu/src/image/atlas.rs @@ -24,10 +24,14 @@ pub struct Atlas {  impl Atlas {      pub fn new(device: &wgpu::Device) -> Self { +        // We start with 2 layers, to help wgpu figure out that this texture is `GL_TEXTURE_2D_ARRAY` rather +        // than `GL_TEXTURE_2D` +        // https://github.com/gfx-rs/wgpu/blob/004e3efe84a320d9331371ed31fa50baa2414911/wgpu-hal/src/gles/mod.rs#L371 +        let layers = vec![Layer::Empty, Layer::Empty];          let extent = wgpu::Extent3d {              width: SIZE,              height: SIZE, -            depth_or_array_layers: 1, +            depth_or_array_layers: layers.len() as u32,          };          let texture = device.create_texture(&wgpu::TextureDescriptor { @@ -55,7 +59,7 @@ impl Atlas {          Atlas {              texture,              texture_view, -            layers: vec![Layer::Empty], +            layers,          }      } | 
