From d7bacbcc3f5a3de4d6042dbb30e56ad3972b4b69 Mon Sep 17 00:00:00 2001 From: Arman Uguray Date: Sun, 5 Mar 2023 11:26:58 -0800 Subject: [PATCH] [frame_stats] Build stats layer layout based on viewport dimensions --- examples/with_winit/src/lib.rs | 7 +++++- examples/with_winit/src/stats.rs | 37 +++++++++++++++++++++----------- 2 files changed, 31 insertions(+), 13 deletions(-) diff --git a/examples/with_winit/src/lib.rs b/examples/with_winit/src/lib.rs index 80e7112..e0281e2 100644 --- a/examples/with_winit/src/lib.rs +++ b/examples/with_winit/src/lib.rs @@ -305,7 +305,12 @@ fn run( } builder.append(&fragment, Some(transform)); if stats_toggle { - snapshot.draw_layer(&mut builder, &mut scene_params.text, width as f64); + snapshot.draw_layer( + &mut builder, + &mut scene_params.text, + width as f64, + height as f64, + ); } let surface_texture = render_state .surface diff --git a/examples/with_winit/src/stats.rs b/examples/with_winit/src/stats.rs index bf5fb1b..9a3a1c9 100644 --- a/examples/with_winit/src/stats.rs +++ b/examples/with_winit/src/stats.rs @@ -33,45 +33,58 @@ pub struct Snapshot { } impl Snapshot { - pub fn draw_layer(&self, sb: &mut SceneBuilder, text: &mut SimpleText, width: f64) { - let x_offset = width - 450.; + pub fn draw_layer( + &self, + sb: &mut SceneBuilder, + text: &mut SimpleText, + viewport_width: f64, + viewport_height: f64, + ) { + let width = (viewport_width * 0.4).max(200.).min(400.); + let height = width * 0.3; + let x_offset = viewport_width - width; + let y_offset = viewport_height - height; + let offset = Affine::translate((x_offset, y_offset)); + let text_height = height * 0.2; + let left_margin = width * 0.03; + let text_size = (text_height * 0.9) as f32; sb.fill( Fill::NonZero, - Affine::IDENTITY, + offset, &Brush::Solid(Color::rgba8(0, 0, 0, 200)), None, - &Rect::new(x_offset, 0., width, 115.), + &Rect::new(0., 0., width, height), ); text.add( sb, None, - 25., + text_size, Some(&Brush::Solid(Color::WHITE)), - Affine::translate((x_offset + 15., 30.)), + offset * Affine::translate((left_margin, text_height)), &format!("Frame Time: {:.2} ms", self.frame_time_ms), ); text.add( sb, None, - 25., + text_size, Some(&Brush::Solid(Color::WHITE)), - Affine::translate((x_offset + 15., 60.)), + offset * Affine::translate((left_margin, 2. * text_height)), &format!("Frame Time (min): {:.2} ms", self.frame_time_min_ms), ); text.add( sb, None, - 25., + text_size, Some(&Brush::Solid(Color::WHITE)), - Affine::translate((x_offset + 15., 90.)), + offset * Affine::translate((left_margin, 3. * text_height)), &format!("Frame Time (max): {:.2} ms", self.frame_time_max_ms), ); text.add( sb, None, - 25., + text_size, Some(&Brush::Solid(Color::WHITE)), - Affine::translate((x_offset + 300., 30.)), + offset * Affine::translate((width * 0.67, text_height)), &format!("FPS: {:.2}", self.fps), ); }