egui/emigui/src/example_app.rs

179 lines
7.6 KiB
Rust
Raw Normal View History

use crate::{
color::*, label, math::*, widgets::*, Align, CollapsingHeader, Outline, PaintCmd, Region,
ScrollArea,
};
2018-12-26 09:46:23 +00:00
2020-04-12 10:07:51 +00:00
/// Showcase some region code
pub struct ExampleApp {
2018-12-26 21:17:33 +00:00
checked: bool,
2019-03-11 12:32:44 +00:00
count: usize,
radio: usize,
2018-12-26 16:32:58 +00:00
size: Vec2,
2018-12-26 16:32:58 +00:00
corner_radius: f32,
stroke_width: f32,
2019-03-11 12:32:44 +00:00
num_boxes: usize,
num_columns: usize,
2019-03-11 12:32:54 +00:00
slider_value: usize,
2018-12-26 09:46:23 +00:00
}
2020-04-12 10:07:51 +00:00
impl Default for ExampleApp {
fn default() -> ExampleApp {
ExampleApp {
2019-01-05 15:23:40 +00:00
checked: true,
radio: 0,
2018-12-26 16:32:58 +00:00
count: 0,
size: vec2(100.0, 50.0),
2018-12-26 16:32:58 +00:00
corner_radius: 5.0,
stroke_width: 2.0,
2019-02-10 15:10:08 +00:00
num_boxes: 1,
2019-03-11 12:32:44 +00:00
num_columns: 2,
2019-03-11 12:32:54 +00:00
slider_value: 100,
2018-12-26 16:32:58 +00:00
}
}
2018-12-26 21:17:33 +00:00
}
2018-12-26 16:32:58 +00:00
2020-04-12 10:07:51 +00:00
impl ExampleApp {
pub fn ui(&mut self, region: &mut Region) {
region.collapsing("About Emigui", |region| {
2020-04-21 18:48:31 +00:00
region.add(label!(
"Emigui is an experimental immediate mode GUI written in Rust."
));
2020-04-23 17:15:17 +00:00
region.horizontal(Align::Min, |region| {
region.add_label("Project home page:");
region.add_hyperlink("https://github.com/emilk/emigui/");
});
2020-04-12 10:07:51 +00:00
});
2020-04-23 07:50:03 +00:00
CollapsingHeader::new("Widgets")
.default_open()
.show(region, |region| {
2020-04-12 10:07:51 +00:00
region.horizontal(Align::Min, |region| {
region.add(label!("Text can have").text_color(srgba(110, 255, 110, 255)));
region.add(label!("color").text_color(srgba(128, 140, 255, 255)));
region.add(label!("and tooltips (hover me)")).tooltip_text(
2019-01-21 07:48:32 +00:00
"This is a multiline tooltip that demonstrates that you can easily add tooltips to any element.\nThis is the second line.\nThis is the third.",
);
});
2018-12-27 23:51:40 +00:00
2020-04-12 10:07:51 +00:00
region.add(Checkbox::new(&mut self.checked, "checkbox"));
2018-12-28 22:53:15 +00:00
2020-04-12 10:07:51 +00:00
region.horizontal(Align::Min, |region| {
if region.add(radio(self.radio == 0, "First")).clicked {
2019-01-21 07:48:32 +00:00
self.radio = 0;
}
2020-04-12 10:07:51 +00:00
if region.add(radio(self.radio == 1, "Second")).clicked {
2019-01-21 07:48:32 +00:00
self.radio = 1;
}
2020-04-12 10:07:51 +00:00
if region.add(radio(self.radio == 2, "Final")).clicked {
2019-01-21 07:48:32 +00:00
self.radio = 2;
}
});
2020-04-12 10:07:51 +00:00
region.horizontal(Align::Min, |region| {
if region
2019-01-21 07:48:32 +00:00
.add(Button::new("Click me"))
.tooltip_text("This will just increase a counter.")
.clicked
{
self.count += 1;
}
2020-04-12 10:07:51 +00:00
region.add(label!(
2019-01-21 07:48:32 +00:00
"The button have been clicked {} times",
self.count
));
});
region.add(Slider::usize(&mut self.slider_value, 1, 1000).text("value"));
if region.add(Button::new("Double it")).clicked {
self.slider_value *= 2;
}
2018-12-28 09:39:08 +00:00
});
2018-12-26 21:26:15 +00:00
region.collapsing("Layouts", |region| {
2020-04-12 10:07:51 +00:00
region.add(Slider::usize(&mut self.num_columns, 1, 10).text("Columns"));
region.columns(self.num_columns, |cols| {
2019-03-11 12:32:44 +00:00
for (i, col) in cols.iter_mut().enumerate() {
col.add(label!("Column {} out of {}", i + 1, self.num_columns));
if i + 1 == self.num_columns {
if col.add(Button::new("Delete this")).clicked {
self.num_columns -= 1;
}
}
}
});
});
region.collapsing("Test box rendering", |region| {
2020-04-12 10:07:51 +00:00
region.add(Slider::f32(&mut self.size.x, 0.0, 500.0).text("width"));
region.add(Slider::f32(&mut self.size.y, 0.0, 500.0).text("height"));
region.add(Slider::f32(&mut self.corner_radius, 0.0, 50.0).text("corner_radius"));
region.add(Slider::f32(&mut self.stroke_width, 0.0, 10.0).text("stroke_width"));
region.add(Slider::usize(&mut self.num_boxes, 0, 5).text("num_boxes"));
2018-12-26 16:32:58 +00:00
2020-04-12 10:07:51 +00:00
let pos = region
2019-02-10 15:10:08 +00:00
.reserve_space(
vec2(self.size.x * (self.num_boxes as f32), self.size.y),
None,
)
.rect
.min();
2019-02-10 19:56:59 +00:00
let mut cmds = vec![];
2019-02-10 15:10:08 +00:00
for i in 0..self.num_boxes {
2019-02-10 19:56:59 +00:00
cmds.push(PaintCmd::Rect {
2019-02-10 15:10:08 +00:00
corner_radius: self.corner_radius,
2019-03-11 14:30:32 +00:00
fill_color: Some(gray(136, 255)),
2019-02-10 15:10:08 +00:00
rect: Rect::from_min_size(
2020-04-21 14:50:56 +00:00
pos2(10.0 + pos.x + (i as f32) * (self.size.x * 1.1), pos.y),
2019-02-10 15:10:08 +00:00
self.size,
),
2020-04-19 09:11:41 +00:00
outline: Some(Outline::new(self.stroke_width, gray(255, 255))),
2019-02-10 19:56:59 +00:00
});
2019-02-10 15:10:08 +00:00
}
2020-04-12 10:07:51 +00:00
region.add_paint_cmds(cmds);
});
2019-03-11 12:32:54 +00:00
CollapsingHeader::new("Scroll area")
2020-04-23 07:50:03 +00:00
// .default_open()
.show(region, |region| {
ScrollArea::default().show(region, |region| {
region.add_label(LOREM_IPSUM);
});
});
region.collapsing("Name clash example", |region| {
2020-04-20 21:42:11 +00:00
region.add_label("\
Regions that store state require unique identifiers so we can track their state between frames. \
2020-04-20 21:42:11 +00:00
Identifiers are normally derived from the titles of the widget.");
2020-04-20 21:42:11 +00:00
region.add_label("\
For instance, collapsing regions needs to store wether or not they are open. \
If you fail to give them unique names then clicking one will open both. \
2020-04-21 18:48:31 +00:00
To help you debug this, an error message is printed on screen:");
region.collapsing("Collapsing header", |region| {
2020-04-20 21:42:11 +00:00
region.add_label("Contents of first folddable region");
});
region.collapsing("Collapsing header", |region| {
2020-04-20 21:42:11 +00:00
region.add_label("Contents of second folddable region");
});
2020-04-20 21:42:11 +00:00
region.add_label("\
Most widgets don't need unique names, but are tracked \
based on their position on screen. For instance, buttons:");
region.add(Button::new("Button"));
region.add(Button::new("Button"));
});
2018-12-26 22:08:50 +00:00
}
}
2020-04-12 10:07:51 +00:00
const LOREM_IPSUM: &str = "Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.
Curabitur pretium tincidunt lacus. Nulla gravida orci a odio. Nullam varius, turpis et commodo pharetra, est eros bibendum elit, nec luctus magna felis sollicitudin mauris. Integer in mauris eu nibh euismod gravida. Duis ac tellus et risus vulputate vehicula. Donec lobortis risus a elit. Etiam tempor. Ut ullamcorper, ligula eu tempor congue, eros est euismod turpis, id tincidunt sapien risus a quam. Maecenas fermentum consequat mi. Donec fermentum. Pellentesque malesuada nulla a mi. Duis sapien sem, aliquet nec, commodo eget, consequat quis, neque. Aliquam faucibus, elit ut dictum aliquet, felis nisl adipiscing sapien, sed malesuada diam lacus eget erat. Cras mollis scelerisque nunc. Nullam arcu. Aliquam consequat. Curabitur augue lorem, dapibus quis, laoreet et, pretium ac, nisi. Aenean magna nisl, mollis quis, molestie eu, feugiat in, orci. In hac habitasse platea dictumst.";