diff options
Diffstat (limited to 'wgpu/src/image')
| -rw-r--r-- | wgpu/src/image/vector.rs | 22 | 
1 files changed, 5 insertions, 17 deletions
| diff --git a/wgpu/src/image/vector.rs b/wgpu/src/image/vector.rs index ab0f67d0..8c7de617 100644 --- a/wgpu/src/image/vector.rs +++ b/wgpu/src/image/vector.rs @@ -1,7 +1,8 @@ -use crate::image::atlas::{self, Atlas};  use iced_native::svg;  use std::collections::{HashMap, HashSet}; +use crate::image::atlas::{self, Atlas}; +  pub enum Svg {      Loaded(usvg::Tree),      NotFound, @@ -111,26 +112,13 @@ impl Cache {                  let width = img.width();                  let height = img.height(); -                let mut rgba = img.take().into_iter(); - -                // TODO: Perform conversion in the GPU -                let bgra: Vec<u8> = std::iter::from_fn(move || { -                    use std::iter::once; - -                    let r = rgba.next()?; -                    let g = rgba.next()?; -                    let b = rgba.next()?; -                    let a = rgba.next()?; - -                    Some(once(b).chain(once(g)).chain(once(r)).chain(once(a))) -                }) -                .flatten() -                .collect(); +                let mut rgba = img.take(); +                rgba.chunks_exact_mut(4).for_each(|rgba| rgba.swap(0, 2));                  let allocation = texture_atlas.upload(                      width,                      height, -                    bytemuck::cast_slice(bgra.as_slice()), +                    bytemuck::cast_slice(rgba.as_slice()),                      device,                      encoder,                  )?; | 
