hUI/hui-examples/examples/ui_test_6.rs

68 lines
1.7 KiB
Rust
Raw Normal View History

2024-03-14 07:30:44 -05:00
use hui::{
color, size,
draw::TextureFormat,
signal::UiSignal,
layout::{Alignment, Direction},
element::{
container::Container,
text::Text,
image::Image,
br::Br,
interactable::ElementInteractableExt,
slider::Slider,
UiElementExt,
},
};
enum CounterSignal {
2024-03-21 12:41:28 -05:00
ChangeValue(f32)
2024-03-14 07:30:44 -05:00
}
impl UiSignal for CounterSignal {}
#[path = "../boilerplate.rs"]
#[macro_use]
mod boilerplate;
const IMAGE_DATA: &[u8] = include_bytes!("../assets/icons/visual-studio-code-icon_32x32.rgba");
ui_main!(
"hUI: Internal input test",
init: |ui| {
let image = ui.add_image(TextureFormat::Rgba, IMAGE_DATA, 32);
(0, image)
},
run: |ui, size, (ref mut counter, image)| {
Container::default()
.with_size(size!(100%))
.with_padding(10.)
.with_align((Alignment::Center, Alignment::Begin))
.with_direction(Direction::Horizontal)
.with_gap(5.)
.with_background((0.1, 0.1, 0.1))
.with_wrap(true)
.with_children(|ui| {
Text::new("Number of images:")
.with_text_size(24)
.add_child(ui);
Br.add_child(ui);
2024-03-21 12:41:28 -05:00
Slider::new(*counter as f32 / 100.)
2024-03-14 07:30:44 -05:00
.with_size(size!(66%, 20))
2024-03-21 12:41:28 -05:00
.on_change(CounterSignal::ChangeValue)
2024-03-14 07:30:44 -05:00
.add_child(ui);
Br.add_child(ui);
for _ in 0..*counter {
Image::new(*image)
.with_size(size!(48, 48))
.add_child(ui);
}
})
.add_root(ui, size);
ui.process_signals(|sig| match sig {
2024-03-21 12:41:28 -05:00
CounterSignal::ChangeValue(v) => {
*counter = (v * 100.).round() as usize;
}
2024-03-14 07:30:44 -05:00
});
}
);