Skip to main content

Checkbox

Struct Checkbox 

Source
pub struct Checkbox<'a, Message, Theme = Theme, Renderer = Renderer>
where Renderer: Renderer, Theme: Catalog,
{ /* private fields */ }
Expand description

A box that can be checked.

§Example

use iced::widget::checkbox;

struct State {
   is_checked: bool,
}

enum Message {
    CheckboxToggled(bool),
}

fn view(state: &State) -> Element<'_, Message> {
    checkbox(state.is_checked)
        .label("Toggle me!")
        .on_toggle(Message::CheckboxToggled)
        .into()
}

fn update(state: &mut State, message: Message) {
    match message {
        Message::CheckboxToggled(is_checked) => {
            state.is_checked = is_checked;
        }
    }
}

Checkbox drawn by iced_wgpu

Implementations§

Source§

impl<'a, Message, Theme, Renderer> Checkbox<'a, Message, Theme, Renderer>
where Renderer: Renderer, Theme: Catalog,

Source

pub fn new(is_checked: bool) -> Self

Creates a new Checkbox.

It expects:

  • a boolean describing whether the Checkbox is checked or not
Source

pub fn label(self, label: impl IntoFragment<'a>) -> Self

Sets the label of the Checkbox.

Source

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

Sets the function that will be called when the Checkbox is toggled. It will receive the new state of the Checkbox and must produce a Message.

Unless on_toggle is called, the Checkbox will be disabled.

Source

pub fn on_toggle_maybe<F>(self, f: Option<F>) -> Self
where F: Fn(bool) -> Message + 'a,

Sets the function that will be called when the Checkbox is toggled, if Some.

If None, the checkbox will be disabled.

Source

pub fn size(self, size: impl Into<Pixels>) -> Self

Sets the size of the Checkbox.

Source

pub fn width(self, width: impl Into<Length>) -> Self

Sets the width of the Checkbox.

Source

pub fn spacing(self, spacing: impl Into<Pixels>) -> Self

Sets the spacing between the Checkbox and the text.

Source

pub fn text_size(self, text_size: impl Into<Pixels>) -> Self

Sets the text size of the Checkbox.

Source

pub fn line_height(self, line_height: impl Into<LineHeight>) -> Self

Sets the text text::LineHeight of the Checkbox.

Source

pub fn shaping(self, shaping: Shaping) -> Self

Sets the text::Shaping strategy of the Checkbox.

Source

pub fn wrapping(self, wrapping: Wrapping) -> Self

Sets the text::Wrapping strategy of the Checkbox.

Source

pub fn font(self, font: impl Into<Renderer::Font>) -> Self

Sets the Renderer::Font of the text of the Checkbox.

Source

pub fn icon(self, icon: Icon<Renderer::Font>) -> Self

Sets the Icon of the Checkbox.

Source

pub fn style(self, style: impl Fn(&Theme, Status) -> Style + 'a) -> Self
where Theme::Class<'a>: From<StyleFn<'a, Theme>>,

Sets the style of the Checkbox.

Source

pub fn class(self, class: impl Into<Theme::Class<'a>>) -> Self

Available on crate feature advanced only.

Sets the style class of the Checkbox.

Trait Implementations§

Source§

impl<'a, Message, Theme, Renderer> From<Checkbox<'a, Message, Theme, Renderer>> for Element<'a, Message, Theme, Renderer>
where Message: 'a, Theme: 'a + Catalog, Renderer: 'a + Renderer,

Source§

fn from( checkbox: Checkbox<'a, Message, Theme, Renderer>, ) -> Element<'a, Message, Theme, Renderer>

Converts to this type from the input type.
Source§

impl<Message, Theme, Renderer> Widget<Message, Theme, Renderer> for Checkbox<'_, Message, Theme, Renderer>
where Renderer: Renderer, Theme: Catalog,

Source§

fn tag(&self) -> Tag

Returns the Tag of the Widget.
Source§

fn state(&self) -> State

Returns the State of the Widget.
Source§

fn size(&self) -> Size<Length>

Returns the Size of the Widget in lengths.
Source§

fn layout( &mut self, tree: &mut Tree, renderer: &Renderer, limits: &Limits, ) -> Node

Returns the layout::Node of the Widget. Read more
Source§

fn update( &mut self, tree: &mut Tree, event: &Event, layout: Layout<'_>, cursor: Cursor, _renderer: &Renderer, shell: &mut Shell<'_, Message>, _viewport: &Rectangle, )

Processes a runtime Event. Read more
Source§

fn mouse_interaction( &self, _tree: &Tree, layout: Layout<'_>, cursor: Cursor, _viewport: &Rectangle, _renderer: &Renderer, ) -> Interaction

Returns the current mouse::Interaction of the Widget. Read more
Source§

fn draw( &self, tree: &Tree, renderer: &mut Renderer, theme: &Theme, defaults: &Style, layout: Layout<'_>, _cursor: Cursor, viewport: &Rectangle, )

Draws the Widget using the associated Renderer.
Source§

fn operate( &mut self, tree: &mut Tree, layout: Layout<'_>, _renderer: &Renderer, operation: &mut dyn Operation, )

Applies an Operation to the Widget.
Source§

fn size_hint(&self) -> Size<Length>

Returns a Size hint for laying out the Widget. Read more
Source§

fn children(&self) -> Vec<Tree>

Returns the state Tree of the children of the Widget.
Source§

fn diff(&self, tree: &mut Tree)

Reconciles the Widget with the provided Tree.
Source§

fn overlay<'a>( &'a mut self, _tree: &'a mut Tree, _layout: Layout<'a>, _renderer: &Renderer, _viewport: &Rectangle, _translation: Vector, ) -> Option<Element<'a, Message, Theme, Renderer>>

Returns the overlay of the Widget, if there is any.

Auto Trait Implementations§

§

impl<'a, Message, Theme, Renderer> Freeze for Checkbox<'a, Message, Theme, Renderer>
where <Theme as Catalog>::Class<'a>: Freeze, <Renderer as Renderer>::Font: Freeze,

§

impl<'a, Message, Theme = Theme, Renderer = Renderer> !RefUnwindSafe for Checkbox<'a, Message, Theme, Renderer>

§

impl<'a, Message, Theme = Theme, Renderer = Renderer> !Send for Checkbox<'a, Message, Theme, Renderer>

§

impl<'a, Message, Theme = Theme, Renderer = Renderer> !Sync for Checkbox<'a, Message, Theme, Renderer>

§

impl<'a, Message, Theme, Renderer> Unpin for Checkbox<'a, Message, Theme, Renderer>
where <Theme as Catalog>::Class<'a>: Unpin, <Renderer as Renderer>::Font: Unpin,

§

impl<'a, Message, Theme, Renderer> UnsafeUnpin for Checkbox<'a, Message, Theme, Renderer>
where <Theme as Catalog>::Class<'a>: UnsafeUnpin, <Renderer as Renderer>::Font: UnsafeUnpin,

§

impl<'a, Message, Theme = Theme, Renderer = Renderer> !UnwindSafe for Checkbox<'a, Message, Theme, Renderer>

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