2024-05-03 09:11:46 +02:00
|
|
|
use iced::widget::{center, column, container, slider, text, vertical_slider};
|
|
|
|
|
use iced::Element;
|
2022-12-12 15:27:00 +01:00
|
|
|
|
|
|
|
|
pub fn main() -> iced::Result {
|
2024-03-16 05:33:47 +01:00
|
|
|
iced::run("Slider - Iced", Slider::update, Slider::view)
|
2022-12-12 15:27:00 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#[derive(Debug, Clone)]
|
|
|
|
|
pub enum Message {
|
|
|
|
|
SliderChanged(u8),
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
pub struct Slider {
|
2024-01-31 21:56:55 +01:00
|
|
|
value: u8,
|
|
|
|
|
default: u8,
|
|
|
|
|
step: u8,
|
|
|
|
|
shift_step: u8,
|
2022-12-12 15:27:00 +01:00
|
|
|
}
|
|
|
|
|
|
2024-03-16 05:33:47 +01:00
|
|
|
impl Slider {
|
|
|
|
|
fn new() -> Self {
|
2023-09-20 20:56:50 +02:00
|
|
|
Slider {
|
2024-01-31 21:56:55 +01:00
|
|
|
value: 50,
|
|
|
|
|
default: 50,
|
|
|
|
|
step: 5,
|
|
|
|
|
shift_step: 1,
|
2023-09-20 20:56:50 +02:00
|
|
|
}
|
2022-12-12 15:27:00 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
fn update(&mut self, message: Message) {
|
|
|
|
|
match message {
|
|
|
|
|
Message::SliderChanged(value) => {
|
2024-01-31 21:56:55 +01:00
|
|
|
self.value = value;
|
2022-12-12 15:27:00 +01:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
fn view(&self) -> Element<Message> {
|
2023-09-20 20:56:50 +02:00
|
|
|
let h_slider = container(
|
2024-01-31 21:56:55 +01:00
|
|
|
slider(0..=100, self.value, Message::SliderChanged)
|
|
|
|
|
.default(self.default)
|
|
|
|
|
.step(self.step)
|
|
|
|
|
.shift_step(self.shift_step),
|
2023-09-20 20:56:50 +02:00
|
|
|
)
|
|
|
|
|
.width(250);
|
2022-12-12 15:27:00 +01:00
|
|
|
|
2023-09-20 20:56:50 +02:00
|
|
|
let v_slider = container(
|
2024-01-31 21:56:55 +01:00
|
|
|
vertical_slider(0..=100, self.value, Message::SliderChanged)
|
|
|
|
|
.default(self.default)
|
|
|
|
|
.step(self.step)
|
|
|
|
|
.shift_step(self.shift_step),
|
2023-09-20 20:56:50 +02:00
|
|
|
)
|
|
|
|
|
.height(200);
|
2022-12-12 15:27:00 +01:00
|
|
|
|
2024-01-31 21:56:55 +01:00
|
|
|
let text = text(self.value);
|
2022-12-12 15:27:00 +01:00
|
|
|
|
2024-05-03 09:11:46 +02:00
|
|
|
center(
|
2022-12-12 15:27:00 +01:00
|
|
|
column![
|
2024-05-03 09:11:46 +02:00
|
|
|
container(v_slider).center_x(),
|
|
|
|
|
container(h_slider).center_x(),
|
|
|
|
|
container(text).center_x()
|
2022-12-12 15:27:00 +01:00
|
|
|
]
|
|
|
|
|
.spacing(25),
|
|
|
|
|
)
|
|
|
|
|
.into()
|
|
|
|
|
}
|
|
|
|
|
}
|
2024-03-16 05:33:47 +01:00
|
|
|
|
|
|
|
|
impl Default for Slider {
|
|
|
|
|
fn default() -> Self {
|
|
|
|
|
Self::new()
|
|
|
|
|
}
|
|
|
|
|
}
|