BigText

Struct BigText 

Source
#[non_exhaustive]
pub struct BigText<'a> { pub lines: Vec<Line<'a>>, pub style: Style, pub pixel_size: PixelSize, pub alignment: Alignment, }
Expand description

Displays one or more lines of text using 8x8 pixel characters.

The text is rendered using the font8x8 crate.

Using the pixel_size method, you can also chose, how ‘big’ a pixel should be. Currently a pixel of the 8x8 font can be represented by one full or half (horizontal/vertical/both) character cell of the terminal.

§Examples

use ratatui::prelude::*;
use tui_big_text::{BigText, PixelSize};

BigText::builder()
    .pixel_size(PixelSize::Full)
    .style(Style::new().white())
    .lines(vec![
        "Hello".red().into(),
        "World".blue().into(),
        "=====".into(),
    ])
    .build();

Renders:

██  ██           ███     ███
██  ██            ██      ██
██  ██   ████     ██      ██     ████
██████  ██  ██    ██      ██    ██  ██
██  ██  ██████    ██      ██    ██  ██
██  ██  ██        ██      ██    ██  ██
██  ██   ████    ████    ████    ████

██   ██                  ███       ███
██   ██                   ██        ██
██   ██  ████   ██ ███    ██        ██
██ █ ██ ██  ██   ███ ██   ██     █████
███████ ██  ██   ██  ██   ██    ██  ██
███ ███ ██  ██   ██       ██    ██  ██
██   ██  ████   ████     ████    ███ ██

 ███ ██  ███ ██  ███ ██  ███ ██  ███ ██
██ ███  ██ ███  ██ ███  ██ ███  ██ ███

Fields (Non-exhaustive)§

This struct is marked as non-exhaustive
Non-exhaustive structs could have additional fields added in future. Therefore, non-exhaustive structs cannot be constructed in external crates using the traditional Struct { .. } syntax; cannot be matched against without a wildcard ..; and struct update syntax will not work.
§lines: Vec<Line<'a>>

The text to display

§style: Style

The style of the widget

Defaults to Style::default()

§pixel_size: PixelSize

The size of single glyphs

Defaults to PixelSize::default() (=> PixelSize::Full)

§alignment: Alignment

The horizontal alignment of the text

Defaults to Alignment::default() (=> Alignment::Left)

Implementations§

Source§

impl BigText<'static>

Source

pub fn builder() -> BigTextBuilder<'static>

Create a new BigTextBuilder to configure a BigText widget.

Trait Implementations§

Source§

impl<'a> Clone for BigText<'a>

Source§

fn clone(&self) -> BigText<'a>

Returns a duplicate 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> Debug for BigText<'a>

Source§

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

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

impl<'a> Hash for BigText<'a>

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> PartialEq for BigText<'a>

Source§

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

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

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

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Widget for BigText<'_>

Source§

fn render(self, area: Rect, buf: &mut Buffer)

Draws the current state of the widget in the given buffer. That is the only method required to implement a custom widget.
Source§

impl<'a> Eq for BigText<'a>

Source§

impl<'a> StructuralPartialEq for BigText<'a>

Auto Trait Implementations§

§

impl<'a> Freeze for BigText<'a>

§

impl<'a> RefUnwindSafe for BigText<'a>

§

impl<'a> Send for BigText<'a>

§

impl<'a> Sync for BigText<'a>

§

impl<'a> Unpin for BigText<'a>

§

impl<'a> UnwindSafe for BigText<'a>

Blanket Implementations§

Source§

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

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

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

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

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

Source§

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

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where 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.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

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 T
where U: Into<T>,

Source§

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 T
where U: TryFrom<T>,

Source§

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.