From a29b4979ef69a7d061c0332cf6b1232472046cfa Mon Sep 17 00:00:00 2001 From: Jarrod Doyle Date: Sat, 13 May 2023 11:51:14 +0100 Subject: [PATCH] Simplify block gen code path when all corners are empty --- src/voxel/world.rs | 36 ++++++++++++++++++++---------------- 1 file changed, 20 insertions(+), 16 deletions(-) diff --git a/src/voxel/world.rs b/src/voxel/world.rs index 88f20fe..459dbff 100644 --- a/src/voxel/world.rs +++ b/src/voxel/world.rs @@ -39,25 +39,29 @@ impl Chunk { } } - let mut vals = [0.0f32; 512]; - if block_sign != -8.0 { + // If all the corners are negative, then all the interpolated values + // will be negative too. In that case we can just fill with empty. + if block_sign == -8.0 { + block.resize(512, Voxel::Empty); + } else { + let mut vals = [0.0f32; 512]; math::tri_lerp_block(&noise_vals, &[8, 8, 8], &mut vals); - } - let mut idx = 0; - for z in 0..8 { - for y in 0..8 { - for x in 0..8 { - let val = vals[idx]; - idx += 1; + let mut idx = 0; + for z in 0..8 { + for y in 0..8 { + for x in 0..8 { + let val = vals[idx]; + idx += 1; - if val > 0.0 { - let r = ((x + 1) * 32 - 1) as u8; - let g = ((y + 1) * 32 - 1) as u8; - let b = ((z + 1) * 32 - 1) as u8; - block.push(Voxel::Color(r, g, b)); - } else { - block.push(Voxel::Empty); + if val > 0.0 { + let r = ((x + 1) * 32 - 1) as u8; + let g = ((y + 1) * 32 - 1) as u8; + let b = ((z + 1) * 32 - 1) as u8; + block.push(Voxel::Color(r, g, b)); + } else { + block.push(Voxel::Empty); + } } } }