Skip to main content

MaterialSwitch

Struct MaterialSwitch 

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

Material Design switch component following Material Design 3 specifications

Switches toggle the state of a single item on or off. They are the preferred way to adjust settings on mobile and should be used instead of checkboxes in most cases.

§Usage Examples

let mut wifi_enabled = false;
let mut bluetooth_enabled = true;

// Basic switch
ui.add(MaterialSwitch::new(&mut wifi_enabled));

// Switch with label text
ui.add(MaterialSwitch::new(&mut bluetooth_enabled)
    .text("Enable Bluetooth"));

// Disabled switch
let mut disabled_option = false;
ui.add(MaterialSwitch::new(&mut disabled_option)
    .text("Unavailable option")
    .enabled(false));

§Material Design Spec (Material 3)

  • Track width: 52dp, height: 32dp
  • Thumb diameter: 24dp when on, 16dp when off, 28dp when pressed
  • Corner radius: 16dp (fully rounded)
  • Touch target: 48x48dp minimum
  • Colors: Primary when on, surfaceContainerHighest when off
  • Track outline: 2dp when off, transparent when on
  • Icons: 16dp, displayed on thumb
  • Animation: 300ms cubic-bezier transition

Implementations§

Source§

impl<'a> MaterialSwitch<'a>

Source

pub fn new(selected: &'a mut bool) -> Self

Create a new Material Design switch

§Parameters
  • selected: Mutable reference to boolean state representing on/off
§Returns

A new MaterialSwitch instance with default settings

Source

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

Set optional text label for the switch

The text will be displayed to the right of the switch component.

§Parameters
  • text: Label text to display next to the switch
Source

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

Set whether the switch is enabled or disabled

Disabled switches cannot be interacted with and are visually dimmed.

§Parameters
  • enabled: True for interactive, false for disabled
Source

pub fn selected_icon(self, icon: char) -> Self

Set an icon to display on the thumb when the switch is selected (on)

§Parameters
  • icon: Character representing a Material icon to display on selected thumb
Source

pub fn unselected_icon(self, icon: char) -> Self

Set an icon to display on the thumb when the switch is unselected (off)

§Parameters
  • icon: Character representing a Material icon to display on unselected thumb
Source

pub fn with_icons(self, selected: char, unselected: char) -> Self

Set icons for both selected and unselected states

§Parameters
  • selected: Character representing a Material icon to display when on
  • unselected: Character representing a Material icon to display when off
Source

pub fn show_track_outline(self, show: bool) -> Self

Set whether to show track outline (Material 3 style)

§Parameters
  • show: True to show outline when off, false for no outline

Trait Implementations§

Source§

impl<'a> Widget for MaterialSwitch<'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 MaterialSwitch<'a>

§

impl<'a> RefUnwindSafe for MaterialSwitch<'a>

§

impl<'a> Send for MaterialSwitch<'a>

§

impl<'a> Sync for MaterialSwitch<'a>

§

impl<'a> Unpin for MaterialSwitch<'a>

§

impl<'a> UnsafeUnpin for MaterialSwitch<'a>

§

impl<'a> !UnwindSafe for MaterialSwitch<'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> DowncastSync for T
where T: Any + Send + Sync,

Source§

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

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<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