Merge pull request #2158 from iced-rs/feature/raw-text-primitive
Introduce `RawText` to `Primitive` in `iced_graphics`
This commit is contained in:
commit
a5ae442819
8 changed files with 131 additions and 4 deletions
|
|
@ -73,6 +73,11 @@ impl<T: Damage> Damage for Primitive<T> {
|
|||
|
||||
bounds.expand(1.5)
|
||||
}
|
||||
Self::RawText(raw) => {
|
||||
// TODO: Add `size` field to `raw` to compute more accurate
|
||||
// damage bounds (?)
|
||||
raw.clip_bounds.expand(1.5)
|
||||
}
|
||||
Self::Quad { bounds, .. }
|
||||
| Self::Image { bounds, .. }
|
||||
| Self::Svg { bounds, .. } => bounds.expand(1.0),
|
||||
|
|
|
|||
|
|
@ -57,6 +57,8 @@ pub enum Primitive<T> {
|
|||
/// The clip bounds of the editor.
|
||||
clip_bounds: Rectangle,
|
||||
},
|
||||
/// A raw `cosmic-text` primitive
|
||||
RawText(crate::text::Raw),
|
||||
/// A quad primitive
|
||||
Quad {
|
||||
/// The bounds of the quad
|
||||
|
|
|
|||
|
|
@ -12,11 +12,11 @@ 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 +68,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
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue