Skip to main content

Flow

Struct Flow 

Source
pub struct Flow<C: Collection, D: Directional> { /* private fields */ }
Expand description

Rows or columns of content with line-splitting

This widget is a variant of List, arranging a linear Collection of children into multiple rows or columns with automatic splitting. Unlike Grid, items are not aligned across lines.

When the collection uses Vec, various methods to insert/remove elements are available.

§Layout details

Currently only horizontal lines (rows) which wrap down to the next line are supported.

Width requirements depend on the desired numbers of columns; see Self::set_num_columns.

Items within each line are stretched (if any has non-zero Stretch priority) in accordance with SizeRules::solve_widths. It is not currently possible to adjust this (except by tweaking the stretchiness of items).

§Performance

Sizing, drawing and event handling are all O(n) where n is the number of children.

§Example

use kas::collection;

let list = Flow::right(collection![
    "A checkbox",
    CheckBox::new(|_, state: &bool| *state),
]);

Implementations§

Source§

impl<C: Collection, D> Flow<C, D>
where D: Default + Directional,

Source

pub fn new(widgets: C) -> Self

Construct a new instance with default-constructed direction

This constructor is available where the direction is determined by the type: for D: Directional + Default. The wrap direction is down or right.

§Examples

Where widgets have the same type and the length is fixed, an array may be used:

use kas_widgets::{Label, Row};
let _ = Row::new([Label::new("left"), Label::new("right")]);

To support run-time insertion/deletion, use Vec:

use kas_widgets::{AdaptWidget, Button, Row};

#[derive(Clone, Debug)]
enum Msg {
    Add,
    Remove,
}

let _ = Row::new(vec![Button::label_msg("Add", Msg::Add)])
    .on_messages(|cx, row, data| {
        if let Some(msg) = cx.try_pop() {
            match msg {
                Msg::Add => {
                    let button = if row.len() % 2 == 0 {
                        Button::label_msg("Add", Msg::Add)
                    } else {
                        Button::label_msg("Remove", Msg::Remove)
                    };
                    row.push(cx, data, button);
                }
                Msg::Remove => {
                    let _ = row.pop(cx);
                }
            }
        }
    });
Source§

impl<C: Collection> Flow<C, Left>

Source

pub fn left(widgets: C) -> Self

Construct a new instance with fixed direction

Lines flow from right-to-left, wrapping down.

Source§

impl<C: Collection> Flow<C, Right>

Source

pub fn right(widgets: C) -> Self

Construct a new instance with fixed direction

Lines flow from left-to-right, wrapping down.

Source§

impl<C: Collection, D: Directional> Flow<C, D>

Source

pub fn new_dir(widgets: C, direction: D) -> Self

Construct a new instance with explicit direction

Source

pub fn set_num_columns(&mut self, min: i32, ideal: i32)

Set the (minimum, ideal) numbers of columns

This affects the final SizeRules for the horizontal axis.

By default, the values 1, 3 are used.

Source

pub fn with_num_columns(self, min: i32, ideal: i32) -> Self

Set the (minimum, ideal) numbers of columns (inline)

This affects the final SizeRules for the horizontal axis.

By default, the values 1, 3 are used.

Source

pub fn is_empty(&self) -> bool

True if there are no child widgets

Source

pub fn len(&self) -> usize

Returns the number of child widgets

Source§

impl<W: Widget, D: Directional> Flow<Vec<W>, D>

Source

pub fn get(&self, index: usize) -> Option<&W>

Returns a reference to the child, if any

Source

pub fn get_mut(&mut self, index: usize) -> Option<&mut W>

Returns a mutable reference to the child, if any

Source

pub fn clear(&mut self)

Remove all child widgets

Source

pub fn push( &mut self, cx: &mut ConfigCx<'_>, data: &W::Data, widget: W, ) -> usize

Append a child widget

The new child is configured immediately. Triggers a resize.

Returns the new element’s index.

Source

pub fn pop(&mut self, cx: &mut ConfigCx<'_>) -> Option<W>

Remove the last child widget (if any) and return

Triggers a resize.

Source

pub fn insert( &mut self, cx: &mut ConfigCx<'_>, data: &W::Data, index: usize, widget: W, )

Inserts a child widget position index

Panics if index > len.

The new child is configured immediately. Triggers a resize.

Source

pub fn remove(&mut self, cx: &mut ConfigCx<'_>, index: usize) -> W

Removes the child widget at position index

Panics if index is out of bounds.

Triggers a resize.

Source

pub fn truncate(&mut self, cx: &mut ConfigCx<'_>, len: usize)

Removes all children at positions ≥ len

Does nothing if self.len() < len.

Triggers a resize.

Source

pub fn replace( &mut self, cx: &mut ConfigCx<'_>, data: &W::Data, index: usize, widget: W, ) -> W

Replace the child at index

Panics if index is out of bounds.

The new child is configured immediately. Triggers a resize.

Source

pub fn extend<T>(&mut self, cx: &mut ConfigCx<'_>, data: &W::Data, iter: T)
where T: IntoIterator<Item = W>,

Append child widgets from an iterator

New children are configured immediately. Triggers a resize.

Source

pub fn resize_with<F>( &mut self, cx: &mut ConfigCx<'_>, data: &W::Data, len: usize, f: F, )
where F: Fn(usize) -> W,

Resize, using the given closure to construct new widgets

New children are configured immediately. Triggers a resize.

Source

pub fn iter(&self) -> impl Iterator<Item = &W>

Iterate over childern

Source

pub fn iter_mut(&mut self) -> impl Iterator<Item = &mut W>

Mutably iterate over childern

Trait Implementations§

Source§

impl<C, D> Default for Flow<C, D>

Source§

fn default() -> Self

Returns the “default value” for a type. Read more
Source§

impl<W: Widget, D: Directional> Index<usize> for Flow<Vec<W>, D>

Source§

type Output = W

The returned type after indexing.
Source§

fn index(&self, index: usize) -> &Self::Output

Performs the indexing (container[index]) operation. Read more
Source§

impl<W: Widget, D: Directional> IndexMut<usize> for Flow<Vec<W>, D>

Source§

fn index_mut(&mut self, index: usize) -> &mut Self::Output

Performs the mutable indexing (container[index]) operation. Read more
Source§

impl<C: Collection, D: Directional> Layout for Flow<C, D>

Source§

fn size_rules(&mut self, cx: &mut SizeCx<'_>, axis: AxisInfo) -> SizeRules

Calculate size requirements for an axis Read more
Source§

fn set_rect(&mut self, cx: &mut SizeCx<'_>, rect: Rect, hints: AlignHints)

Set size and position Read more
Source§

fn draw(&self, draw: DrawCx<'_>)

Draw a widget and its children Read more
Source§

fn rect(&self) -> Rect

Get the widget’s region Read more
Source§

impl<C: Collection, D: Directional> Tile for Flow<C, D>

Source§

fn try_probe(&self, coord: Coord) -> Option<Id>

Probe a coordinate for a widget’s Id Read more
Source§

fn as_tile(&self) -> &dyn Tile

Get as a dyn Tile Read more
Source§

fn id_ref(&self) -> &Id

Get a reference to the widget’s identifier Read more
Source§

fn id(&self) -> Id

Get the widget’s identifier Read more
Source§

fn identify(&self) -> IdentifyWidget<'_>

Return a Display-able widget identifier Read more
Source§

fn child_indices(&self) -> ChildIndices

Get child indices available to recursion Read more
Source§

fn get_child(&self, index: usize) -> Option<&dyn Tile>

Access a child as a dyn Tile, if available Read more
Source§

fn find_child_index(&self, id: &Id) -> Option<usize>

Find the child which is an ancestor of this id, if any Read more
Source§

fn translation(&self, index: usize) -> Offset

Get translation of child index relative to this widget Read more
Source§

fn navigable(&self) -> bool

Whether this widget supports navigation focus Read more
Source§

fn tooltip(&self) -> Option<&str>

Tooltip Read more
Source§

fn role(&self, cx: &mut dyn RoleCx) -> Role<'_>

Describe the widget’s role Read more
Source§

fn role_child_properties(&self, cx: &mut dyn RoleCx, index: usize)

Specify additional role properties for child index Read more
Source§

fn nav_next(&self, reverse: bool, from: Option<usize>) -> Option<usize>

Navigation in spatial order Read more
Source§

impl<C: Collection, D: Directional> Widget for Flow<C, D>

Source§

type Data = <List<C, D> as Widget>::Data

Input data type Read more
Source§

fn as_node<'__a>(&'__a mut self, data: &'__a Self::Data) -> Node<'__a>

Erase type Read more
Source§

fn child_node<'__n>( &'__n mut self, data: &'__n Self::Data, index: usize, ) -> Option<Node<'__n>>

Access a child as a Node, if available Read more

Auto Trait Implementations§

§

impl<C, D> Freeze for Flow<C, D>
where C: Freeze, D: Freeze,

§

impl<C, D> RefUnwindSafe for Flow<C, D>

§

impl<C, D> !Send for Flow<C, D>

§

impl<C, D> !Sync for Flow<C, D>

§

impl<C, D> Unpin for Flow<C, D>
where C: Unpin, D: Unpin,

§

impl<C, D> UnwindSafe for Flow<C, D>
where C: UnwindSafe, D: UnwindSafe,

Blanket Implementations§

Source§

impl<W> AdaptWidget for W
where W: Widget,

Source§

fn align(self, hints: AlignHints) -> Align<Self>

Apply an alignment hint Read more
Source§

fn pack(self, hints: AlignHints) -> Pack<Self>

Apply an alignment hint, squash and align the result Read more
Source§

fn with_stretch( self, horiz: impl Into<Option<Stretch>>, vert: impl Into<Option<Stretch>>, ) -> WithStretch<Self>

Adjust stretch policy Read more
Source§

fn with_margin_style(self, style: MarginStyle) -> WithMarginStyle<Self>

Set the margin style Read more
Source§

fn map<A, F>(self, f: F) -> Map<A, Self, F>
where F: for<'a> Fn(&'a A) -> &'a Self::Data,

Map data type via a function Read more
Source§

fn on_configure<F>(self, f: F) -> AdaptEvents<Self>
where F: Fn(&mut AdaptConfigCx<'_, '_>, &mut Self) + 'static,

Call the given closure on Events::configure Read more
Source§

fn on_update<F>(self, f: F) -> AdaptEvents<Self>
where F: Fn(&mut AdaptConfigCx<'_, '_>, &mut Self, &Self::Data) + 'static,

Call the given closure on Events::update Read more
Source§

fn on_message<M, H>(self, handler: H) -> AdaptEvents<Self>
where M: Debug + 'static, H: Fn(&mut AdaptEventCx<'_, '_>, &mut Self, M) + 'static,

Add a handler on message of type M Read more
Source§

fn map_message<M, N, H>(self, handler: H) -> AdaptEvents<Self>
where M: Debug + 'static, N: Debug + 'static, H: Fn(usize, M) -> N + 'static,

Add a child handler to map messages of type M to N Read more
Source§

fn on_messages<H>(self, handler: H) -> AdaptEvents<Self>
where H: Fn(&mut AdaptEventCx<'_, '_>, &mut Self, &Self::Data) + 'static,

Add a generic message handler Read more
Source§

fn with_min_size_px(self, w: i32, h: i32) -> Reserve<Self>

Construct a wrapper, setting minimum size in pixels Read more
Source§

fn with_min_size_em(self, w: f32, h: f32) -> Reserve<Self>

Construct a wrapper, setting minimum size in Em Read more
Source§

fn with_label<D, T>(self, direction: D, label: T) -> WithLabel<Self, D>

Construct a wrapper widget adding a label Read more
Source§

fn with_hidden_label<T: ToString>(self, label: T) -> WithHiddenLabel<Self>

Construct a wrapper widget adding a hidden label Read more
Source§

fn with_state<A>(self, state: Self::Data) -> Adapt<A, Self>

Construct an Adapt widget over input
Source§

impl<W> AdaptWidgetAny for W
where W: Widget<Data = ()>,

Source§

fn map_any<A>(self) -> MapAny<A, Self>

Map any input data to () Read more
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<S, T> Cast<T> for S
where T: Conv<S>,

Source§

fn cast(self) -> T

Cast from Self to T Read more
Source§

fn try_cast(self) -> Result<T, Error>

Try converting from Self to T Read more
Source§

impl<S, T> CastApprox<T> for S
where T: ConvApprox<S>,

Source§

fn try_cast_approx(self) -> Result<T, Error>

Try approximate conversion from Self to T Read more
Source§

fn cast_approx(self) -> T

Cast approximately from Self to T Read more
Source§

impl<S, T> CastFloat<T> for S
where T: ConvFloat<S>,

Source§

fn cast_trunc(self) -> T

Cast to integer, truncating Read more
Source§

fn cast_nearest(self) -> T

Cast to the nearest integer Read more
Source§

fn cast_floor(self) -> T

Cast the floor to an integer Read more
Source§

fn cast_ceil(self) -> T

Cast the ceiling to an integer Read more
Source§

fn try_cast_trunc(self) -> Result<T, Error>

Try converting to integer with truncation Read more
Source§

fn try_cast_nearest(self) -> Result<T, Error>

Try converting to the nearest integer Read more
Source§

fn try_cast_floor(self) -> Result<T, Error>

Try converting the floor to an integer Read more
Source§

fn try_cast_ceil(self) -> Result<T, Error>

Try convert the ceiling to an integer 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<W> TileExt for W
where W: Tile + ?Sized,

Source§

fn is_configured(&self) -> bool

Check whether this widget has been configured Read more
Source§

fn is_sized(&self) -> bool

Check whether this widget has been sized Read more
Source§

fn eq_id<T>(&self, rhs: T) -> bool
where Id: PartialEq<T>,

Test widget identifier for equality Read more
Source§

fn is_ancestor_of(&self, id: &Id) -> bool

Check whether id is self or a descendant Read more
Source§

fn is_strict_ancestor_of(&self, id: &Id) -> bool

Check whether id is not self and is a descendant Read more
Source§

fn children(&self) -> impl Iterator<Item = &dyn Tile>

Return an iterator over visible children Read more
Source§

fn find_tile(&self, id: &Id) -> Option<&dyn Tile>

Find the descendant with this id, if any Read more
Source§

fn find_tile_rect(&self, id: &Id) -> Option<(Rect, Offset)>

Find the Rect of the descendant with this id, if any 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> 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> ErasedDestructor for T
where T: 'static,