Struct glyph_brush::Section

source ·
pub struct Section<'a, X = Extra> {
    pub screen_position: (f32, f32),
    pub bounds: (f32, f32),
    pub layout: Layout<BuiltInLineBreaker>,
    pub text: Vec<Text<'a, X>>,
}
Expand description

An object that contains all the info to render a varied section of text. That is one including many parts with differing fonts/scales/colors bowing to a single layout.

Example

use glyph_brush::{HorizontalAlign, Layout, Section, Text};

let section = Section::default()
    .add_text(Text::new("The last word was ").with_color([0.0, 0.0, 0.0, 1.0]))
    .add_text(Text::new("RED").with_color([1.0, 0.0, 0.0, 1.0]))
    .with_layout(Layout::default().h_align(HorizontalAlign::Center));

Extra

Extra text section data is stored in a generic type, default Extra. To use custom extra data ensure your custom type implements Debug, Clone, PartialEq & Hash.

Fields§

§screen_position: (f32, f32)

Position on screen to render text, in pixels from top-left. Defaults to (0, 0).

§bounds: (f32, f32)

Max (width, height) bounds, in pixels from top-left. Defaults to unbounded.

§layout: Layout<BuiltInLineBreaker>

Built in layout, can be overridden with custom layout logic see queue_custom_layout

§text: Vec<Text<'a, X>>

Text to render, rendered next to one another according the layout.

Implementations§

source§

impl<'a, X> Section<'a, X>

source

pub fn new() -> Self

source§

impl Section<'_, ()>

source

pub fn builder() -> SectionBuilder

Return a SectionBuilder to fluently build up a Section.

source§

impl<'a, X> Section<'a, X>

source

pub fn with_screen_position<P: Into<(f32, f32)>>(self, position: P) -> Self

source

pub fn with_bounds<P: Into<(f32, f32)>>(self, bounds: P) -> Self

source

pub fn with_layout<L: Into<Layout<BuiltInLineBreaker>>>(self, layout: L) -> Self

source

pub fn add_text<T: Into<Text<'a, X>>>(self, text: T) -> Self

source

pub fn with_text<X2>(self, text: Vec<Text<'_, X2>>) -> Section<'_, X2>

source§

impl<'text, X: Clone> Section<'text, X>

source

pub fn to_owned(&self) -> OwnedSection<X>

Trait Implementations§

source§

impl<'a, X: Clone> Clone for Section<'a, X>

source§

fn clone(&self) -> Section<'a, X>

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl<'a, X: Debug> Debug for Section<'a, X>

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Default for Section<'static, Extra>

source§

fn default() -> Self

Note this only works for X=Extra for more flexible use see Section::builder.

source§

impl<'a> From<&'a OwnedSection> for Section<'a>

source§

fn from(owned: &'a OwnedSection) -> Self

Converts to this type from the input type.
source§

impl<'a> From<&'a OwnedVariedSection> for Section<'a>

source§

fn from(owned: &'a OwnedVariedSection) -> Self

Converts to this type from the input type.
source§

impl<X> From<&Section<'_, X>> for SectionGeometry

source§

fn from(section: &Section<'_, X>) -> Self

Converts to this type from the input type.
source§

impl<'a> From<&Section<'a>> for Section<'a>

source§

fn from(s: &Section<'a>) -> Self

Converts to this type from the input type.
source§

impl<'a> From<&Section<'a>> for VariedSection<'a>

source§

fn from(s: &Section<'a>) -> Self

Converts to this type from the input type.
source§

impl<'a, 'b, X: Clone> From<&'b Section<'a, X>> for Cow<'b, Section<'a, X>>

source§

fn from(owned: &'b Section<'a, X>) -> Self

Converts to this type from the input type.
source§

impl<'a> From<&VariedSection<'a>> for Section<'a>

source§

fn from(s: &VariedSection<'a>) -> Self

Converts to this type from the input type.
source§

impl<'a> From<Section<'a>> for Section<'a>

source§

fn from(s: Section<'a>) -> Self

Converts to this type from the input type.
source§

impl<'a, X: Clone> From<Section<'a, X>> for Cow<'a, Section<'a, X>>

source§

fn from(owned: Section<'a, X>) -> Self

Converts to this type from the input type.
source§

impl<'a, X> From<Text<'a, X>> for Section<'a, X>

source§

fn from(text: Text<'a, X>) -> Self

Converts to this type from the input type.
source§

impl<'a> From<VariedSection<'a>> for Section<'a>

source§

fn from(s: VariedSection<'a>) -> Self

Converts to this type from the input type.
source§

impl<'a, X> From<Vec<Text<'a, X>>> for Section<'a, X>

source§

fn from(text: Vec<Text<'a, X>>) -> Self

Converts to this type from the input type.
source§

impl<X: Hash> Hash for Section<'_, X>

source§

fn hash<H: Hasher>(&self, state: &mut H)

Feeds this value into the given Hasher. Read more
1.3.0 · source§

fn hash_slice<H>(data: &[Self], state: &mut H)where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
source§

impl<'a, X: PartialEq> PartialEq for Section<'a, X>

source§

fn eq(&self, other: &Section<'a, X>) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl<'a, X> StructuralPartialEq for Section<'a, X>

Auto Trait Implementations§

§

impl<'a, X> RefUnwindSafe for Section<'a, X>where X: RefUnwindSafe,

§

impl<'a, X> Send for Section<'a, X>where X: Send,

§

impl<'a, X> Sync for Section<'a, X>where X: Sync,

§

impl<'a, X> Unpin for Section<'a, X>where X: Unpin,

§

impl<'a, X> UnwindSafe for Section<'a, X>where X: UnwindSafe,

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

§

impl<T> Pointable for T

§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
source§

impl<T> ToOwned for Twhere T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for Twhere U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<V, T> VZip<V> for Twhere V: MultiLane<T>,

§

fn vzip(self) -> V