diff options
| author | 2022-02-10 21:54:13 +0700 | |
|---|---|---|
| committer | 2022-02-10 21:54:13 +0700 | |
| commit | 5225e0e304bf5b407977e549c48ce9dea26b8c40 (patch) | |
| tree | 8358ef6152f743e87a9d83d8deb3aa47e877cd88 /examples/virtual_counter | |
| parent | 8f0839e786f8d521f7319dd0e188d43284f526b7 (diff) | |
| download | iced-5225e0e304bf5b407977e549c48ce9dea26b8c40.tar.gz iced-5225e0e304bf5b407977e549c48ce9dea26b8c40.tar.bz2 iced-5225e0e304bf5b407977e549c48ce9dea26b8c40.zip | |
Draft virtual `Button`, `Column`, and `Text`
... as well as a very naive diffing strategy!
Diffstat (limited to 'examples/virtual_counter')
| -rw-r--r-- | examples/virtual_counter/Cargo.toml | 10 | ||||
| -rw-r--r-- | examples/virtual_counter/README.md | 18 | ||||
| -rw-r--r-- | examples/virtual_counter/index.html | 12 | ||||
| -rw-r--r-- | examples/virtual_counter/src/main.rs | 61 | 
4 files changed, 101 insertions, 0 deletions
| diff --git a/examples/virtual_counter/Cargo.toml b/examples/virtual_counter/Cargo.toml new file mode 100644 index 00000000..537d4174 --- /dev/null +++ b/examples/virtual_counter/Cargo.toml @@ -0,0 +1,10 @@ +[package] +name = "virtual_counter" +version = "0.1.0" +authors = ["Héctor Ramón Jiménez <hector0193@gmail.com>"] +edition = "2021" +publish = false + +[dependencies] +iced = { path = "../.." } +iced_virtual = { path = "../../virtual" } diff --git a/examples/virtual_counter/README.md b/examples/virtual_counter/README.md new file mode 100644 index 00000000..4d9fc5b9 --- /dev/null +++ b/examples/virtual_counter/README.md @@ -0,0 +1,18 @@ +## Counter + +The classic counter example explained in the [`README`](../../README.md). + +The __[`main`]__ file contains all the code of the example. + +<div align="center"> +  <a href="https://gfycat.com/fairdeadcatbird"> +    <img src="https://thumbs.gfycat.com/FairDeadCatbird-small.gif"> +  </a> +</div> + +You can run it with `cargo run`: +``` +cargo run --package counter +``` + +[`main`]: src/main.rs diff --git a/examples/virtual_counter/index.html b/examples/virtual_counter/index.html new file mode 100644 index 00000000..d2e368e4 --- /dev/null +++ b/examples/virtual_counter/index.html @@ -0,0 +1,12 @@ +<!DOCTYPE html> +<html lang="en"> +<head> +    <meta charset="utf-8" content="text/html; charset=utf-8" /> +    <meta name="viewport" content="width=device-width, initial-scale=1" /> +    <title>Counter - Iced</title> +    <base data-trunk-public-url /> +</head> +<body> +<link data-trunk rel="rust" href="Cargo.toml" data-wasm-opt="z" data-bin="counter" /> +</body> +</html> diff --git a/examples/virtual_counter/src/main.rs b/examples/virtual_counter/src/main.rs new file mode 100644 index 00000000..46e8320e --- /dev/null +++ b/examples/virtual_counter/src/main.rs @@ -0,0 +1,61 @@ +use iced::{Alignment, Element, Sandbox, Settings}; +use iced_virtual::{Button, Column, Text, Virtual}; + +pub fn main() -> iced::Result { +    Counter::run(Settings::default()) +} + +struct Counter { +    value: i32, +    state: iced_virtual::State<Message, iced::Renderer>, +} + +#[derive(Debug, Clone, Copy)] +enum Message { +    IncrementPressed, +    DecrementPressed, +} + +impl Sandbox for Counter { +    type Message = Message; + +    fn new() -> Self { +        Self { +            value: 0, +            state: iced_virtual::State::new(), +        } +    } + +    fn title(&self) -> String { +        String::from("Counter - Iced") +    } + +    fn update(&mut self, message: Message) { +        match message { +            Message::IncrementPressed => { +                self.value += 1; +            } +            Message::DecrementPressed => { +                self.value -= 1; +            } +        } +    } + +    fn view(&mut self) -> Element<Message> { +        let content = Column::new() +            .padding(20) +            .align_items(Alignment::Center) +            .push( +                Button::new(Text::new("Increment")) +                    .on_press(Message::IncrementPressed), +            ) +            .push(Text::new(self.value.to_string()).size(50)) +            .push( +                Button::new(Text::new("Decrement")) +                    .on_press(Message::DecrementPressed), +            ); + +        Virtual::new(&mut self.state, iced_virtual::Element::new(content)) +            .into() +    } +} | 
