diff options
| author | 2024-01-16 12:02:42 +0100 | |
|---|---|---|
| committer | 2024-01-16 12:02:42 +0100 | |
| commit | 534c7dd7b0bc515c31b6de87b4aa6a35b44c46a0 (patch) | |
| tree | 0ddc8f1b681cbade7e47293bd46a362896aa538a /wgpu/src | |
| parent | 17135cbd56316f31167eb62e026839450506573f (diff) | |
| parent | c4ba657de86d7606587dad5124f435141258f570 (diff) | |
| download | iced-534c7dd7b0bc515c31b6de87b4aa6a35b44c46a0.tar.gz iced-534c7dd7b0bc515c31b6de87b4aa6a35b44c46a0.tar.bz2 iced-534c7dd7b0bc515c31b6de87b4aa6a35b44c46a0.zip | |
Merge branch 'master' into update-winit
Diffstat (limited to 'wgpu/src')
| -rw-r--r-- | wgpu/src/layer.rs | 15 | ||||
| -rw-r--r-- | wgpu/src/layer/text.rs | 5 | ||||
| -rw-r--r-- | wgpu/src/primitive/pipeline.rs | 4 | ||||
| -rw-r--r-- | wgpu/src/text.rs | 22 | 
4 files changed, 43 insertions, 3 deletions
| diff --git a/wgpu/src/layer.rs b/wgpu/src/layer.rs index 557a7633..4ad12a88 100644 --- a/wgpu/src/layer.rs +++ b/wgpu/src/layer.rs @@ -177,6 +177,21 @@ impl<'a> Layer<'a> {                      clip_bounds: *clip_bounds + translation,                  }));              } +            graphics::Primitive::RawText(graphics::text::Raw { +                buffer, +                position, +                color, +                clip_bounds, +            }) => { +                let layer = &mut layers[current_layer]; + +                layer.text.push(Text::Raw(graphics::text::Raw { +                    buffer: buffer.clone(), +                    position: *position + translation, +                    color: *color, +                    clip_bounds: *clip_bounds + translation, +                })); +            }              Primitive::Quad {                  bounds,                  background, diff --git a/wgpu/src/layer/text.rs b/wgpu/src/layer/text.rs index df2f2875..37ee5247 100644 --- a/wgpu/src/layer/text.rs +++ b/wgpu/src/layer/text.rs @@ -1,6 +1,7 @@  use crate::core::alignment;  use crate::core::text;  use crate::core::{Color, Font, Pixels, Point, Rectangle}; +use crate::graphics;  use crate::graphics::text::editor;  use crate::graphics::text::paragraph; @@ -23,8 +24,10 @@ pub enum Text<'a> {          color: Color,          clip_bounds: Rectangle,      }, -    /// A cached text. +    /// Some cached text.      Cached(Cached<'a>), +    /// Some raw text. +    Raw(graphics::text::Raw),  }  #[derive(Debug, Clone)] diff --git a/wgpu/src/primitive/pipeline.rs b/wgpu/src/primitive/pipeline.rs index 302e38f6..c8e45458 100644 --- a/wgpu/src/primitive/pipeline.rs +++ b/wgpu/src/primitive/pipeline.rs @@ -82,7 +82,7 @@ impl<Theme> Renderer for crate::Renderer<Theme> {  /// Stores custom, user-provided pipelines.  #[derive(Default, Debug)]  pub struct Storage { -    pipelines: HashMap<TypeId, Box<dyn Any>>, +    pipelines: HashMap<TypeId, Box<dyn Any + Send>>,  }  impl Storage { @@ -92,7 +92,7 @@ impl Storage {      }      /// Inserts the pipeline `T` in to [`Storage`]. -    pub fn store<T: 'static>(&mut self, pipeline: T) { +    pub fn store<T: 'static + Send>(&mut self, pipeline: T) {          let _ = self.pipelines.insert(TypeId::of::<T>(), Box::new(pipeline));      } diff --git a/wgpu/src/text.rs b/wgpu/src/text.rs index 888b1924..dca09cb8 100644 --- a/wgpu/src/text.rs +++ b/wgpu/src/text.rs @@ -7,6 +7,7 @@ use crate::layer::Text;  use std::borrow::Cow;  use std::cell::RefCell; +use std::sync::Arc;  #[allow(missing_debug_implementations)]  pub struct Pipeline { @@ -76,6 +77,7 @@ impl Pipeline {              Paragraph(Paragraph),              Editor(Editor),              Cache(cache::KeyHash), +            Raw(Arc<glyphon::Buffer>),          }          let allocations: Vec<_> = sections @@ -107,6 +109,7 @@ impl Pipeline {                      Some(Allocation::Cache(key))                  } +                Text::Raw(text) => text.buffer.upgrade().map(Allocation::Raw),              })              .collect(); @@ -185,6 +188,25 @@ impl Pipeline {                              text.clip_bounds,                          )                      } +                    Text::Raw(text) => { +                        let Some(Allocation::Raw(buffer)) = allocation else { +                            return None; +                        }; + +                        let (width, height) = buffer.size(); + +                        ( +                            buffer.as_ref(), +                            Rectangle::new( +                                text.position, +                                Size::new(width, height), +                            ), +                            alignment::Horizontal::Left, +                            alignment::Vertical::Top, +                            text.color, +                            text.clip_bounds, +                        ) +                    }                  };                  let bounds = bounds * scale_factor; | 
