Skip to main content

MaterialFab

Struct MaterialFab 

Source
pub struct MaterialFab<'a> { /* private fields */ }
Expand description

Material Design Floating Action Button (FAB) component

FABs help users take primary actions within an app. They appear in front of all screen content, typically as a circular button with an icon in the center.

§Usage Examples

// Primary FAB with add icon
ui.add(MaterialFab::primary()
    .icon("add")
    .action(|| println!("Add clicked")));

// Extended FAB with text
ui.add(MaterialFab::primary()
    .size(FabSize::Extended)
    .icon("edit")
    .text("Compose")
    .action(|| println!("Compose clicked")));

// Large FAB for prominent action
ui.add(MaterialFab::primary()
    .size(FabSize::Large)
    .icon("camera")
    .action(|| println!("Camera clicked")));

§Material Design Spec

  • Elevation: 6dp (raised above content)
  • Corner radius: 50% (fully rounded)
  • Sizes: Small (40dp), Regular (56dp), Large (96dp), Extended (≥80dp)
  • Icon size: 24dp for regular, 32dp for large
  • Placement: 16dp from screen edge, above navigation bars

Implementations§

Source§

impl<'a> MaterialFab<'a>

Source

pub fn new(variant: FabVariant) -> Self

Create a new FAB with the specified variant

§Parameters
  • variant: The color variant to use for the FAB
Source

pub fn surface() -> Self

Create a surface FAB

Source

pub fn primary() -> Self

Create a primary FAB

Source

pub fn secondary() -> Self

Create a secondary FAB

Source

pub fn tertiary() -> Self

Create a tertiary FAB

Source

pub fn branded() -> Self

Create a branded FAB

Source

pub fn size(self, size: FabSize) -> Self

Set the size of the FAB

Source

pub fn icon(self, icon: impl Into<String>) -> Self

Set the icon of the FAB

Source

pub fn text(self, text: impl Into<String>) -> Self

Set the text of the FAB (for extended FABs)

Source

pub fn enabled(self, enabled: bool) -> Self

Enable or disable the FAB

Source

pub fn lowered(self, _lowered: bool) -> Self

Set the lowered state of the FAB (elevation effect)

Source

pub fn svg_icon(self, svg_icon: SvgIcon) -> Self

Set a custom SVG icon for the FAB

Source

pub fn on_click<F>(self, f: F) -> Self
where F: Fn() + 'a,

Set the action to perform when the FAB is clicked

Trait Implementations§

Source§

impl<'a> Widget for MaterialFab<'a>

Source§

fn ui(self, ui: &mut Ui) -> Response

Allocate space, interact, paint, and return a Response. Read more

Auto Trait Implementations§

§

impl<'a> Freeze for MaterialFab<'a>

§

impl<'a> !RefUnwindSafe for MaterialFab<'a>

§

impl<'a> !Send for MaterialFab<'a>

§

impl<'a> !Sync for MaterialFab<'a>

§

impl<'a> Unpin for MaterialFab<'a>

§

impl<'a> UnsafeUnpin for MaterialFab<'a>

§

impl<'a> !UnwindSafe for MaterialFab<'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> 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> 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<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> 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