104 lines
4.2 KiB
Rust
104 lines
4.2 KiB
Rust
use egui::Color32;
|
|
use egui_extras::{GridBuilder, Padding, Size};
|
|
|
|
/// Shows off a table with dynamic layout
|
|
#[cfg_attr(feature = "serde", derive(serde::Deserialize, serde::Serialize))]
|
|
#[derive(Default)]
|
|
pub struct GridDemo {}
|
|
|
|
impl super::Demo for GridDemo {
|
|
fn name(&self) -> &'static str {
|
|
"▣ Grid Demo"
|
|
}
|
|
|
|
fn show(&mut self, ctx: &egui::Context, open: &mut bool) {
|
|
egui::Window::new(self.name())
|
|
.open(open)
|
|
.resizable(true)
|
|
.default_width(400.0)
|
|
.show(ctx, |ui| {
|
|
use super::View as _;
|
|
self.ui(ui);
|
|
});
|
|
}
|
|
}
|
|
|
|
impl super::View for GridDemo {
|
|
fn ui(&mut self, ui: &mut egui::Ui) {
|
|
GridBuilder::new(ui, Padding::new(0.0, 0.0))
|
|
.size(Size::Absolute(50.0))
|
|
.size(Size::Remainder)
|
|
.size(Size::RelativeMinimum {
|
|
relative: 0.5,
|
|
minimum: 60.0,
|
|
})
|
|
.vertical(|mut grid| {
|
|
grid.cell(|ui| {
|
|
ui.painter()
|
|
.rect_filled(ui.available_rect_before_wrap(), 0.0, Color32::BLUE);
|
|
ui.label("Full width and 50px height");
|
|
});
|
|
grid.grid(|builder| {
|
|
builder.sizes(Size::Remainder, 2).horizontal(|mut grid| {
|
|
grid.cell(|ui| {
|
|
ui.painter().rect_filled(
|
|
ui.available_rect_before_wrap(),
|
|
0.0,
|
|
Color32::RED,
|
|
);
|
|
ui.label("remaining height and 50% of the width");
|
|
});
|
|
grid.grid(|builder| {
|
|
builder.sizes(Size::Remainder, 3).vertical(|mut grid| {
|
|
grid.empty();
|
|
grid.cell(|ui| {
|
|
ui.painter().rect_filled(
|
|
ui.available_rect_before_wrap(),
|
|
0.0,
|
|
Color32::YELLOW,
|
|
);
|
|
ui.label("one third of the box left of me but same width");
|
|
});
|
|
});
|
|
});
|
|
});
|
|
});
|
|
grid.grid(|builder| {
|
|
builder
|
|
.size(Size::Remainder)
|
|
.size(Size::Absolute(60.0))
|
|
.size(Size::Remainder)
|
|
.size(Size::Absolute(70.0))
|
|
.horizontal(|mut grid| {
|
|
grid.empty();
|
|
grid.grid(|builder| {
|
|
builder
|
|
.size(Size::Remainder)
|
|
.size(Size::Absolute(60.0))
|
|
.size(Size::Remainder)
|
|
.vertical(|mut grid| {
|
|
grid.empty();
|
|
grid.cell(|ui| {
|
|
ui.painter().rect_filled(
|
|
ui.available_rect_before_wrap(),
|
|
0.0,
|
|
Color32::GOLD,
|
|
);
|
|
ui.label("60x60");
|
|
});
|
|
});
|
|
});
|
|
grid.empty();
|
|
grid.cell(|ui| {
|
|
ui.painter().rect_filled(
|
|
ui.available_rect_before_wrap(),
|
|
0.0,
|
|
Color32::GREEN,
|
|
);
|
|
ui.label("height: half the available - at least 60px, width: 70px");
|
|
});
|
|
});
|
|
});
|
|
});
|
|
}
|
|
}
|