diff options
| author | 2023-04-19 01:19:56 +0200 | |
|---|---|---|
| committer | 2023-05-02 01:02:13 +0200 | |
| commit | 33b5a900197e2798a393d6d9a0834039666eddbb (patch) | |
| tree | b4ce1f77dc50d3733a2c9252d57674c3592a0c3c /graphics/src | |
| parent | 57a276e16539d6aeca0619e0c5e36d0b1c1b5ef9 (diff) | |
| download | iced-33b5a900197e2798a393d6d9a0834039666eddbb.tar.gz iced-33b5a900197e2798a393d6d9a0834039666eddbb.tar.bz2 iced-33b5a900197e2798a393d6d9a0834039666eddbb.zip | |
Make basic text shaping the default shaping strategy
Diffstat (limited to '')
| -rw-r--r-- | graphics/src/backend.rs | 2 | ||||
| -rw-r--r-- | graphics/src/geometry/text.rs | 10 | ||||
| -rw-r--r-- | graphics/src/primitive.rs | 9 | ||||
| -rw-r--r-- | graphics/src/renderer.rs | 7 | 
4 files changed, 27 insertions, 1 deletions
| diff --git a/graphics/src/backend.rs b/graphics/src/backend.rs index dd2888ab..0e107dd5 100644 --- a/graphics/src/backend.rs +++ b/graphics/src/backend.rs @@ -48,6 +48,7 @@ pub trait Text {          size: f32,          font: Font,          bounds: Size, +        advanced_shape: bool,      ) -> (f32, f32);      /// Tests whether the provided point is within the boundaries of [`Text`] @@ -65,6 +66,7 @@ pub trait Text {          bounds: Size,          point: Point,          nearest_only: bool, +        advanced_shape: bool,      ) -> Option<text::Hit>;      /// Loads a [`Font`] from its bytes. diff --git a/graphics/src/geometry/text.rs b/graphics/src/geometry/text.rs index 0befd635..f4af9ee4 100644 --- a/graphics/src/geometry/text.rs +++ b/graphics/src/geometry/text.rs @@ -25,6 +25,15 @@ pub struct Text {      pub horizontal_alignment: alignment::Horizontal,      /// The vertical alignment of the text      pub vertical_alignment: alignment::Vertical, +    /// Whether the text needs advanced shaping and font fallback. +    /// +    /// You will need to enable this flag if the text contains a complex +    /// script, the font used needs it, and/or multiple fonts in your system +    /// may be needed to display all of the glyphs. +    /// +    /// Advanced shaping is expensive! You should only enable it when +    /// necessary. +    pub advanced_shape: bool,  }  impl Default for Text { @@ -37,6 +46,7 @@ impl Default for Text {              font: Font::default(),              horizontal_alignment: alignment::Horizontal::Left,              vertical_alignment: alignment::Vertical::Top, +            advanced_shape: false,          }      }  } diff --git a/graphics/src/primitive.rs b/graphics/src/primitive.rs index d6a2c4c4..2d9c221b 100644 --- a/graphics/src/primitive.rs +++ b/graphics/src/primitive.rs @@ -26,6 +26,15 @@ pub enum Primitive {          horizontal_alignment: alignment::Horizontal,          /// The vertical alignment of the text          vertical_alignment: alignment::Vertical, +        /// Whether the text needs advanced shaping and font fallback. +        /// +        /// You will need to enable this flag if the text contains a complex +        /// script, the font used needs it, and/or multiple fonts in your system +        /// may be needed to display all of the glyphs. +        /// +        /// Advanced shaping is expensive! You should only enable it when +        /// necessary. +        advanced_shape: bool,      },      /// A quad primitive      Quad { diff --git a/graphics/src/renderer.rs b/graphics/src/renderer.rs index 23e594be..558e21dd 100644 --- a/graphics/src/renderer.rs +++ b/graphics/src/renderer.rs @@ -138,8 +138,10 @@ where          size: f32,          font: Font,          bounds: Size, +        needs_shaping: bool,      ) -> (f32, f32) { -        self.backend().measure(content, size, font, bounds) +        self.backend() +            .measure(content, size, font, bounds, needs_shaping)      }      fn hit_test( @@ -150,6 +152,7 @@ where          bounds: Size,          point: Point,          nearest_only: bool, +        advanced_shape: bool,      ) -> Option<text::Hit> {          self.backend().hit_test(              content, @@ -158,6 +161,7 @@ where              bounds,              point,              nearest_only, +            advanced_shape,          )      } @@ -174,6 +178,7 @@ where              font: text.font,              horizontal_alignment: text.horizontal_alignment,              vertical_alignment: text.vertical_alignment, +            advanced_shape: text.advanced_shape,          });      }  } | 
