pub struct CollapsingHeader { /* private fields */ }
Expand description
A header which can be collapsed/expanded, revealing a contained Ui
region.
egui::CollapsingHeader::new("Heading")
.show(ui, |ui| {
ui.label("Body");
});
// Short version:
ui.collapsing("Heading", |ui| { ui.label("Body"); });
If you want to customize the header contents, see CollapsingState::show_header
.
Implementations§
Source§impl CollapsingHeader
impl CollapsingHeader
Sourcepub fn new(text: impl Into<WidgetText>) -> CollapsingHeader
pub fn new(text: impl Into<WidgetText>) -> CollapsingHeader
The CollapsingHeader
starts out collapsed unless you call default_open
.
The label is used as an Id
source.
If the label is unique and static this is fine,
but if it changes or there are several CollapsingHeader
with the same title
you need to provide a unique id source with Self::id_source
.
Sourcepub fn default_open(self, open: bool) -> CollapsingHeader
pub fn default_open(self, open: bool) -> CollapsingHeader
By default, the CollapsingHeader
is collapsed.
Call .default_open(true)
to change this.
Sourcepub fn open(self, open: Option<bool>) -> CollapsingHeader
pub fn open(self, open: Option<bool>) -> CollapsingHeader
Calling .open(Some(true))
will make the collapsing header open this frame (or stay open).
Calling .open(Some(false))
will make the collapsing header close this frame (or stay closed).
Calling .open(None)
has no effect (default).
Sourcepub fn id_source(self, id_source: impl Hash) -> CollapsingHeader
pub fn id_source(self, id_source: impl Hash) -> CollapsingHeader
Explicitly set the source of the Id
of this widget, instead of using title label.
This is useful if the title label is dynamic or not unique.
Sourcepub fn enabled(self, enabled: bool) -> CollapsingHeader
pub fn enabled(self, enabled: bool) -> CollapsingHeader
If you set this to false
, the CollapsingHeader
will be grayed out and un-clickable.
This is a convenience for Ui::set_enabled
.
Sourcepub fn selectable(self, selectable: bool) -> CollapsingHeader
👎Deprecated: Use the more powerful egui::collapsing_header::CollapsingState::show_header
pub fn selectable(self, selectable: bool) -> CollapsingHeader
Can the CollapsingHeader
be selected by clicking it? Default: false
.
Sourcepub fn selected(self, selected: bool) -> CollapsingHeader
👎Deprecated: Use the more powerful egui::collapsing_header::CollapsingState::show_header
pub fn selected(self, selected: bool) -> CollapsingHeader
If you set this to ‘true’, the CollapsingHeader
will be shown as selected.
Example:
let mut selected = false;
let response = egui::CollapsingHeader::new("Select and open me")
.selectable(true)
.selected(selected)
.show(ui, |ui| ui.label("Body"));
if response.header_response.clicked() {
selected = true;
}
Sourcepub fn show_background(self, show_background: bool) -> CollapsingHeader
pub fn show_background(self, show_background: bool) -> CollapsingHeader
Should the CollapsingHeader
show a background behind it? Default: false
.
To show it behind all CollapsingHeader
you can just use:
ui.visuals_mut().collapsing_header_frame = true;
Sourcepub fn icon(
self,
icon_fn: impl FnOnce(&mut Ui, f32, &Response) + 'static,
) -> CollapsingHeader
pub fn icon( self, icon_fn: impl FnOnce(&mut Ui, f32, &Response) + 'static, ) -> CollapsingHeader
Use the provided function to render a different CollapsingHeader
icon.
Defaults to a triangle that animates as the CollapsingHeader
opens and closes.
For example:
fn circle_icon(ui: &mut egui::Ui, openness: f32, response: &egui::Response) {
let stroke = ui.style().interact(&response).fg_stroke;
let radius = egui::lerp(2.0..=3.0, openness);
ui.painter().circle_filled(response.rect.center(), radius, stroke.color);
}
egui::CollapsingHeader::new("Circles")
.icon(circle_icon)
.show(ui, |ui| { ui.label("Hi!"); });
Source§impl CollapsingHeader
impl CollapsingHeader
pub fn show<R>( self, ui: &mut Ui, add_body: impl FnOnce(&mut Ui) -> R, ) -> CollapsingResponse<R>
pub fn show_unindented<R>( self, ui: &mut Ui, add_body: impl FnOnce(&mut Ui) -> R, ) -> CollapsingResponse<R>
Auto Trait Implementations§
impl Freeze for CollapsingHeader
impl !RefUnwindSafe for CollapsingHeader
impl !Send for CollapsingHeader
impl !Sync for CollapsingHeader
impl Unpin for CollapsingHeader
impl !UnwindSafe for CollapsingHeader
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<S> FromSample<S> for S
impl<S> FromSample<S> for S
fn from_sample_(s: S) -> S
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§impl<F, T> IntoSample<T> for Fwhere
T: FromSample<F>,
impl<F, T> IntoSample<T> for Fwhere
T: FromSample<F>,
fn into_sample(self) -> T
Source§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
Source§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
self
from the equivalent element of its
superset. Read moreSource§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
self
is actually part of its subset T
(and can be converted to it).Source§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
self.to_subset
but without any property checks. Always succeeds.Source§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
self
to the equivalent element of its superset.