summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorLibravatar Héctor Ramón <hector0193@gmail.com>2020-06-20 19:20:37 +0200
committerLibravatar GitHub <noreply@github.com>2020-06-20 19:20:37 +0200
commiteec65a055fd4dbec5684611edc77338db0e6330e (patch)
tree840b2427350682b7e9448c64fdc6121364004e39 /src
parent1432c82bdf43c6febd6a9153a71302e37347e524 (diff)
parentc9696ca687446d78de374a828183de0a5e4bace3 (diff)
downloadiced-eec65a055fd4dbec5684611edc77338db0e6330e.tar.gz
iced-eec65a055fd4dbec5684611edc77338db0e6330e.tar.bz2
iced-eec65a055fd4dbec5684611edc77338db0e6330e.zip
Merge pull request #415 from hecrj/feature/configurable-scale-factor
Add `scale_factor` to `Application` and `Sandbox`
Diffstat (limited to 'src')
-rw-r--r--src/application.rs19
-rw-r--r--src/sandbox.rs21
2 files changed, 39 insertions, 1 deletions
diff --git a/src/application.rs b/src/application.rs
index b9b71645..47b89dbd 100644
--- a/src/application.rs
+++ b/src/application.rs
@@ -186,6 +186,21 @@ pub trait Application: Sized {
Color::WHITE
}
+ /// Returns the scale factor of the [`Application`].
+ ///
+ /// It can be used to dynamically control the size of the UI at runtime
+ /// (i.e. zooming).
+ ///
+ /// For instance, a scale factor of `2.0` will make widgets twice as big,
+ /// while a scale factor of `0.5` will shrink them to half their size.
+ ///
+ /// By default, it returns `1.0`.
+ ///
+ /// [`Application`]: trait.Application.html
+ fn scale_factor(&self) -> f64 {
+ 1.0
+ }
+
/// Runs the [`Application`].
///
/// On native platforms, this method will take control of the current thread
@@ -273,6 +288,10 @@ where
fn background_color(&self) -> Color {
self.0.background_color()
}
+
+ fn scale_factor(&self) -> f64 {
+ self.0.scale_factor()
+ }
}
#[cfg(target_arch = "wasm32")]
diff --git a/src/sandbox.rs b/src/sandbox.rs
index 729d9103..6a73eab0 100644
--- a/src/sandbox.rs
+++ b/src/sandbox.rs
@@ -130,12 +130,27 @@ pub trait Sandbox {
///
/// By default, it returns [`Color::WHITE`].
///
- /// [`Application`]: trait.Application.html
+ /// [`Sandbox`]: trait.Sandbox.html
/// [`Color::WHITE`]: struct.Color.html#const.WHITE
fn background_color(&self) -> Color {
Color::WHITE
}
+ /// Returns the scale factor of the [`Sandbox`].
+ ///
+ /// It can be used to dynamically control the size of the UI at runtime
+ /// (i.e. zooming).
+ ///
+ /// For instance, a scale factor of `2.0` will make widgets twice as big,
+ /// while a scale factor of `0.5` will shrink them to half their size.
+ ///
+ /// By default, it returns `1.0`.
+ ///
+ /// [`Sandbox`]: trait.Sandbox.html
+ fn scale_factor(&self) -> f64 {
+ 1.0
+ }
+
/// Runs the [`Sandbox`].
///
/// On native platforms, this method will take control of the current thread
@@ -185,4 +200,8 @@ where
fn background_color(&self) -> Color {
T::background_color(self)
}
+
+ fn scale_factor(&self) -> f64 {
+ T::scale_factor(self)
+ }
}