pub struct Column<'a, Key, Message, Theme = Theme, Renderer = Renderer>{ /* private fields */ }Expand description
A container that distributes its contents vertically while keeping continuity.
§Example
use iced::widget::{keyed_column, text};
enum Message {
// ...
}
fn view(state: &State) -> Element<'_, Message> {
keyed_column((0..=100).map(|i| {
(i, text!("Item {i}").into())
})).into()
}Implementations§
Source§impl<'a, Key, Message, Theme, Renderer> Column<'a, Key, Message, Theme, Renderer>
impl<'a, Key, Message, Theme, Renderer> Column<'a, Key, Message, Theme, Renderer>
Sourcepub fn from_vecs(
keys: Vec<Key>,
children: Vec<Element<'a, Message, Theme, Renderer>>,
) -> Self
pub fn from_vecs( keys: Vec<Key>, children: Vec<Element<'a, Message, Theme, Renderer>>, ) -> Self
Creates a Column from already allocated Vecs.
Keep in mind that the Column will not inspect the Vecs, which means
it won’t automatically adapt to the sizing strategy of its contents.
If any of the children have a Length::Fill strategy, you will need to
call Column::width or Column::height accordingly.
Sourcepub fn with_capacity(capacity: usize) -> Self
pub fn with_capacity(capacity: usize) -> Self
Creates a Column with the given capacity.
Sourcepub fn with_children(
children: impl IntoIterator<Item = (Key, Element<'a, Message, Theme, Renderer>)>,
) -> Self
pub fn with_children( children: impl IntoIterator<Item = (Key, Element<'a, Message, Theme, Renderer>)>, ) -> Self
Creates a Column with the given elements.
Sourcepub fn spacing(self, amount: impl Into<Pixels>) -> Self
pub fn spacing(self, amount: impl Into<Pixels>) -> Self
Sets the vertical spacing between elements.
Custom margins per element do not exist in iced. You should use this method instead! While less flexible, it helps you keep spacing between elements consistent.
Sourcepub fn max_width(self, max_width: impl Into<Pixels>) -> Self
pub fn max_width(self, max_width: impl Into<Pixels>) -> Self
Sets the maximum width of the Column.
Sourcepub fn align_items(self, align: Alignment) -> Self
pub fn align_items(self, align: Alignment) -> Self
Sets the horizontal alignment of the contents of the Column .
Sourcepub fn push(
self,
key: Key,
child: impl Into<Element<'a, Message, Theme, Renderer>>,
) -> Self
pub fn push( self, key: Key, child: impl Into<Element<'a, Message, Theme, Renderer>>, ) -> Self
Adds an element to the Column.
Sourcepub fn push_maybe(
self,
key: Key,
child: Option<impl Into<Element<'a, Message, Theme, Renderer>>>,
) -> Self
pub fn push_maybe( self, key: Key, child: Option<impl Into<Element<'a, Message, Theme, Renderer>>>, ) -> Self
Adds an element to the Column, if Some.
Sourcepub fn extend(
self,
children: impl IntoIterator<Item = (Key, Element<'a, Message, Theme, Renderer>)>,
) -> Self
pub fn extend( self, children: impl IntoIterator<Item = (Key, Element<'a, Message, Theme, Renderer>)>, ) -> Self
Extends the Column with the given children.
Trait Implementations§
Source§impl<'a, Key, Message, Theme, Renderer> From<Column<'a, Key, Message, Theme, Renderer>> for Element<'a, Message, Theme, Renderer>
impl<'a, Key, Message, Theme, Renderer> From<Column<'a, Key, Message, Theme, Renderer>> for Element<'a, Message, Theme, Renderer>
Source§impl<Key, Message, Theme, Renderer> Widget<Message, Theme, Renderer> for Column<'_, Key, Message, Theme, Renderer>
impl<Key, Message, Theme, Renderer> Widget<Message, Theme, Renderer> for Column<'_, Key, Message, Theme, Renderer>
Source§fn operate(
&mut self,
tree: &mut Tree,
layout: Layout<'_>,
renderer: &Renderer,
operation: &mut dyn Operation,
)
fn operate( &mut self, tree: &mut Tree, layout: Layout<'_>, renderer: &Renderer, operation: &mut dyn Operation, )
Source§fn update(
&mut self,
tree: &mut Tree,
event: &Event,
layout: Layout<'_>,
cursor: Cursor,
renderer: &Renderer,
shell: &mut Shell<'_, Message>,
viewport: &Rectangle,
)
fn update( &mut self, tree: &mut Tree, event: &Event, layout: Layout<'_>, cursor: Cursor, renderer: &Renderer, shell: &mut Shell<'_, Message>, viewport: &Rectangle, )
Source§fn mouse_interaction(
&self,
tree: &Tree,
layout: Layout<'_>,
cursor: Cursor,
viewport: &Rectangle,
renderer: &Renderer,
) -> Interaction
fn mouse_interaction( &self, tree: &Tree, layout: Layout<'_>, cursor: Cursor, viewport: &Rectangle, renderer: &Renderer, ) -> Interaction
Source§fn draw(
&self,
tree: &Tree,
renderer: &mut Renderer,
theme: &Theme,
style: &Style,
layout: Layout<'_>,
cursor: Cursor,
viewport: &Rectangle,
)
fn draw( &self, tree: &Tree, renderer: &mut Renderer, theme: &Theme, style: &Style, layout: Layout<'_>, cursor: Cursor, viewport: &Rectangle, )
Widget using the associated Renderer.