kubi/kubi-ui/examples/test.rs

150 lines
4.4 KiB
Rust
Raw Normal View History

2023-11-23 04:10:35 -06:00
use std::time::Instant;
use glam::{UVec2, vec4};
2023-11-23 04:10:35 -06:00
use glium::{backend::glutin::SimpleWindowBuilder, Surface};
use winit::{
event::{Event, WindowEvent},
event_loop::{EventLoopBuilder, ControlFlow}
};
use kubi_ui::{
KubiUi,
element::{
UiElement,
progress_bar::ProgressBar,
container::{Container, Sides, Alignment},
rect::Rect
},
interaction::IntoInteractable,
UiSize,
UiDirection,
2023-11-23 04:10:35 -06:00
};
use kubi_ui_glium::GliumUiRenderer;
2023-11-23 04:10:35 -06:00
fn main() {
kubi_logging::init();
let event_loop = EventLoopBuilder::new().build().unwrap();
let (window, display) = SimpleWindowBuilder::new().build(&event_loop);
let mut kui = KubiUi::new();
let mut backend = GliumUiRenderer::new(&display);
let instant = Instant::now();
event_loop.run(|event, window_target| {
window_target.set_control_flow(ControlFlow::Poll);
match event {
Event::WindowEvent { event: WindowEvent::CloseRequested, .. } => {
window_target.exit();
},
Event::AboutToWait => {
let mut frame = display.draw();
frame.clear_color_srgb(0.5, 0.5, 0.5, 0.);
let resolution = UVec2::from(display.get_framebuffer_dimensions()).as_vec2();
kui.begin();
2023-11-28 03:39:25 -06:00
let z = instant.elapsed().as_secs_f32().sin().powi(2);
2023-11-23 04:10:35 -06:00
kui.add(Container {
gap: 5.,
padding: Sides::all(5.),
2023-11-28 04:32:09 -06:00
align: (Alignment::Begin, Alignment::Center),
size: (UiSize::Percentage(1.), UiSize::Percentage(1.)),
2023-11-23 04:10:35 -06:00
elements: vec![
Box::new(ProgressBar {
value: 0.5,
..Default::default()
}),
2023-11-28 04:32:09 -06:00
],
..Default::default()
}, resolution);
kui.add(Container {
gap: 5.,
padding: Sides::all(5.),
align: (Alignment::End, Alignment::Center),
size: (UiSize::Percentage(1.), UiSize::Percentage(1.)),
elements: vec![
2023-11-23 04:10:35 -06:00
Box::new(ProgressBar {
2023-11-28 03:39:25 -06:00
value: z,
2023-11-23 04:10:35 -06:00
..Default::default()
}),
2023-11-28 03:31:38 -06:00
Box::new(Container {
size: (UiSize::Percentage(1.), UiSize::Auto),
align: (Alignment::Center, Alignment::End),
padding: Sides::all(5.),
gap: 10.,
elements: vec![
Box::new(Rect {
size: (UiSize::Percentage(0.5), UiSize::Pixels(30.)),
color: Some(vec4(0.75, 0., 0., 1.))
}),
Box::new(Rect {
2023-11-28 03:39:25 -06:00
size: (UiSize::Percentage(z / 2. + 0.5), UiSize::Pixels(30.)),
2023-11-28 03:31:38 -06:00
color: Some(vec4(0., 0.75, 0., 1.))
}),
],
..Default::default()
}),
2023-11-28 03:39:25 -06:00
Box::new(Rect {
size: (UiSize::Percentage(z / 2. + 0.5), UiSize::Pixels(30.)),
color: Some(vec4(0., 0.75, 0., 1.))
}),
2023-11-28 03:31:38 -06:00
Box::new(Container {
gap: 5.,
padding: Sides::all(5.),
background: Some(vec4(0., 0., 0., 0.5)),
direction: UiDirection::Horizontal,
elements: {
let mut x: Vec<Box<dyn UiElement>> = vec![];
for i in 0..10 {
x.push(Box::new(Rect {
size: (UiSize::Pixels(50.), UiSize::Pixels(50.)),
color: if i == 1 {
Some(vec4(0.75, 0.75, 0.75, 0.75))
} else {
Some(vec4(0.5, 0.5, 0.5, 0.75))
}
}));
}
x
},
..Default::default()
}),
Box::new(Container {
background: Some(vec4(1., 0., 0., 1.)),
2023-11-28 13:18:47 -06:00
padding: Sides {
top: 10.,
bottom: 20.,
left: 30.,
right: 40.,
},
2023-11-28 03:31:38 -06:00
elements: vec![
Box::new(Rect {
size: (UiSize::Pixels(50.), UiSize::Pixels(50.)),
color: Some(vec4(1., 1., 1., 0.75))
}.into_interactable().on_click(|| {
println!("clicked");
}))
2023-11-28 03:31:38 -06:00
],
..Default::default()
})
2023-11-23 04:10:35 -06:00
],
..Default::default()
}, resolution);
kui.end();
let plan = kui.draw_plan();
if plan.0 {
backend.update(plan.1);
}
backend.draw(&mut frame, resolution);
frame.finish().unwrap();
}
_ => (),
}
}).unwrap();
2023-11-22 18:48:04 -06:00
}