hUI/hui-examples/examples/mom_downloader.rs

118 lines
3.8 KiB
Rust
Raw Normal View History

2024-02-17 14:43:46 -06:00
use std::time::Instant;
use glam::{UVec2, vec4};
use glium::{backend::glutin::SimpleWindowBuilder, Surface};
use winit::{
event::{Event, WindowEvent},
event_loop::{EventLoopBuilder, ControlFlow}
};
use hui::{
2024-02-20 10:30:26 -06:00
UiInstance, elements,
layout::{Alignment, UiDirection, UiSize},
rectangle::{Corners, Sides},
element::{
container::Container,
progress_bar::ProgressBar,
text::Text,
},
2024-02-17 14:43:46 -06:00
};
use hui_glium::GliumUiRenderer;
fn main() {
kubi_logging::init();
let event_loop = EventLoopBuilder::new().build().unwrap();
let (window, display) = SimpleWindowBuilder::new().build(&event_loop);
window.set_title("Mom Downloader 2000");
2024-02-17 14:47:21 -06:00
let mut hui = UiInstance::new();
2024-02-17 14:43:46 -06:00
let mut backend = GliumUiRenderer::new(&display);
2024-02-17 14:47:21 -06:00
let font_handle = hui.add_font_from_bytes(include_bytes!("../assets/roboto/Roboto-Regular.ttf"));
2024-02-17 14:43:46 -06:00
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., 0., 0., 1.);
let resolution = UVec2::from(display.get_framebuffer_dimensions()).as_vec2();
2024-02-17 14:47:21 -06:00
hui.begin();
2024-02-17 14:43:46 -06:00
let mom_ratio = (instant.elapsed().as_secs_f32() / 60.).powf(0.5);
2024-02-17 14:47:21 -06:00
hui.add(Container {
align: Alignment::Center.into(),
2024-02-18 12:27:45 -06:00
size: (UiSize::Fraction(1.), UiSize::Fraction(1.)),
2024-02-20 13:10:56 -06:00
background: vec4(0.1, 0.1, 0.1, 1.),
2024-02-17 14:43:46 -06:00
elements: vec![Box::new(Container {
gap: 5.,
padding: Sides::all(10.),
2024-02-18 12:27:45 -06:00
size: (UiSize::Static(450.), UiSize::Auto),
2024-02-20 13:10:56 -06:00
background: vec4(0.2, 0.2, 0.5, 1.),
2024-02-20 13:06:13 -06:00
corner_radius: Corners::all(8.),
2024-02-17 14:43:46 -06:00
elements: elements(|el| {
if instant.elapsed().as_secs_f32() < 5. {
el.add(Text {
text: "Downloading your mom...".into(),
font: font_handle,
2024-02-19 07:26:59 -06:00
text_size: 24,
2024-02-17 14:43:46 -06:00
..Default::default()
});
el.add(ProgressBar {
value: mom_ratio,
..Default::default()
});
2024-02-19 07:26:59 -06:00
el.add(Container {
direction: UiDirection::Horizontal,
align: (Alignment::End, Alignment::Center).into(),
2024-02-19 07:26:59 -06:00
size: (UiSize::Fraction(1.), UiSize::Auto),
elements: vec![Box::new(Text {
text: format!("{:.2}% ({:.1} GB)", mom_ratio * 100., mom_ratio * 10000.).into(),
font: font_handle,
text_size: 16,
..Default::default()
})],
2024-02-17 14:43:46 -06:00
..Default::default()
});
} else if instant.elapsed().as_secs() < 10 {
el.add(Text {
2024-02-19 07:26:59 -06:00
text: "Error 413: Request Entity Too Large".into(),
2024-02-17 14:43:46 -06:00
font: font_handle,
color: vec4(1., 0.125, 0.125, 1.),
2024-02-19 07:26:59 -06:00
text_size: 20,
2024-02-17 14:43:46 -06:00
..Default::default()
});
el.add(Text {
text: format!("Exiting in {}...", 10 - instant.elapsed().as_secs()).into(),
font: font_handle,
2024-02-19 07:26:59 -06:00
text_size: 16,
2024-02-17 14:43:46 -06:00
..Default::default()
2024-02-19 07:26:59 -06:00
});
2024-02-17 14:43:46 -06:00
} else {
window_target.exit();
}
}),
..Default::default()
})],
..Default::default()
}, resolution);
2024-02-17 14:47:21 -06:00
hui.end();
2024-02-17 14:43:46 -06:00
2024-02-17 14:47:21 -06:00
backend.update(&hui);
2024-02-17 14:43:46 -06:00
backend.draw(&mut frame, resolution);
frame.finish().unwrap();
}
_ => (),
}
}).unwrap();
}