summaryrefslogtreecommitdiffstats
path: root/examples/svg/src/main.rs
blob: e071c3afbf936f99d86eef9976b08fa8aca0cfc2 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
use iced::widget::{center, checkbox, column, container, svg};
use iced::{color, Element, Length};

pub fn main() -> iced::Result {
    iced::run("SVG - Iced", Tiger::update, Tiger::view)
}

#[derive(Debug, Default)]
struct Tiger {
    apply_color_filter: bool,
}

#[derive(Debug, Clone, Copy)]
pub enum Message {
    ToggleColorFilter(bool),
}

impl Tiger {
    fn update(&mut self, message: Message) {
        match message {
            Message::ToggleColorFilter(apply_color_filter) => {
                self.apply_color_filter = apply_color_filter;
            }
        }
    }

    fn view(&self) -> Element<Message> {
        let handle = svg::Handle::from_path(format!(
            "{}/resources/tiger.svg",
            env!("CARGO_MANIFEST_DIR")
        ));

        let svg = svg(handle).width(Length::Fill).height(Length::Fill).style(
            |_theme, _status| svg::Style {
                color: if self.apply_color_filter {
                    Some(color!(0x0000ff))
                } else {
                    None
                },
            },
        );

        let apply_color_filter =
            checkbox("Apply a color filter", self.apply_color_filter)
                .on_toggle(Message::ToggleColorFilter);

        center(
            column![svg, container(apply_color_filter).center_x(Length::Fill)]
                .spacing(20)
                .height(Length::Fill),
        )
        .padding(20)
        .into()
    }
}