summaryrefslogtreecommitdiffstats
path: root/examples/vectorial_text
diff options
context:
space:
mode:
authorLibravatar Héctor Ramón <hector@hecrj.dev>2024-03-16 17:09:00 +0100
committerLibravatar GitHub <noreply@github.com>2024-03-16 17:09:00 +0100
commit503a48e89977437bf8b7bf485f416a15a2e83ed0 (patch)
tree30306bbaee7a31090ace9d7725d46c2c0027fe6b /examples/vectorial_text
parent0524e9b4571d264018656418f02a1f9e27e268d7 (diff)
parentcfc0383bbfff083786840e3f1fd499e5991fa629 (diff)
downloadiced-503a48e89977437bf8b7bf485f416a15a2e83ed0.tar.gz
iced-503a48e89977437bf8b7bf485f416a15a2e83ed0.tar.bz2
iced-503a48e89977437bf8b7bf485f416a15a2e83ed0.zip
Merge pull request #2331 from iced-rs/program-api
`Program` API
Diffstat (limited to 'examples/vectorial_text')
-rw-r--r--examples/vectorial_text/src/main.rs42
1 files changed, 17 insertions, 25 deletions
diff --git a/examples/vectorial_text/src/main.rs b/examples/vectorial_text/src/main.rs
index 0b9ea938..84347203 100644
--- a/examples/vectorial_text/src/main.rs
+++ b/examples/vectorial_text/src/main.rs
@@ -3,18 +3,20 @@ use iced::mouse;
use iced::widget::{
canvas, checkbox, column, horizontal_space, row, slider, text,
};
-use iced::{
- Element, Length, Point, Rectangle, Renderer, Sandbox, Settings, Theme,
- Vector,
-};
+use iced::{Element, Length, Point, Rectangle, Renderer, Theme, Vector};
pub fn main() -> iced::Result {
- VectorialText::run(Settings {
- antialiasing: true,
- ..Settings::default()
- })
+ iced::sandbox(
+ "Vectorial Text - Iced",
+ VectorialText::update,
+ VectorialText::view,
+ )
+ .theme(|_| Theme::Dark)
+ .antialiased()
+ .run()
}
+#[derive(Default)]
struct VectorialText {
state: State,
}
@@ -27,19 +29,7 @@ enum Message {
ToggleJapanese(bool),
}
-impl Sandbox for VectorialText {
- type Message = Message;
-
- fn new() -> Self {
- Self {
- state: State::new(),
- }
- }
-
- fn title(&self) -> String {
- String::from("Vectorial Text - Iced")
- }
-
+impl VectorialText {
fn update(&mut self, message: Message) {
match message {
Message::SizeChanged(size) => {
@@ -106,10 +96,6 @@ impl Sandbox for VectorialText {
.padding(20)
.into()
}
-
- fn theme(&self) -> Theme {
- Theme::Dark
- }
}
struct State {
@@ -170,3 +156,9 @@ impl<Message> canvas::Program<Message> for State {
vec![geometry]
}
}
+
+impl Default for State {
+ fn default() -> Self {
+ State::new()
+ }
+}