diff options
author | 2021-05-11 22:41:55 +0100 | |
---|---|---|
committer | 2021-05-11 22:41:55 +0100 | |
commit | 77a17cde83c9bdb8a61b871c7a15303f13e8d781 (patch) | |
tree | a23ec1f86c50475b3cc0aeec0135274cef1057c7 /wgpu | |
parent | 08f5591148a74fecf3920357ce8ecba6036925a7 (diff) | |
download | iced-77a17cde83c9bdb8a61b871c7a15303f13e8d781.tar.gz iced-77a17cde83c9bdb8a61b871c7a15303f13e8d781.tar.bz2 iced-77a17cde83c9bdb8a61b871c7a15303f13e8d781.zip |
This commit optimizes the function used to converg rgba pixels into bgra pixels.
Diffstat (limited to 'wgpu')
-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, )?; |