summaryrefslogtreecommitdiffstats
path: root/graphics
diff options
context:
space:
mode:
authorLibravatar Héctor Ramón Jiménez <hector0193@gmail.com>2023-04-19 02:00:45 +0200
committerLibravatar Héctor Ramón Jiménez <hector0193@gmail.com>2023-05-02 01:02:32 +0200
commit4bd290afe7d81d9aaf7467b3ce91491f6600261a (patch)
tree906bfe10f6118c86429c3bb83a8ce742dccb170a /graphics
parent33b5a900197e2798a393d6d9a0834039666eddbb (diff)
downloadiced-4bd290afe7d81d9aaf7467b3ce91491f6600261a.tar.gz
iced-4bd290afe7d81d9aaf7467b3ce91491f6600261a.tar.bz2
iced-4bd290afe7d81d9aaf7467b3ce91491f6600261a.zip
Introduce `text::Shaping` enum and replace magic boolean
Diffstat (limited to '')
-rw-r--r--graphics/src/backend.rs4
-rw-r--r--graphics/src/geometry/text.rs18
-rw-r--r--graphics/src/primitive.rs20
-rw-r--r--graphics/src/renderer.rs11
4 files changed, 20 insertions, 33 deletions
diff --git a/graphics/src/backend.rs b/graphics/src/backend.rs
index 0e107dd5..0c2a6d30 100644
--- a/graphics/src/backend.rs
+++ b/graphics/src/backend.rs
@@ -48,7 +48,7 @@ pub trait Text {
size: f32,
font: Font,
bounds: Size,
- advanced_shape: bool,
+ shaping: text::Shaping,
) -> (f32, f32);
/// Tests whether the provided point is within the boundaries of [`Text`]
@@ -64,9 +64,9 @@ pub trait Text {
size: f32,
font: Font,
bounds: Size,
+ shaping: text::Shaping,
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 f4af9ee4..0f731e74 100644
--- a/graphics/src/geometry/text.rs
+++ b/graphics/src/geometry/text.rs
@@ -1,5 +1,6 @@
-use iced_core::alignment;
-use iced_core::{Color, Font, Point};
+use crate::core::alignment;
+use crate::core::text::Shaping;
+use crate::core::{Color, Font, Point};
/// A bunch of text that can be drawn to a canvas
#[derive(Debug, Clone)]
@@ -25,15 +26,8 @@ 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,
+ /// The shaping strategy of the text.
+ pub shaping: Shaping,
}
impl Default for Text {
@@ -46,7 +40,7 @@ impl Default for Text {
font: Font::default(),
horizontal_alignment: alignment::Horizontal::Left,
vertical_alignment: alignment::Vertical::Top,
- advanced_shape: false,
+ shaping: Shaping::Basic,
}
}
}
diff --git a/graphics/src/primitive.rs b/graphics/src/primitive.rs
index 2d9c221b..db237035 100644
--- a/graphics/src/primitive.rs
+++ b/graphics/src/primitive.rs
@@ -1,7 +1,8 @@
-use iced_core::alignment;
-use iced_core::image;
-use iced_core::svg;
-use iced_core::{Background, Color, Font, Gradient, Rectangle, Size, Vector};
+use crate::core::alignment;
+use crate::core::image;
+use crate::core::svg;
+use crate::core::text;
+use crate::core::{Background, Color, Font, Gradient, Rectangle, Size, Vector};
use bytemuck::{Pod, Zeroable};
use std::sync::Arc;
@@ -26,15 +27,8 @@ 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,
+ /// The shaping strategy of the text.
+ shaping: text::Shaping,
},
/// A quad primitive
Quad {
diff --git a/graphics/src/renderer.rs b/graphics/src/renderer.rs
index 558e21dd..605286d6 100644
--- a/graphics/src/renderer.rs
+++ b/graphics/src/renderer.rs
@@ -138,10 +138,9 @@ where
size: f32,
font: Font,
bounds: Size,
- needs_shaping: bool,
+ shaping: text::Shaping,
) -> (f32, f32) {
- self.backend()
- .measure(content, size, font, bounds, needs_shaping)
+ self.backend().measure(content, size, font, bounds, shaping)
}
fn hit_test(
@@ -150,18 +149,18 @@ where
size: f32,
font: Font,
bounds: Size,
+ shaping: text::Shaping,
point: Point,
nearest_only: bool,
- advanced_shape: bool,
) -> Option<text::Hit> {
self.backend().hit_test(
content,
size,
font,
bounds,
+ shaping,
point,
nearest_only,
- advanced_shape,
)
}
@@ -178,7 +177,7 @@ where
font: text.font,
horizontal_alignment: text.horizontal_alignment,
vertical_alignment: text.vertical_alignment,
- advanced_shape: text.advanced_shape,
+ shaping: text.shaping,
});
}
}