1
1
Fork 0
mirror of https://github.com/griffi-gh/hUI.git synced 2025-01-12 15:18:22 -06:00
hUI/hui-examples/examples/rounded_rect.rs

142 lines
4.8 KiB
Rust
Raw Normal View History

2024-02-29 09:02:05 -06:00
//WARNING: THIS EXAMPLE IS EXTREMELY OUTDATED AND USES DEPRECATED API
2024-02-18 21:37:28 -06:00
use glam::{vec4, UVec2};
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
element::{
container::Container,
2024-02-25 18:15:55 -06:00
text::Text, ElementList
2024-02-20 10:30:26 -06:00
},
2024-02-27 13:31:12 -06:00
layout::{Alignment, UiDirection, Size},
2024-02-25 18:15:55 -06:00
rectangle::{Corners, Sides},
UiInstance
2024-02-18 21:37:28 -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);
let mut hui = UiInstance::new();
let mut backend = GliumUiRenderer::new(&display);
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();
hui.begin();
hui.add(Container {
gap: 10.,
align: Alignment::Center.into(),
2024-02-27 13:31:12 -06:00
size: (Size::Fraction(1.), Size::Fraction(1.)).into(),
2024-02-25 18:15:55 -06:00
children: ElementList(vec![
Box::new(Container {
align: Alignment::Center.into(),
2024-02-27 13:31:12 -06:00
size: (Size::Fraction(0.5), Size::Fraction(0.5)).into(),
background: vec4(1., 0., 0., 1.).into(),
corner_radius: Corners {
top_left: 10.,
top_right: 20.,
bottom_left: 50.,
bottom_right: 80.
},
2024-02-25 18:15:55 -06:00
children: ElementList(vec![
Box::new(Container {
padding: Sides::all(20.),
direction: UiDirection::Horizontal,
align: Alignment::Center.into(),
2024-02-27 13:31:12 -06:00
size: (Size::Auto, Size::Auto).into(),
background: vec4(0.1, 0.1, 0.1, 0.5).into(),
corner_radius: Corners::all(8.),
2024-02-25 18:15:55 -06:00
children: ElementList(vec![
Box::new(Text {
text: "Corners".into(),
text_size: 50,
color: vec4(1., 1., 1., 1.),
..Default::default()
}),
Box::new(Text {
text: "!".into(),
text_size: 50,
color: vec4(1., 1., 0., 1.),
..Default::default()
}),
2024-02-25 18:15:55 -06:00
]),
..Default::default()
}),
2024-02-25 18:15:55 -06:00
]),
..Default::default()
}),
Box::new(Container {
gap: 10.,
direction: UiDirection::Horizontal,
2024-02-25 18:15:55 -06:00
children: ElementList(vec![
Box::new(Container {
2024-02-27 13:31:12 -06:00
size: (Size::Static(100.), Size::Static(100.)).into(),
background: Corners::left_right(
vec4(1., 0., 0., 1.),
vec4(0., 1., 0., 1.)
).into(),
corner_radius: Corners::all(0.),
..Default::default()
}),
Box::new(Container {
2024-02-27 13:31:12 -06:00
size: (Size::Static(100.), Size::Static(100.)).into(),
background: Corners::left_right(
vec4(1., 0., 0., 1.),
vec4(0., 1., 0., 1.)
).into(),
corner_radius: Corners::all(10.),
..Default::default()
}),
Box::new(Container {
2024-02-27 13:31:12 -06:00
size: (Size::Static(100.), Size::Static(100.)).into(),
background: Corners::left_right(
vec4(1., 0., 0., 1.),
vec4(0., 1., 0., 1.)
).into(),
corner_radius: Corners::all(20.),
..Default::default()
}),
Box::new(Container {
2024-02-27 13:31:12 -06:00
size: (Size::Static(100.), Size::Static(100.)).into(),
background: Corners::left_right(
vec4(1., 0., 0., 1.),
vec4(0., 1., 0., 1.)
).into(),
corner_radius: Corners::all(30.),
..Default::default()
}),
2024-02-25 18:15:55 -06:00
]),
..Default::default()
}),
2024-02-25 18:15:55 -06:00
]),
2024-02-18 21:37:28 -06:00
..Default::default()
}, resolution);
hui.end();
backend.update(&hui);
backend.draw(&mut frame, resolution);
frame.finish().unwrap();
}
_ => (),
}
}).unwrap();
}