diff options
| author | 2024-01-16 12:02:42 +0100 | |
|---|---|---|
| committer | 2024-01-16 12:02:42 +0100 | |
| commit | 534c7dd7b0bc515c31b6de87b4aa6a35b44c46a0 (patch) | |
| tree | 0ddc8f1b681cbade7e47293bd46a362896aa538a /graphics/src/text | |
| 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 '')
| -rw-r--r-- | graphics/src/text.rs | 37 | ||||
| -rw-r--r-- | graphics/src/text/paragraph.rs | 25 | 
2 files changed, 42 insertions, 20 deletions
| diff --git a/graphics/src/text.rs b/graphics/src/text.rs index fc7694c2..7c4b5e31 100644 --- a/graphics/src/text.rs +++ b/graphics/src/text.rs @@ -9,14 +9,13 @@ pub use paragraph::Paragraph;  pub use cosmic_text; -use crate::color;  use crate::core::font::{self, Font};  use crate::core::text::Shaping; -use crate::core::{Color, Size}; +use crate::core::{Color, Point, Rectangle, Size};  use once_cell::sync::OnceCell;  use std::borrow::Cow; -use std::sync::{Arc, RwLock}; +use std::sync::{Arc, RwLock, Weak};  /// Returns the global [`FontSystem`].  pub fn font_system() -> &'static RwLock<FontSystem> { @@ -68,6 +67,29 @@ impl FontSystem {  #[derive(Debug, Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Hash, Default)]  pub struct Version(u32); +/// A weak reference to a [`cosmic-text::Buffer`] that can be drawn. +#[derive(Debug, Clone)] +pub struct Raw { +    /// A weak reference to a [`cosmic_text::Buffer`]. +    pub buffer: Weak<cosmic_text::Buffer>, +    /// The position of the text. +    pub position: Point, +    /// The color of the text. +    pub color: Color, +    /// The clip bounds of the text. +    pub clip_bounds: Rectangle, +} + +impl PartialEq for Raw { +    fn eq(&self, _other: &Self) -> bool { +        // TODO: There is no proper way to compare raw buffers +        // For now, no two instances of `Raw` text will be equal. +        // This should be fine, but could trigger unnecessary redraws +        // in the future. +        false +    } +} +  /// Measures the dimensions of the given [`cosmic_text::Buffer`].  pub fn measure(buffer: &cosmic_text::Buffer) -> Size {      let (width, total_lines) = buffer @@ -150,12 +172,7 @@ pub fn to_shaping(shaping: Shaping) -> cosmic_text::Shaping {  /// Converts some [`Color`] to a [`cosmic_text::Color`].  pub fn to_color(color: Color) -> cosmic_text::Color { -    let [r, g, b, a] = color::pack(color).components(); +    let [r, g, b, a] = color.into_rgba8(); -    cosmic_text::Color::rgba( -        (r * 255.0) as u8, -        (g * 255.0) as u8, -        (b * 255.0) as u8, -        (a * 255.0) as u8, -    ) +    cosmic_text::Color::rgba(r, g, b, a)  } diff --git a/graphics/src/text/paragraph.rs b/graphics/src/text/paragraph.rs index 4a08a8f4..5d027542 100644 --- a/graphics/src/text/paragraph.rs +++ b/graphics/src/text/paragraph.rs @@ -187,38 +187,43 @@ impl core::text::Paragraph for Paragraph {      }      fn grapheme_position(&self, line: usize, index: usize) -> Option<Point> { +        use unicode_segmentation::UnicodeSegmentation; +          let run = self.internal().buffer.layout_runs().nth(line)?;          // index represents a grapheme, not a glyph          // Let's find the first glyph for the given grapheme cluster          let mut last_start = None; +        let mut last_grapheme_count = 0;          let mut graphemes_seen = 0;          let glyph = run              .glyphs              .iter()              .find(|glyph| { -                if graphemes_seen == index { -                    return true; -                } -                  if Some(glyph.start) != last_start { +                    last_grapheme_count = run.text[glyph.start..glyph.end] +                        .graphemes(false) +                        .count();                      last_start = Some(glyph.start); -                    graphemes_seen += 1; +                    graphemes_seen += last_grapheme_count;                  } -                false +                graphemes_seen >= index              })              .or_else(|| run.glyphs.last())?; -        let advance_last = if index == run.glyphs.len() { -            glyph.w -        } else { +        let advance = if index == 0 {              0.0 +        } else { +            glyph.w +                * (1.0 +                    - graphemes_seen.saturating_sub(index) as f32 +                        / last_grapheme_count.max(1) as f32)          };          Some(Point::new( -            glyph.x + glyph.x_offset * glyph.font_size + advance_last, +            glyph.x + glyph.x_offset * glyph.font_size + advance,              glyph.y - glyph.y_offset * glyph.font_size,          ))      } | 
