Skip to main content

IconSpec

Struct IconSpec 

Source
pub struct IconSpec {
    pub glyph: Cow<'static, str>,
    pub font: Option<Font>,
    pub size: Option<f32>,
}
Expand description

Description of how to render an icon for a particular IconRole.

Constructed by an IconTheme. The widget takes the spec and emits an iced text element using glyph, optionally setting the specified font and size. When font is None, the glyph renders in the default iced font. When size is None, the widget picks its own default (currently 14).

Use IconSpec::new + IconSpec::with_font / IconSpec::with_size for ergonomic construction:

let spec = IconSpec::new("\u{E89C}").with_size(16.0);
assert_eq!(spec.glyph.as_ref(), "\u{E89C}");

Fields are pub so const themes can construct specs literally — but note that adding fields here is a breaking change, so we don’t expect to add new fields before a hypothetical 2.0.

Fields§

§glyph: Cow<'static, str>

The text to render. A single char for typical icons; longer strings are supported (e.g. ligatures, emoji sequences, labels like "DIR").

Cow<'static, str> so themes can use &'static str literals at no allocation cost, while still accepting owned Strings for dynamically constructed glyphs.

§font: Option<Font>

The font to render glyph in, or None for the iced default. Themes using icon-font packs (lucide-icons, Material Design Icons, …) must set this or the glyph codepoints will render as tofu.

§size: Option<f32>

The point size to render at, or None to let the widget pick (currently 14). Themes using larger/smaller glyphs than the default can set this to match their intended visual balance.

Implementations§

Source§

impl IconSpec

Source

pub fn new(glyph: impl Into<Cow<'static, str>>) -> Self

Build a spec from a glyph string. Font and size are None by default — the widget will render in the iced default font at its default size.

Examples found in repository?
examples/icon_theme.rs (line 51)
39    fn glyph(&self, role: IconRole) -> IconSpec {
40        // External theme → include a `_ =>` fallback for future
41        // variants added in a minor release.
42        let s: &'static str = match role {
43            IconRole::FolderClosed => "[D]",
44            IconRole::FolderOpen => "[O]",
45            IconRole::File => "[F]",
46            IconRole::Error => "[!]",
47            IconRole::CaretRight => ">",
48            IconRole::CaretDown => "v",
49            _ => "?",
50        };
51        IconSpec::new(s)
52    }
53}
54
55/// Custom theme: ultra-compact ASCII. Shows that a theme doesn't
56/// need to pull in an icon font — plain text works fine if the
57/// glyphs exist in the default system font.
58#[derive(Debug)]
59struct AsciiTheme;
60
61impl IconTheme for AsciiTheme {
62    fn glyph(&self, role: IconRole) -> IconSpec {
63        let s: &'static str = match role {
64            IconRole::FolderClosed => "+",
65            IconRole::FolderOpen => "-",
66            IconRole::File => ".",
67            IconRole::Error => "!",
68            IconRole::CaretRight => ">",
69            IconRole::CaretDown => "v",
70            _ => "?",
71        };
72        IconSpec::new(s)
73    }
Source

pub fn with_font(self, font: Font) -> Self

Set the font used to render the glyph. Required for icon-font packs where the codepoint is only valid in a specific font.

Source

pub fn with_size(self, size: f32) -> Self

Set the point size. None (the default) means the widget picks — currently 14.

Trait Implementations§

Source§

impl Clone for IconSpec

Source§

fn clone(&self) -> IconSpec

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 Debug for IconSpec

Source§

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

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

impl PartialEq for IconSpec

Source§

fn eq(&self, other: &IconSpec) -> 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 StructuralPartialEq for IconSpec

Auto Trait Implementations§

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<T> Downcast<T> for T

Source§

fn downcast(&self) -> &T

Source§

impl<T> Downcast for T
where T: Any,

Source§

fn into_any(self: Box<T>) -> Box<dyn Any>

Convert Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.
Source§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

Convert Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be further downcast into Rc<ConcreteType> where ConcreteType implements Trait.
Source§

fn as_any(&self) -> &(dyn Any + 'static)

Convert &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &Any’s vtable from &Trait’s.
Source§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Convert &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
Source§

impl<T> DowncastSync for T
where T: Any + Send + Sync,

Source§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Send + Sync>

Convert Arc<Trait> (where Trait: Downcast) to Arc<Any>. Arc<Any> can then be further downcast into Arc<ConcreteType> where ConcreteType implements Trait.
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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<State, Message> IntoBoot<State, Message> for State

Source§

fn into_boot(self) -> (State, Task<Message>)

Turns some type into the initial state of some Application.
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> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

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

Initializes a with the given initializer. Read more
Source§

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

Dereferences the given pointer. Read more
Source§

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

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. 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.
Source§

impl<T> Upcast<T> for T

Source§

fn upcast(&self) -> Option<&T>

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

impl<T> MaybeClone for T

Source§

impl<T> MaybeDebug for T

Source§

impl<T> MaybeSend for T
where T: Send,

Source§

impl<T> MaybeSync for T
where T: Sync,

Source§

impl<T> WasmNotSend for T
where T: Send,

Source§

impl<T> WasmNotSendSync for T

Source§

impl<T> WasmNotSync for T
where T: Sync,