From e44b1ba30608894743a94021913946f59f77d9cf Mon Sep 17 00:00:00 2001 From: Dave Corley Date: Wed, 23 Oct 2024 01:54:14 -0700 Subject: [PATCH] FEAT: Make face inversion face-specific instead of brush-specific --- resources/GameConfig.cfg | 6 +++--- src/brush_ni_node.rs | 31 +++++++++---------------------- src/surfaces.rs | 5 ++--- 3 files changed, 14 insertions(+), 28 deletions(-) diff --git a/resources/GameConfig.cfg b/resources/GameConfig.cfg index 8483eee..7a27799 100644 --- a/resources/GameConfig.cfg +++ b/resources/GameConfig.cfg @@ -51,14 +51,14 @@ { "name": "Smooth Shading", "description": "Use phong shading. Value key above will set the shading group *not yet implemented*" - } - ], - "contentflags": [ + }, { "name": "Invert Faces", "description": "Draw the rendered mesh inside-out; intended for use with fake skyboxes." } ], + "contentflags": [ + ], "defaults": { "scale": [0.25, 0.25] } diff --git a/src/brush_ni_node.rs b/src/brush_ni_node.rs index 10d3ad6..cb3bae0 100644 --- a/src/brush_ni_node.rs +++ b/src/brush_ni_node.rs @@ -316,7 +316,7 @@ impl BrushNiNode { continue; }; - let (content_flags, mut surface_flags, _value) = match &map_data + let (_content_flags, mut surface_flags, _value) = match &map_data .geomap .face_extensions .get(face_id) @@ -332,27 +332,17 @@ impl BrushNiNode { let vertices = &map_data.face_vertices.get(&face_id).unwrap(); - let mut use_inverted_tris = false; - - if content_flags & surfaces::NiBroomContent::InvertFaces as u32 == 1 { - use_inverted_tris = true; - } - - let mut indices = if use_inverted_tris { + let indices = if surface_flags & surfaces::NiBroomSurface::InvertFaces as u32 != 0 { map_data.inverted_face_tri_indices.get(&face_id).unwrap_or_else(|| { panic!("Critical error: Missing inverted face triangle indices for face_id: {:?}", face_id) -}).clone() +}) } else { - map_data - .face_tri_indices - .get(&face_id) - .unwrap_or_else(|| { - panic!( - "Critical error: Missing face triangle indices for face_id: {:?}", - face_id - ) - }) - .clone() + map_data.face_tri_indices.get(&face_id).unwrap_or_else(|| { + panic!( + "Critical error: Missing face triangle indices for face_id: {:?}", + face_id + ) + }) }; // We can't do fuzzier matches on this, so, @@ -367,9 +357,6 @@ panic!("Critical error: Missing inverted face triangle indices for face_id: {:?} || texture_name.to_ascii_lowercase().contains("lava") || texture_name.to_ascii_lowercase().contains("mwat") { - let inverted_indices = map_data.inverted_face_tri_indices.get(&face_id).unwrap(); - indices.extend_from_slice(inverted_indices); - surface_flags |= surfaces::NiBroomSurface::NoClip as u32; println!("{face_id} interpreted as liquid") } diff --git a/src/surfaces.rs b/src/surfaces.rs index 719ff20..e08da40 100644 --- a/src/surfaces.rs +++ b/src/surfaces.rs @@ -6,8 +6,7 @@ pub mod colors {} pub enum NiBroomSurface { NoClip = 1, SmoothShading = 2, + InvertFaces = 4, } -pub enum NiBroomContent { - InvertFaces = 1, -} +pub enum NiBroomContent {}