summaryrefslogtreecommitdiffstats
path: root/examples
diff options
context:
space:
mode:
authorLibravatar Héctor <hector@hecrj.dev>2024-10-02 17:23:33 +0200
committerLibravatar GitHub <noreply@github.com>2024-10-02 17:23:33 +0200
commit4a080e27ab05d33b6c053328a21746ac0af0e2a0 (patch)
treefe9fc2086dccec841bfd08da4f5493332b903ffe /examples
parentd5f278b31de1ba2d3df6cc8e1e617649e1f21869 (diff)
parentb02ec8b6b2f2bea68256a91e2a8a8c17198d4ce2 (diff)
downloadiced-4a080e27ab05d33b6c053328a21746ac0af0e2a0.tar.gz
iced-4a080e27ab05d33b6c053328a21746ac0af0e2a0.tar.bz2
iced-4a080e27ab05d33b6c053328a21746ac0af0e2a0.zip
Merge pull request #2606 from tvolk131/qr_code_fixed_size
feat: set total size of QRCode
Diffstat (limited to 'examples')
-rw-r--r--examples/qr_code/src/main.rs54
1 files changed, 44 insertions, 10 deletions
diff --git a/examples/qr_code/src/main.rs b/examples/qr_code/src/main.rs
index f1b654e0..2c892e3f 100644
--- a/examples/qr_code/src/main.rs
+++ b/examples/qr_code/src/main.rs
@@ -1,6 +1,10 @@
-use iced::widget::{center, column, pick_list, qr_code, row, text, text_input};
+use iced::widget::{
+ center, column, pick_list, qr_code, row, slider, text, text_input, toggler,
+};
use iced::{Center, Element, Theme};
+use std::ops::RangeInclusive;
+
pub fn main() -> iced::Result {
iced::application(
"QR Code Generator - Iced",
@@ -15,16 +19,21 @@ pub fn main() -> iced::Result {
struct QRGenerator {
data: String,
qr_code: Option<qr_code::Data>,
+ total_size: Option<f32>,
theme: Theme,
}
#[derive(Debug, Clone)]
enum Message {
DataChanged(String),
+ ToggleTotalSize(bool),
+ TotalSizeChanged(f32),
ThemeChanged(Theme),
}
impl QRGenerator {
+ const SIZE_RANGE: RangeInclusive<f32> = 200.0..=400.0;
+
fn update(&mut self, message: Message) {
match message {
Message::DataChanged(mut data) => {
@@ -38,6 +47,16 @@ impl QRGenerator {
self.data = data;
}
+ Message::ToggleTotalSize(enabled) => {
+ self.total_size = enabled.then_some(
+ Self::SIZE_RANGE.start()
+ + (Self::SIZE_RANGE.end() - Self::SIZE_RANGE.start())
+ / 2.0,
+ );
+ }
+ Message::TotalSizeChanged(total_size) => {
+ self.total_size = Some(total_size);
+ }
Message::ThemeChanged(theme) => {
self.theme = theme;
}
@@ -53,6 +72,10 @@ impl QRGenerator {
.size(30)
.padding(15);
+ let toggle_total_size = toggler(self.total_size.is_some())
+ .on_toggle(Message::ToggleTotalSize)
+ .label("Limit Total Size");
+
let choose_theme = row![
text("Theme:"),
pick_list(Theme::ALL, Some(&self.theme), Message::ThemeChanged,)
@@ -60,15 +83,26 @@ impl QRGenerator {
.spacing(10)
.align_y(Center);
- let content = column![title, input, choose_theme]
- .push_maybe(
- self.qr_code
- .as_ref()
- .map(|data| qr_code(data).cell_size(10)),
- )
- .width(700)
- .spacing(20)
- .align_x(Center);
+ let content = column![
+ title,
+ input,
+ row![toggle_total_size, choose_theme]
+ .spacing(20)
+ .align_y(Center)
+ ]
+ .push_maybe(self.total_size.map(|total_size| {
+ slider(Self::SIZE_RANGE, total_size, Message::TotalSizeChanged)
+ }))
+ .push_maybe(self.qr_code.as_ref().map(|data| {
+ if let Some(total_size) = self.total_size {
+ qr_code(data).total_size(total_size)
+ } else {
+ qr_code(data).cell_size(10.0)
+ }
+ }))
+ .width(700)
+ .spacing(20)
+ .align_x(Center);
center(content).padding(20).into()
}