summaryrefslogtreecommitdiffstats
path: root/native/src
diff options
context:
space:
mode:
authorLibravatar Héctor Ramón <hector0193@gmail.com>2019-11-05 21:46:37 +0100
committerLibravatar GitHub <noreply@github.com>2019-11-05 21:46:37 +0100
commitae6156f779c24beaabf43ea6110d3ce38e34a998 (patch)
tree9545408530437eb780ac73c600f7d40968803786 /native/src
parentda2717c74dbe3e1123ff41de345a409c1afc2f18 (diff)
parent0157121038987feb6c2ea3066a21ce25e689888e (diff)
downloadiced-ae6156f779c24beaabf43ea6110d3ce38e34a998.tar.gz
iced-ae6156f779c24beaabf43ea6110d3ce38e34a998.tar.bz2
iced-ae6156f779c24beaabf43ea6110d3ce38e34a998.zip
Merge pull request #38 from hecrj/feature/performance-metrics
Debug view
Diffstat (limited to 'native/src')
-rw-r--r--native/src/renderer.rs2
-rw-r--r--native/src/renderer/windowed.rs24
2 files changed, 19 insertions, 7 deletions
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..6e4ae611 100644
--- a/native/src/renderer/windowed.rs
+++ b/native/src/renderer/windowed.rs
@@ -2,16 +2,28 @@ use crate::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 new() -> Self;
- fn target(&self, width: u16, height: u16) -> Self::Target;
-
- fn draw(
+ fn draw<T: AsRef<str>>(
&mut self,
output: &Self::Output,
+ overlay: &[T],
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);
+}