Implement iced::Sandbox trait for simple apps

This commit is contained in:
Héctor Ramón Jiménez 2019-11-21 18:00:27 +01:00
parent 428509c84a
commit ba56a561b2
4 changed files with 131 additions and 86 deletions

View File

@ -1,7 +1,7 @@
use iced::{ use iced::{
button, scrollable, slider, text_input, Application, Background, Button, button, scrollable, slider, text_input, Background, Button, Checkbox,
Checkbox, Color, Column, Command, Container, Element, HorizontalAlignment, Color, Column, Container, Element, HorizontalAlignment, Image, Length,
Image, Length, Radio, Row, Scrollable, Slider, Text, TextInput, Radio, Row, Sandbox, Scrollable, Slider, Text, TextInput,
}; };
pub fn main() { pub fn main() {
@ -18,27 +18,24 @@ pub struct Tour {
debug: bool, debug: bool,
} }
impl Application for Tour { impl Sandbox for Tour {
type Message = Message; type Message = Message;
fn new() -> (Tour, Command<Message>) { fn new() -> Tour {
(
Tour { Tour {
steps: Steps::new(), steps: Steps::new(),
scroll: scrollable::State::new(), scroll: scrollable::State::new(),
back_button: button::State::new(), back_button: button::State::new(),
next_button: button::State::new(), next_button: button::State::new(),
debug: true, debug: true,
}, }
Command::none(),
)
} }
fn title(&self) -> String { fn title(&self) -> String {
format!("{} - Iced", self.steps.title()) format!("{} - Iced", self.steps.title())
} }
fn update(&mut self, event: Message) -> Command<Message> { fn update(&mut self, event: Message) {
match event { match event {
Message::BackPressed => { Message::BackPressed => {
self.steps.go_back(); self.steps.go_back();
@ -50,8 +47,6 @@ impl Application for Tour {
self.steps.update(step_msg, &mut self.debug); self.steps.update(step_msg, &mut self.debug);
} }
} }
Command::none()
} }
fn view(&mut self) -> Element<Message> { fn view(&mut self) -> Element<Message> {

69
src/application.rs Normal file
View File

@ -0,0 +1,69 @@
use crate::{Command, Element};
pub trait Application: Sized {
type Message: std::fmt::Debug + Send;
fn new() -> (Self, Command<Self::Message>);
fn title(&self) -> String;
fn update(&mut self, message: Self::Message) -> Command<Self::Message>;
fn view(&mut self) -> Element<Self::Message>;
fn run()
where
Self: 'static + Sized,
{
#[cfg(not(target_arch = "wasm32"))]
<Instance<Self> as iced_winit::Application>::run();
#[cfg(target_arch = "wasm32")]
iced_web::Application::run(Instance(self));
}
}
struct Instance<A: Application>(A);
#[cfg(not(target_arch = "wasm32"))]
impl<A> iced_winit::Application for Instance<A>
where
A: Application,
{
type Renderer = iced_wgpu::Renderer;
type Message = A::Message;
fn new() -> (Self, Command<A::Message>) {
let (app, command) = A::new();
(Instance(app), command)
}
fn title(&self) -> String {
self.0.title()
}
fn update(&mut self, message: Self::Message) -> Command<Self::Message> {
self.0.update(message)
}
fn view(&mut self) -> Element<Self::Message> {
self.0.view()
}
}
#[cfg(target_arch = "wasm32")]
impl<A> iced_web::Application for Instance<A>
where
A: Application,
{
type Message = A::Message;
fn update(&mut self, message: Self::Message) {
self.0.update(message);
}
fn view(&mut self) -> Element<Self::Message> {
self.0.view()
}
}

View File

@ -1,73 +1,9 @@
mod application;
#[cfg_attr(target_arch = "wasm32", path = "web.rs")] #[cfg_attr(target_arch = "wasm32", path = "web.rs")]
#[cfg_attr(not(target_arch = "wasm32"), path = "native.rs")] #[cfg_attr(not(target_arch = "wasm32"), path = "native.rs")]
mod platform; mod platform;
mod sandbox;
pub use application::Application;
pub use platform::*; pub use platform::*;
pub use sandbox::Sandbox;
pub trait Application: Sized {
type Message: std::fmt::Debug + Send;
fn new() -> (Self, Command<Self::Message>);
fn title(&self) -> String;
fn update(&mut self, message: Self::Message) -> Command<Self::Message>;
fn view(&mut self) -> Element<Self::Message>;
fn run()
where
Self: 'static + Sized,
{
#[cfg(not(target_arch = "wasm32"))]
<Instance<Self> as iced_winit::Application>::run();
#[cfg(target_arch = "wasm32")]
iced_web::Application::run(Instance(self));
}
}
struct Instance<A: Application>(A);
#[cfg(not(target_arch = "wasm32"))]
impl<A> iced_winit::Application for Instance<A>
where
A: Application,
{
type Renderer = iced_wgpu::Renderer;
type Message = A::Message;
fn new() -> (Self, Command<A::Message>) {
let (app, command) = A::new();
(Instance(app), command)
}
fn title(&self) -> String {
self.0.title()
}
fn update(&mut self, message: Self::Message) -> Command<Self::Message> {
self.0.update(message)
}
fn view(&mut self) -> Element<Self::Message> {
self.0.view()
}
}
#[cfg(target_arch = "wasm32")]
impl<A> iced_web::Application for Instance<A>
where
A: Application,
{
type Message = A::Message;
fn update(&mut self, message: Self::Message) {
self.0.update(message);
}
fn view(&mut self) -> Element<Self::Message> {
self.0.view()
}
}

45
src/sandbox.rs Normal file
View File

@ -0,0 +1,45 @@
use crate::{Application, Command, Element};
pub trait Sandbox {
type Message: std::fmt::Debug + Send;
fn new() -> Self;
fn title(&self) -> String;
fn update(&mut self, message: Self::Message);
fn view(&mut self) -> Element<Self::Message>;
fn run()
where
Self: 'static + Sized,
{
<Self as Application>::run()
}
}
impl<T> Application for T
where
T: Sandbox,
{
type Message = T::Message;
fn new() -> (Self, Command<T::Message>) {
(T::new(), Command::none())
}
fn title(&self) -> String {
T::title(self)
}
fn update(&mut self, message: T::Message) -> Command<T::Message> {
T::update(self, message);
Command::none()
}
fn view(&mut self) -> Element<T::Message> {
T::view(self)
}
}