2024-09-24 20:57:53 -05:00
|
|
|
use iced::widget::{
|
|
|
|
|
center, column, pick_list, qr_code, row, slider, text, text_input, toggler,
|
|
|
|
|
};
|
2024-07-12 18:12:34 +02:00
|
|
|
use iced::{Center, Element, Theme};
|
2020-11-20 10:26:08 +01:00
|
|
|
|
2024-09-24 20:57:53 -05:00
|
|
|
const QR_CODE_EXACT_SIZE_MIN_PX: u32 = 200;
|
|
|
|
|
const QR_CODE_EXACT_SIZE_MAX_PX: u32 = 400;
|
|
|
|
|
const QR_CODE_EXACT_SIZE_SLIDER_STEPS: u8 = 100;
|
|
|
|
|
|
2020-11-20 10:26:08 +01:00
|
|
|
pub fn main() -> iced::Result {
|
2024-06-19 01:53:40 +02:00
|
|
|
iced::application(
|
2024-03-16 16:12:07 +01:00
|
|
|
"QR Code Generator - Iced",
|
|
|
|
|
QRGenerator::update,
|
|
|
|
|
QRGenerator::view,
|
|
|
|
|
)
|
|
|
|
|
.theme(QRGenerator::theme)
|
|
|
|
|
.run()
|
2020-11-20 10:26:08 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#[derive(Default)]
|
|
|
|
|
struct QRGenerator {
|
|
|
|
|
data: String,
|
2024-02-09 23:57:11 +01:00
|
|
|
qr_code: Option<qr_code::Data>,
|
2024-09-24 20:57:53 -05:00
|
|
|
display_with_fixed_size: bool,
|
|
|
|
|
fixed_size_slider_value: u8,
|
2024-02-02 10:45:37 -06:00
|
|
|
theme: Theme,
|
2020-11-20 10:26:08 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#[derive(Debug, Clone)]
|
|
|
|
|
enum Message {
|
|
|
|
|
DataChanged(String),
|
2024-09-24 20:57:53 -05:00
|
|
|
SetDisplayWithFixedSize(bool),
|
|
|
|
|
FixedSizeSliderChanged(u8),
|
2024-02-02 10:45:37 -06:00
|
|
|
ThemeChanged(Theme),
|
2020-11-20 10:26:08 +01:00
|
|
|
}
|
|
|
|
|
|
2024-03-16 05:33:47 +01:00
|
|
|
impl QRGenerator {
|
2020-11-20 10:26:08 +01:00
|
|
|
fn update(&mut self, message: Message) {
|
|
|
|
|
match message {
|
|
|
|
|
Message::DataChanged(mut data) => {
|
|
|
|
|
data.truncate(100);
|
|
|
|
|
|
2023-01-20 13:46:09 +08:00
|
|
|
self.qr_code = if data.is_empty() {
|
|
|
|
|
None
|
|
|
|
|
} else {
|
2024-02-09 23:57:11 +01:00
|
|
|
qr_code::Data::new(&data).ok()
|
2023-01-20 13:56:02 +08:00
|
|
|
};
|
2023-02-17 13:57:04 +01:00
|
|
|
|
2020-11-20 10:26:08 +01:00
|
|
|
self.data = data;
|
|
|
|
|
}
|
2024-09-24 20:57:53 -05:00
|
|
|
Message::SetDisplayWithFixedSize(exact_size) => {
|
|
|
|
|
self.display_with_fixed_size = exact_size;
|
|
|
|
|
}
|
|
|
|
|
Message::FixedSizeSliderChanged(value) => {
|
|
|
|
|
self.fixed_size_slider_value = value;
|
|
|
|
|
}
|
2024-02-02 10:45:37 -06:00
|
|
|
Message::ThemeChanged(theme) => {
|
|
|
|
|
self.theme = theme;
|
|
|
|
|
}
|
2020-11-20 10:26:08 +01:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2022-07-27 06:49:20 +02:00
|
|
|
fn view(&self) -> Element<Message> {
|
2024-02-02 10:45:37 -06:00
|
|
|
let title = text("QR Code Generator").size(70);
|
2020-11-20 10:26:08 +01:00
|
|
|
|
2023-03-03 10:01:49 +03:00
|
|
|
let input =
|
|
|
|
|
text_input("Type the data of your QR code here...", &self.data)
|
2023-04-12 04:13:36 +02:00
|
|
|
.on_input(Message::DataChanged)
|
2023-03-03 10:01:49 +03:00
|
|
|
.size(30)
|
|
|
|
|
.padding(15);
|
2020-11-20 10:26:08 +01:00
|
|
|
|
2024-02-02 10:45:37 -06:00
|
|
|
let choose_theme = row![
|
|
|
|
|
text("Theme:"),
|
2024-02-14 03:54:40 +01:00
|
|
|
pick_list(Theme::ALL, Some(&self.theme), Message::ThemeChanged,)
|
2024-02-02 10:45:37 -06:00
|
|
|
]
|
|
|
|
|
.spacing(10)
|
2024-07-12 18:12:34 +02:00
|
|
|
.align_y(Center);
|
2024-02-02 10:45:37 -06:00
|
|
|
|
2024-02-15 02:38:07 +01:00
|
|
|
let content = column![title, input, choose_theme]
|
2024-09-24 20:57:53 -05:00
|
|
|
.push(
|
|
|
|
|
toggler(self.display_with_fixed_size)
|
|
|
|
|
.on_toggle(Message::SetDisplayWithFixedSize)
|
|
|
|
|
.label("Fixed Size"),
|
2024-02-15 02:38:07 +01:00
|
|
|
)
|
2024-09-24 20:57:53 -05:00
|
|
|
.push_maybe(self.display_with_fixed_size.then(|| {
|
|
|
|
|
slider(
|
|
|
|
|
1..=QR_CODE_EXACT_SIZE_SLIDER_STEPS,
|
|
|
|
|
self.fixed_size_slider_value,
|
|
|
|
|
Message::FixedSizeSliderChanged,
|
|
|
|
|
)
|
|
|
|
|
}))
|
|
|
|
|
.push_maybe(self.qr_code.as_ref().map(|data| {
|
|
|
|
|
if self.display_with_fixed_size {
|
|
|
|
|
// Convert the slider value to a size in pixels.
|
|
|
|
|
let qr_code_size_px = (self.fixed_size_slider_value as f32
|
|
|
|
|
/ QR_CODE_EXACT_SIZE_SLIDER_STEPS as f32)
|
|
|
|
|
* (QR_CODE_EXACT_SIZE_MAX_PX
|
|
|
|
|
- QR_CODE_EXACT_SIZE_MIN_PX)
|
|
|
|
|
as f32
|
|
|
|
|
+ QR_CODE_EXACT_SIZE_MIN_PX as f32;
|
|
|
|
|
|
|
|
|
|
qr_code(data).total_size(qr_code_size_px)
|
|
|
|
|
} else {
|
|
|
|
|
qr_code(data).cell_size(10.0)
|
|
|
|
|
}
|
|
|
|
|
}))
|
2023-02-04 12:24:13 +01:00
|
|
|
.width(700)
|
2020-11-20 10:26:08 +01:00
|
|
|
.spacing(20)
|
2024-07-12 18:12:34 +02:00
|
|
|
.align_x(Center);
|
2020-11-20 10:26:08 +01:00
|
|
|
|
2024-05-03 09:11:46 +02:00
|
|
|
center(content).padding(20).into()
|
2020-11-20 10:26:08 +01:00
|
|
|
}
|
2024-02-02 10:45:37 -06:00
|
|
|
|
|
|
|
|
fn theme(&self) -> Theme {
|
|
|
|
|
self.theme.clone()
|
|
|
|
|
}
|
2020-11-20 10:26:08 +01:00
|
|
|
}
|