summaryrefslogtreecommitdiffstats
path: root/graphics
diff options
context:
space:
mode:
authorLibravatar Héctor Ramón Jiménez <hector0193@gmail.com>2023-04-19 01:19:56 +0200
committerLibravatar Héctor Ramón Jiménez <hector0193@gmail.com>2023-05-02 01:02:13 +0200
commit33b5a900197e2798a393d6d9a0834039666eddbb (patch)
treeb4ce1f77dc50d3733a2c9252d57674c3592a0c3c /graphics
parent57a276e16539d6aeca0619e0c5e36d0b1c1b5ef9 (diff)
downloadiced-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.rs2
-rw-r--r--graphics/src/geometry/text.rs10
-rw-r--r--graphics/src/primitive.rs9
-rw-r--r--graphics/src/renderer.rs7
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,
});
}
}