summaryrefslogtreecommitdiffstats
path: root/glow/src/renderer/widget/text.rs
diff options
context:
space:
mode:
Diffstat (limited to 'glow/src/renderer/widget/text.rs')
-rw-r--r--glow/src/renderer/widget/text.rs61
1 files changed, 61 insertions, 0 deletions
diff --git a/glow/src/renderer/widget/text.rs b/glow/src/renderer/widget/text.rs
new file mode 100644
index 00000000..4605ed06
--- /dev/null
+++ b/glow/src/renderer/widget/text.rs
@@ -0,0 +1,61 @@
+use crate::{Primitive, Renderer};
+use iced_native::{
+ mouse, text, Color, Font, HorizontalAlignment, Rectangle, Size,
+ VerticalAlignment,
+};
+
+use std::f32;
+
+impl text::Renderer for Renderer {
+ type Font = Font;
+
+ const DEFAULT_SIZE: u16 = 20;
+
+ fn measure(
+ &self,
+ content: &str,
+ size: u16,
+ font: Font,
+ bounds: Size,
+ ) -> (f32, f32) {
+ self.text_pipeline
+ .measure(content, f32::from(size), font, bounds)
+ }
+
+ fn draw(
+ &mut self,
+ defaults: &Self::Defaults,
+ bounds: Rectangle,
+ content: &str,
+ size: u16,
+ font: Font,
+ color: Option<Color>,
+ horizontal_alignment: HorizontalAlignment,
+ vertical_alignment: VerticalAlignment,
+ ) -> Self::Output {
+ let x = match horizontal_alignment {
+ iced_native::HorizontalAlignment::Left => bounds.x,
+ iced_native::HorizontalAlignment::Center => bounds.center_x(),
+ iced_native::HorizontalAlignment::Right => bounds.x + bounds.width,
+ };
+
+ let y = match vertical_alignment {
+ iced_native::VerticalAlignment::Top => bounds.y,
+ iced_native::VerticalAlignment::Center => bounds.center_y(),
+ iced_native::VerticalAlignment::Bottom => bounds.y + bounds.height,
+ };
+
+ (
+ Primitive::Text {
+ content: content.to_string(),
+ size: f32::from(size),
+ bounds: Rectangle { x, y, ..bounds },
+ color: color.unwrap_or(defaults.text.color),
+ font,
+ horizontal_alignment,
+ vertical_alignment,
+ },
+ mouse::Interaction::default(),
+ )
+ }
+}