summaryrefslogtreecommitdiffstats
path: root/examples/stopwatch/src
diff options
context:
space:
mode:
Diffstat (limited to 'examples/stopwatch/src')
-rw-r--r--examples/stopwatch/src/main.rs91
1 files changed, 29 insertions, 62 deletions
diff --git a/examples/stopwatch/src/main.rs b/examples/stopwatch/src/main.rs
index dc8a4de7..b8cee807 100644
--- a/examples/stopwatch/src/main.rs
+++ b/examples/stopwatch/src/main.rs
@@ -1,7 +1,12 @@
+use iced::alignment;
+use iced::executor;
+use iced::theme::{self, Theme};
+use iced::time;
+use iced::widget::{button, column, container, row, text};
use iced::{
- alignment, button, executor, time, Alignment, Application, Button, Column,
- Command, Container, Element, Length, Row, Settings, Subscription, Text,
+ Alignment, Application, Command, Element, Length, Settings, Subscription,
};
+
use std::time::{Duration, Instant};
pub fn main() -> iced::Result {
@@ -11,8 +16,6 @@ pub fn main() -> iced::Result {
struct Stopwatch {
duration: Duration,
state: State,
- toggle: button::State,
- reset: button::State,
}
enum State {
@@ -28,8 +31,9 @@ enum Message {
}
impl Application for Stopwatch {
- type Executor = executor::Default;
type Message = Message;
+ type Theme = Theme;
+ type Executor = executor::Default;
type Flags = ();
fn new(_flags: ()) -> (Stopwatch, Command<Message>) {
@@ -37,8 +41,6 @@ impl Application for Stopwatch {
Stopwatch {
duration: Duration::default(),
state: State::Idle,
- toggle: button::State::new(),
- reset: button::State::new(),
},
Command::none(),
)
@@ -60,13 +62,12 @@ impl Application for Stopwatch {
self.state = State::Idle;
}
},
- Message::Tick(now) => match &mut self.state {
- State::Ticking { last_tick } => {
+ Message::Tick(now) => {
+ if let State::Ticking { last_tick } = &mut self.state {
self.duration += now - *last_tick;
*last_tick = now;
}
- _ => {}
- },
+ }
Message::Reset => {
self.duration = Duration::default();
}
@@ -84,13 +85,13 @@ impl Application for Stopwatch {
}
}
- fn view(&mut self) -> Element<Message> {
+ fn view(&self) -> Element<Message> {
const MINUTE: u64 = 60;
const HOUR: u64 = 60 * MINUTE;
let seconds = self.duration.as_secs();
- let duration = Text::new(format!(
+ let duration = text(format!(
"{:0>2}:{:0>2}:{:0>2}.{:0>2}",
seconds / HOUR,
(seconds % HOUR) / MINUTE,
@@ -99,42 +100,34 @@ impl Application for Stopwatch {
))
.size(40);
- let button = |state, label, style| {
- Button::new(
- state,
- Text::new(label)
- .horizontal_alignment(alignment::Horizontal::Center),
+ let button = |label| {
+ button(
+ text(label).horizontal_alignment(alignment::Horizontal::Center),
)
- .min_width(80)
.padding(10)
- .style(style)
+ .width(Length::Units(80))
};
let toggle_button = {
- let (label, color) = match self.state {
- State::Idle => ("Start", style::Button::Primary),
- State::Ticking { .. } => ("Stop", style::Button::Destructive),
+ let label = match self.state {
+ State::Idle => "Start",
+ State::Ticking { .. } => "Stop",
};
- button(&mut self.toggle, label, color).on_press(Message::Toggle)
+ button(label).on_press(Message::Toggle)
};
- let reset_button =
- button(&mut self.reset, "Reset", style::Button::Secondary)
- .on_press(Message::Reset);
+ let reset_button = button("Reset")
+ .style(theme::Button::Destructive)
+ .on_press(Message::Reset);
- let controls = Row::new()
- .spacing(20)
- .push(toggle_button)
- .push(reset_button);
+ let controls = row![toggle_button, reset_button].spacing(20);
- let content = Column::new()
+ let content = column![duration, controls]
.align_items(Alignment::Center)
- .spacing(20)
- .push(duration)
- .push(controls);
+ .spacing(20);
- Container::new(content)
+ container(content)
.width(Length::Fill)
.height(Length::Fill)
.center_x()
@@ -142,29 +135,3 @@ impl Application for Stopwatch {
.into()
}
}
-
-mod style {
- use iced::{button, Background, Color, Vector};
-
- pub enum Button {
- Primary,
- Secondary,
- Destructive,
- }
-
- impl button::StyleSheet for Button {
- fn active(&self) -> button::Style {
- button::Style {
- background: Some(Background::Color(match self {
- Button::Primary => Color::from_rgb(0.11, 0.42, 0.87),
- Button::Secondary => Color::from_rgb(0.5, 0.5, 0.5),
- Button::Destructive => Color::from_rgb(0.8, 0.2, 0.2),
- })),
- border_radius: 12.0,
- shadow_offset: Vector::new(1.0, 1.0),
- text_color: Color::WHITE,
- ..button::Style::default()
- }
- }
- }
-}