Trait kas_text::format::FormattableText
source · pub trait FormattableText: Debug {
type FontTokenIter<'a>: Iterator<Item = FontToken>
where
Self: 'a;
fn as_str(&self) -> &str;
fn font_tokens<'a>(&'a self, dpem: f32) -> Self::FontTokenIter<'a>;
fn effect_tokens(&self) -> &[Effect<()>];
fn str_len(&self) -> usize { ... }
}
Expand description
Text, optionally with formatting data
Any F: FormattableText
automatically support FormattableTextDyn
.
Implement either this or FormattableTextDyn
, not both.
Required Associated Types§
type FontTokenIter<'a>: Iterator<Item = FontToken>
where
Self: 'a
Required Methods§
sourcefn font_tokens<'a>(&'a self, dpem: f32) -> Self::FontTokenIter<'a>
fn font_tokens<'a>(&'a self, dpem: f32) -> Self::FontTokenIter<'a>
Construct an iterator over formatting items
It is expected that FontToken::start
of yielded items is strictly
increasing; if not, formatting may not be applied correctly.
The dpem
parameter is font size as in crate::Environment
.
For plain text this iterator will be empty.
sourcefn effect_tokens(&self) -> &[Effect<()>]
fn effect_tokens(&self) -> &[Effect<()>]
Get the sequence of effect tokens
This method has some limitations: (1) it may only return a reference to
an existing sequence, (2) effect tokens cannot be generated dependent
on input state, and (3) it does not incorporate color information. For
most uses it should still be sufficient, but for other cases it may be
preferable not to use this method (use a dummy implementation returning
&[]
and use inherent methods on the text object via Text::text
).
Provided Methods§
sourcefn str_len(&self) -> usize
fn str_len(&self) -> usize
Length of text
Default implementation uses FormattableText::as_str
.