Add a hacky model bounding box info to rendering UI

Closes #134

Signed-off-by: Daniel Egger <daniel@eggers-club.de>
This commit is contained in:
Daniel Egger 2022-02-19 16:08:49 +01:00
parent 9fb0f40bc2
commit 33a67ca549
4 changed files with 44 additions and 9 deletions

View File

@ -6,6 +6,8 @@ use wgpu_glyph::{
GlyphBrush, GlyphBrushBuilder, Section, Text, GlyphBrush, GlyphBrushBuilder, Section, Text,
}; };
use crate::math::Aabb;
use super::{draw_config::DrawConfig, COLOR_FORMAT}; use super::{draw_config::DrawConfig, COLOR_FORMAT};
#[derive(Debug)] #[derive(Debug)]
@ -45,6 +47,7 @@ impl ConfigUi {
encoder: &mut wgpu::CommandEncoder, encoder: &mut wgpu::CommandEncoder,
view: &wgpu::TextureView, view: &wgpu::TextureView,
surface_config: &wgpu::SurfaceConfiguration, surface_config: &wgpu::SurfaceConfiguration,
aabb: &Aabb<3>,
draw_config: &DrawConfig, draw_config: &DrawConfig,
) -> Result<(), String> { ) -> Result<(), String> {
let mut section = Section::new().with_screen_position((50.0, 50.0)); let mut section = Section::new().with_screen_position((50.0, 50.0));
@ -62,6 +65,19 @@ impl ConfigUi {
section = section.add_text(text); section = section.add_text(text);
} }
/* Render size of model bounding box */
let bbsize = aabb.size().components();
let info = format!(
"Model bounding box size: {:0.1} {:0.1} {:0.1}",
bbsize[0].into_f32(),
bbsize[1].into_f32(),
bbsize[2].into_f32()
);
let text = Text::new(&info)
.with_color([0.0, 0.0, 0.0, 1.0])
.with_scale(50.0);
section = section.add_text(text);
self.glyph_brush.queue(section); self.glyph_brush.queue(section);
self.glyph_brush.draw_queued( self.glyph_brush.draw_queued(
device, device,

View File

@ -1,3 +1,4 @@
use crate::math::Aabb;
use std::convert::TryInto; use std::convert::TryInto;
use wgpu::util::DeviceExt; use wgpu::util::DeviceExt;
@ -8,6 +9,7 @@ use super::vertices::{Vertex, Vertices};
pub struct Geometries { pub struct Geometries {
pub mesh: Geometry, pub mesh: Geometry,
pub lines: Geometry, pub lines: Geometry,
pub aabb: Aabb<3>,
} }
impl Geometries { impl Geometries {
@ -15,12 +17,13 @@ impl Geometries {
device: &wgpu::Device, device: &wgpu::Device,
mesh: &Vertices, mesh: &Vertices,
debug_info: &Vertices, debug_info: &Vertices,
aabb: Aabb<3>,
) -> Self { ) -> Self {
let mesh = Geometry::new(device, mesh.vertices(), mesh.indices()); let mesh = Geometry::new(device, mesh.vertices(), mesh.indices());
let lines = let lines =
Geometry::new(device, debug_info.vertices(), debug_info.indices()); Geometry::new(device, debug_info.vertices(), debug_info.indices());
Self { mesh, lines } Self { mesh, lines, aabb }
} }
} }

View File

@ -6,7 +6,7 @@ use wgpu::util::DeviceExt as _;
use wgpu_glyph::ab_glyph::InvalidFont; use wgpu_glyph::ab_glyph::InvalidFont;
use winit::dpi::PhysicalSize; use winit::dpi::PhysicalSize;
use crate::{camera::Camera, window::Window}; use crate::{camera::Camera, math::Aabb, math::Point, window::Window};
use super::{ use super::{
config_ui::ConfigUi, draw_config::DrawConfig, drawables::Drawables, config_ui::ConfigUi, draw_config::DrawConfig, drawables::Drawables,
@ -114,8 +114,15 @@ impl Renderer {
label: None, label: None,
}); });
let geometries = let geometries = Geometries::new(
Geometries::new(&device, &Vertices::empty(), &Vertices::empty()); &device,
&Vertices::empty(),
&Vertices::empty(),
Aabb {
min: Point::from([0.0, 0.0, 0.0]),
max: Point::from([0.0, 0.0, 0.0]),
},
);
let pipelines = Pipelines::new(&device, &bind_group_layout); let pipelines = Pipelines::new(&device, &bind_group_layout);
let config_ui = ConfigUi::new(&device)?; let config_ui = ConfigUi::new(&device)?;
@ -138,8 +145,13 @@ impl Renderer {
}) })
} }
pub fn update_geometry(&mut self, mesh: Vertices, lines: Vertices) { pub fn update_geometry(
self.geometries = Geometries::new(&self.device, &mesh, &lines); &mut self,
mesh: Vertices,
lines: Vertices,
aabb: Aabb<3>,
) {
self.geometries = Geometries::new(&self.device, &mesh, &lines, aabb);
} }
pub fn handle_resize(&mut self, size: PhysicalSize<u32>) { pub fn handle_resize(&mut self, size: PhysicalSize<u32>) {
@ -216,6 +228,7 @@ impl Renderer {
&mut encoder, &mut encoder,
&color_view, &color_view,
&self.surface_config, &self.surface_config,
&self.geometries.aabb,
config, config,
) )
.map_err(|err| DrawError::Text(err))?; .map_err(|err| DrawError::Text(err))?;

View File

@ -196,7 +196,7 @@ fn main() -> anyhow::Result<()> {
let mut input_handler = input::Handler::new(previous_time); let mut input_handler = input::Handler::new(previous_time);
let mut renderer = block_on(Renderer::new(&window))?; let mut renderer = block_on(Renderer::new(&window))?;
renderer.update_geometry((&triangles).into(), (&debug_info).into()); renderer.update_geometry((&triangles).into(), (&debug_info).into(), aabb);
let mut draw_config = DrawConfig::default(); let mut draw_config = DrawConfig::default();
let mut camera = Camera::new(&aabb); let mut camera = Camera::new(&aabb);
@ -218,8 +218,11 @@ fn main() -> anyhow::Result<()> {
aabb = shape.bounding_volume(); aabb = shape.bounding_volume();
faces.triangles(tolerance, &mut triangles, &mut debug_info); faces.triangles(tolerance, &mut triangles, &mut debug_info);
renderer renderer.update_geometry(
.update_geometry((&triangles).into(), (&debug_info).into()); (&triangles).into(),
(&debug_info).into(),
aabb,
);
} }
Err(mpsc::TryRecvError::Empty) => { Err(mpsc::TryRecvError::Empty) => {
// Nothing to receive from the channel. We don't care. // Nothing to receive from the channel. We don't care.