diff options
Diffstat (limited to 'renderer/src/geometry')
| -rw-r--r-- | renderer/src/geometry/cache.rs | 52 | 
1 files changed, 45 insertions, 7 deletions
| diff --git a/renderer/src/geometry/cache.rs b/renderer/src/geometry/cache.rs index 2a3534d0..d82e7f69 100644 --- a/renderer/src/geometry/cache.rs +++ b/renderer/src/geometry/cache.rs @@ -1,6 +1,5 @@  use crate::core::Size;  use crate::geometry::{Frame, Geometry}; -use crate::graphics::Primitive;  use crate::Renderer;  use std::cell::RefCell; @@ -21,10 +20,17 @@ enum State {      Empty,      Filled {          bounds: Size, -        primitive: Arc<Primitive>, +        primitive: Internal,      },  } +#[derive(Debug, Clone)] +enum Internal { +    TinySkia(Arc<iced_tiny_skia::Primitive>), +    #[cfg(feature = "wgpu")] +    Wgpu(Arc<iced_wgpu::Primitive>), +} +  impl Cache {      /// Creates a new empty [`Cache`].      pub fn new() -> Self { @@ -62,9 +68,21 @@ impl Cache {          } = self.state.borrow().deref()          {              if *cached_bounds == bounds { -                return Geometry(Primitive::Cache { -                    content: primitive.clone(), -                }); +                match primitive { +                    Internal::TinySkia(primitive) => { +                        return Geometry::TinySkia( +                            iced_tiny_skia::Primitive::Cache { +                                content: primitive.clone(), +                            }, +                        ); +                    } +                    #[cfg(feature = "wgpu")] +                    Internal::Wgpu(primitive) => { +                        return Geometry::Wgpu(iced_wgpu::Primitive::Cache { +                            content: primitive.clone(), +                        }); +                    } +                }              }          } @@ -74,7 +92,15 @@ impl Cache {          let primitive = {              let geometry = frame.into_geometry(); -            Arc::new(geometry.0) +            match geometry { +                Geometry::TinySkia(primitive) => { +                    Internal::TinySkia(Arc::new(primitive)) +                } +                #[cfg(feature = "wgpu")] +                Geometry::Wgpu(primitive) => { +                    Internal::Wgpu(Arc::new(primitive)) +                } +            }          };          *self.state.borrow_mut() = State::Filled { @@ -82,6 +108,18 @@ impl Cache {              primitive: primitive.clone(),          }; -        Geometry(Primitive::Cache { content: primitive }) +        match primitive { +            Internal::TinySkia(primitive) => { +                Geometry::TinySkia(iced_tiny_skia::Primitive::Cache { +                    content: primitive, +                }) +            } +            #[cfg(feature = "wgpu")] +            Internal::Wgpu(primitive) => { +                Geometry::Wgpu(iced_wgpu::Primitive::Cache { +                    content: primitive, +                }) +            } +        }      }  } | 
