diff options
author | 2019-11-02 19:58:49 +0100 | |
---|---|---|
committer | 2019-11-02 19:58:49 +0100 | |
commit | 58e04af824a64d9f712a2d6691d4283888d271d3 (patch) | |
tree | 1408e07b0eb618d9a64ad6a9a0d8953832dc2aa8 /native | |
parent | f3baae92282566ccb6ff3689a08fcaa907430ef7 (diff) | |
download | iced-58e04af824a64d9f712a2d6691d4283888d271d3.tar.gz iced-58e04af824a64d9f712a2d6691d4283888d271d3.tar.bz2 iced-58e04af824a64d9f712a2d6691d4283888d271d3.zip |
Draft `Metrics` and improve `Target` abstraction
Diffstat (limited to 'native')
-rw-r--r-- | native/src/lib.rs | 2 | ||||
-rw-r--r-- | native/src/metrics.rs | 11 | ||||
-rw-r--r-- | native/src/renderer.rs | 2 | ||||
-rw-r--r-- | native/src/renderer/windowed.rs | 24 |
4 files changed, 32 insertions, 7 deletions
diff --git a/native/src/lib.rs b/native/src/lib.rs index fa72a553..86bfb3ca 100644 --- a/native/src/lib.rs +++ b/native/src/lib.rs @@ -206,6 +206,7 @@ mod element; mod event; mod hasher; mod layout; +mod metrics; mod mouse_cursor; mod node; mod style; @@ -224,6 +225,7 @@ pub use element::Element; pub use event::Event; pub use hasher::Hasher; pub use layout::Layout; +pub use metrics::Metrics; pub use mouse_cursor::MouseCursor; pub use node::Node; pub use renderer::Renderer; diff --git a/native/src/metrics.rs b/native/src/metrics.rs new file mode 100644 index 00000000..7c344b9b --- /dev/null +++ b/native/src/metrics.rs @@ -0,0 +1,11 @@ +use std::time; + +/// A bunch of metrics about an Iced application. +#[derive(Debug, Clone, Copy)] +pub struct Metrics { + pub startup_time: time::Duration, + pub update_time: time::Duration, + pub view_time: time::Duration, + pub renderer_output_time: time::Duration, + pub message_count: usize, +} diff --git a/native/src/renderer.rs b/native/src/renderer.rs index afe1b09a..5963d577 100644 --- a/native/src/renderer.rs +++ b/native/src/renderer.rs @@ -24,7 +24,7 @@ mod debugger; mod windowed; pub use debugger::Debugger; -pub use windowed::Windowed; +pub use windowed::{Target, Windowed}; pub trait Renderer { type Output; diff --git a/native/src/renderer/windowed.rs b/native/src/renderer/windowed.rs index bcf37964..0499ca70 100644 --- a/native/src/renderer/windowed.rs +++ b/native/src/renderer/windowed.rs @@ -1,17 +1,29 @@ -use crate::MouseCursor; +use crate::{Metrics, MouseCursor}; use raw_window_handle::HasRawWindowHandle; -pub trait Windowed: super::Renderer { - type Target; +pub trait Windowed: super::Renderer + Sized { + type Target: Target<Renderer = Self>; - fn new<W: HasRawWindowHandle>(window: &W) -> Self; - - fn target(&self, width: u16, height: u16) -> Self::Target; + fn new() -> Self; fn draw( &mut self, output: &Self::Output, + metrics: Option<Metrics>, target: &mut Self::Target, ) -> MouseCursor; } + +pub trait Target { + type Renderer; + + fn new<W: HasRawWindowHandle>( + window: &W, + width: u16, + height: u16, + renderer: &Self::Renderer, + ) -> Self; + + fn resize(&mut self, width: u16, height: u16, renderer: &Self::Renderer); +} |