Struct vizia::views::Checkbox

source ·
pub struct Checkbox { /* private fields */ }
Expand description

A checkbox used to display and toggle a boolean state.

Pressing the checkbox triggers the on_toggle callback.

§Examples

§Basic checkbox

The checkbox must bound to some boolean data.

Checkbox::new(cx, AppData::value);

§Checkbox with an action

A checkbox can be used to trigger a callback when toggled. Usually this is emitting an event responsible for changing the data the checkbox is bound to.

Checkbox::new(cx, AppData::value).on_toggle(|cx| cx.emit(AppEvent::ToggleValue));

§Checkbox with a label

A checkbox is usually used with a label next to it describing what data the checkbox is bound to or what the checkbox does when pressed. This can be done, for example, by wrapping the checkbox in an HStack and adding a Label to it.

The Label can be used to trigger the checkbox by assigning the checkbox an id name and using it with the describing modifier on the label.

HStack::new(cx, |cx| {
    Checkbox::new(cx, AppData::value).id("check1");
    Label::new(cx, "Press me").describing("check1");
});

§Custom checkbox

The with_icons constructor can be used to create a checkbox with custom icons for both checked and unchecked states.


Checkbox::with_icons(cx, AppData::value, None, Some(ICON_X))
    .on_toggle(|cx| cx.emit(AppEvent::ToggleValue));

Implementations§

source§

impl Checkbox

source

pub fn new( cx: &mut Context, checked: impl Lens<Target = bool>, ) -> Handle<'_, Checkbox>

Creates a new checkbox.

§Examples
Checkbox::new(cx, AppData::value);
source

pub fn with_icons<T>( cx: &mut Context, checked: impl Lens<Target = bool>, icon_default: Option<impl Res<T> + Clone + 'static>, icon_checked: Option<impl Res<T> + Clone + 'static>, ) -> Handle<'_, Checkbox>
where T: AsRef<[u8]> + 'static,

Creates a new checkbox with custom icons for both checked and unchecked states.

§Examples

Checkbox::with_icons(cx, AppData::value, None, Some(ICON_X))
    .on_toggle(|cx| cx.emit(AppEvent::ToggleValue));
source

pub fn intermediate( cx: &mut Context, checked: impl Lens<Target = bool>, intermediate: impl Lens<Target = bool>, ) -> Handle<'_, Checkbox>

Trait Implementations§

source§

impl View for Checkbox

source§

fn element(&self) -> Option<&'static str>

Specifies a name for the view type which can be used as an element selector in css. Read more
source§

fn event(&mut self, cx: &mut EventContext<'_>, event: &mut Event)

Handles any events received by the view. Read more
source§

fn build<F>(self, cx: &mut Context, content: F) -> Handle<'_, Self>
where F: FnOnce(&mut Context),

Builds the view into the tree and returns a handle which can be used to apply style and layout modifiers to the view. Read more
source§

fn draw(&self, cx: &mut DrawContext<'_>, canvas: &Canvas)

Provides custom drawing for the view. Read more
source§

fn accessibility(&self, cx: &mut AccessContext<'_>, node: &mut AccessNode)

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
§

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

§

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

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

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

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.

§

impl<T> Instrument for T

§

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

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

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

§

type Output = T

Should always be Self
source§

impl<T, U> TryFrom<U> for T
where 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 T
where 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<T> WithSubscriber for T

§

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
§

fn with_current_subscriber(self) -> WithDispatch<Self>

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