mirror of
https://github.com/griffi-gh/kubi.git
synced 2024-11-22 06:48:43 -06:00
Separate chunk neighbor code, WIP tasks
This commit is contained in:
parent
7b5120b1d4
commit
f9a7953dd8
|
@ -3,9 +3,6 @@ name = "kubi"
|
|||
version = "0.1.0"
|
||||
edition = "2021"
|
||||
|
||||
[profile.dev.package.noise]
|
||||
opt-level = 3
|
||||
|
||||
[dependencies]
|
||||
glium = "0.32"
|
||||
image = { version = "0.24", default_features = false, features = ["png"] }
|
||||
|
@ -19,3 +16,4 @@ rayon = "1.6"
|
|||
shipyard = { version = "0.6", features = ["thread_local"] }
|
||||
nohash-hasher = "0.2.0"
|
||||
anyhow = "1.0"
|
||||
flume = "0.10"
|
||||
|
|
|
@ -81,6 +81,8 @@ pub fn draw_world(
|
|||
write: true,
|
||||
..Default::default()
|
||||
},
|
||||
polygon_mode: PolygonMode::Fill, //Change to Line for wireframe
|
||||
backface_culling: BackfaceCullingMode::CullCounterClockwise,
|
||||
..Default::default()
|
||||
};
|
||||
let texture_sampler = Sampler(&texture.0, SamplerBehavior {
|
||||
|
|
76
src/world.rs
76
src/world.rs
|
@ -10,52 +10,14 @@ pub mod render;
|
|||
pub mod tasks;
|
||||
pub mod loading;
|
||||
pub mod mesh;
|
||||
pub mod neighbors;
|
||||
|
||||
use chunk::{Chunk, ChunkMesh};
|
||||
|
||||
//TODO separate world struct for render data
|
||||
// because this is not send-sync
|
||||
|
||||
pub struct AllChunksNeighbors<'a> {
|
||||
pub center: &'a Chunk,
|
||||
pub top: &'a Chunk,
|
||||
pub bottom: &'a Chunk,
|
||||
pub left: &'a Chunk,
|
||||
pub right: &'a Chunk,
|
||||
pub front: &'a Chunk,
|
||||
pub back: &'a Chunk,
|
||||
}
|
||||
pub struct AllChunksNeighborsMut<'a> {
|
||||
pub center: &'a mut Chunk,
|
||||
pub top: &'a mut Chunk,
|
||||
pub bottom: &'a mut Chunk,
|
||||
pub left: &'a mut Chunk,
|
||||
pub right: &'a mut Chunk,
|
||||
pub front: &'a mut Chunk,
|
||||
pub back: &'a mut Chunk,
|
||||
}
|
||||
pub struct ChunksNeighbors<'a> {
|
||||
pub center: Option<&'a Chunk>,
|
||||
pub top: Option<&'a Chunk>,
|
||||
pub bottom: Option<&'a Chunk>,
|
||||
pub left: Option<&'a Chunk>,
|
||||
pub right: Option<&'a Chunk>,
|
||||
pub front: Option<&'a Chunk>,
|
||||
pub back: Option<&'a Chunk>,
|
||||
}
|
||||
impl<'a> ChunksNeighbors<'a> {
|
||||
pub fn all(&self) -> Option<AllChunksNeighbors<'a>> {
|
||||
Some(AllChunksNeighbors {
|
||||
center: self.center?,
|
||||
top: self.top?,
|
||||
bottom: self.bottom?,
|
||||
left: self.left?,
|
||||
right: self.right?,
|
||||
front: self.front?,
|
||||
back: self.back?,
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
#[derive(Default, Unique)]
|
||||
#[track(Modification)]
|
||||
|
@ -66,40 +28,6 @@ impl ChunkStorage {
|
|||
pub fn new() -> Self {
|
||||
Self::default()
|
||||
}
|
||||
pub fn neighbors(&self, coords: IVec3) -> ChunksNeighbors {
|
||||
ChunksNeighbors {
|
||||
center: self.chunks.get(&coords),
|
||||
top: self.chunks.get(&(coords - ivec3(0, 1, 0))),
|
||||
bottom: self.chunks.get(&(coords + ivec3(0, 1, 0))),
|
||||
left: self.chunks.get(&(coords - ivec3(1, 0, 0))),
|
||||
right: self.chunks.get(&(coords + ivec3(1, 0, 0))),
|
||||
front: self.chunks.get(&(coords - ivec3(0, 0, 1))),
|
||||
back: self.chunks.get(&(coords + ivec3(0, 0, 1))),
|
||||
}
|
||||
}
|
||||
pub fn neighbors_all(&self, coords: IVec3) -> Option<AllChunksNeighbors> {
|
||||
self.neighbors(coords).all()
|
||||
}
|
||||
pub fn neighbors_all_mut(&mut self, coords: IVec3) -> Option<AllChunksNeighborsMut> {
|
||||
let mut refs = self.chunks.get_many_mut([
|
||||
&coords,
|
||||
&(coords - ivec3(0, 1, 0)),
|
||||
&(coords + ivec3(0, 1, 0)),
|
||||
&(coords - ivec3(1, 0, 0)),
|
||||
&(coords + ivec3(1, 0, 0)),
|
||||
&(coords - ivec3(0, 0, 1)),
|
||||
&(coords + ivec3(0, 0, 1)),
|
||||
])?.map(Some);
|
||||
Some(AllChunksNeighborsMut {
|
||||
center: std::mem::take(&mut refs[0]).unwrap(),
|
||||
top: std::mem::take(&mut refs[1]).unwrap(),
|
||||
bottom: std::mem::take(&mut refs[2]).unwrap(),
|
||||
left: std::mem::take(&mut refs[3]).unwrap(),
|
||||
right: std::mem::take(&mut refs[4]).unwrap(),
|
||||
front: std::mem::take(&mut refs[5]).unwrap(),
|
||||
back: std::mem::take(&mut refs[6]).unwrap(),
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
|
|
@ -4,9 +4,10 @@ use super::{block::Block, render::ChunkVertex};
|
|||
|
||||
pub const CHUNK_SIZE: usize = 32;
|
||||
|
||||
type ChunkBlockData = Box<[[[Block; CHUNK_SIZE]; CHUNK_SIZE]; CHUNK_SIZE]>;
|
||||
pub type BlockData = Box<[[[Block; CHUNK_SIZE]; CHUNK_SIZE]; CHUNK_SIZE]>;
|
||||
|
||||
pub struct ChunkData {
|
||||
pub blocks: ChunkBlockData,
|
||||
pub blocks: BlockData,
|
||||
pub has_renderable_blocks: bool,
|
||||
}
|
||||
impl ChunkData {
|
||||
|
|
122
src/world/neighbors.rs
Normal file
122
src/world/neighbors.rs
Normal file
|
@ -0,0 +1,122 @@
|
|||
use glam::{IVec3, ivec3};
|
||||
use super::chunk::Chunk;
|
||||
|
||||
#[derive(Clone, Copy)]
|
||||
pub struct ChunkNeighbors<'a> {
|
||||
pub center: Option<&'a Chunk>,
|
||||
pub top: Option<&'a Chunk>,
|
||||
pub bottom: Option<&'a Chunk>,
|
||||
pub left: Option<&'a Chunk>,
|
||||
pub right: Option<&'a Chunk>,
|
||||
pub front: Option<&'a Chunk>,
|
||||
pub back: Option<&'a Chunk>,
|
||||
}
|
||||
#[derive(Clone, Copy)]
|
||||
pub struct AllChunkNeighbors<'a> {
|
||||
pub center: &'a Chunk,
|
||||
pub top: &'a Chunk,
|
||||
pub bottom: &'a Chunk,
|
||||
pub left: &'a Chunk,
|
||||
pub right: &'a Chunk,
|
||||
pub front: &'a Chunk,
|
||||
pub back: &'a Chunk,
|
||||
}
|
||||
pub struct AllChunkNeighborsMut<'a> {
|
||||
pub center: &'a mut Chunk,
|
||||
pub top: &'a mut Chunk,
|
||||
pub bottom: &'a mut Chunk,
|
||||
pub left: &'a mut Chunk,
|
||||
pub right: &'a mut Chunk,
|
||||
pub front: &'a mut Chunk,
|
||||
pub back: &'a mut Chunk,
|
||||
}
|
||||
|
||||
impl<'a> ChunkNeighbors<'a> {
|
||||
pub fn all(&self) -> Option<AllChunkNeighbors<'a>> {
|
||||
Some(AllChunkNeighbors {
|
||||
center: self.center?,
|
||||
top: self.top?,
|
||||
bottom: self.bottom?,
|
||||
left: self.left?,
|
||||
right: self.right?,
|
||||
front: self.front?,
|
||||
back: self.back?,
|
||||
})
|
||||
}
|
||||
}
|
||||
impl<'a> From<AllChunkNeighborsMut<'a>> for AllChunkNeighbors<'a> {
|
||||
fn from(neighbors: AllChunkNeighborsMut<'a>) -> Self {
|
||||
AllChunkNeighbors {
|
||||
center: neighbors.center,
|
||||
top: neighbors.top,
|
||||
bottom: neighbors.bottom,
|
||||
left: neighbors.left,
|
||||
right: neighbors.right,
|
||||
front: neighbors.front,
|
||||
back: neighbors.back,
|
||||
}
|
||||
}
|
||||
}
|
||||
impl<'a> From<AllChunkNeighbors<'a>> for ChunkNeighbors<'a> {
|
||||
fn from(neighbors: AllChunkNeighbors<'a>) -> Self {
|
||||
ChunkNeighbors {
|
||||
center: Some(neighbors.center),
|
||||
top: Some(neighbors.top),
|
||||
bottom: Some(neighbors.bottom),
|
||||
left: Some(neighbors.left),
|
||||
right: Some(neighbors.right),
|
||||
front: Some(neighbors.front),
|
||||
back: Some(neighbors.back),
|
||||
}
|
||||
}
|
||||
}
|
||||
impl<'a> From<AllChunkNeighborsMut<'a>> for ChunkNeighbors<'a> {
|
||||
fn from(neighbors: AllChunkNeighborsMut<'a>) -> Self {
|
||||
ChunkNeighbors {
|
||||
center: Some(neighbors.center),
|
||||
top: Some(neighbors.top),
|
||||
bottom: Some(neighbors.bottom),
|
||||
left: Some(neighbors.left),
|
||||
right: Some(neighbors.right),
|
||||
front: Some(neighbors.front),
|
||||
back: Some(neighbors.back),
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
impl super::ChunkStorage {
|
||||
pub fn neighbors(&self, coords: IVec3) -> ChunkNeighbors {
|
||||
ChunkNeighbors {
|
||||
center: self.chunks.get(&coords),
|
||||
top: self.chunks.get(&(coords - ivec3(0, 1, 0))),
|
||||
bottom: self.chunks.get(&(coords + ivec3(0, 1, 0))),
|
||||
left: self.chunks.get(&(coords - ivec3(1, 0, 0))),
|
||||
right: self.chunks.get(&(coords + ivec3(1, 0, 0))),
|
||||
front: self.chunks.get(&(coords - ivec3(0, 0, 1))),
|
||||
back: self.chunks.get(&(coords + ivec3(0, 0, 1))),
|
||||
}
|
||||
}
|
||||
pub fn neighbors_all(&self, coords: IVec3) -> Option<AllChunkNeighbors> {
|
||||
self.neighbors(coords).all()
|
||||
}
|
||||
pub fn neighbors_all_mut(&mut self, coords: IVec3) -> Option<AllChunkNeighborsMut> {
|
||||
let mut refs = self.chunks.get_many_mut([
|
||||
&coords,
|
||||
&(coords - ivec3(0, 1, 0)),
|
||||
&(coords + ivec3(0, 1, 0)),
|
||||
&(coords - ivec3(1, 0, 0)),
|
||||
&(coords + ivec3(1, 0, 0)),
|
||||
&(coords - ivec3(0, 0, 1)),
|
||||
&(coords + ivec3(0, 0, 1)),
|
||||
])?.map(Some);
|
||||
Some(AllChunkNeighborsMut {
|
||||
center: std::mem::take(&mut refs[0]).unwrap(),
|
||||
top: std::mem::take(&mut refs[1]).unwrap(),
|
||||
bottom: std::mem::take(&mut refs[2]).unwrap(),
|
||||
left: std::mem::take(&mut refs[3]).unwrap(),
|
||||
right: std::mem::take(&mut refs[4]).unwrap(),
|
||||
front: std::mem::take(&mut refs[5]).unwrap(),
|
||||
back: std::mem::take(&mut refs[6]).unwrap(),
|
||||
})
|
||||
}
|
||||
}
|
|
@ -0,0 +1,42 @@
|
|||
use flume::{Sender, Receiver};
|
||||
use glam::IVec3;
|
||||
use super::{
|
||||
chunk::BlockData,
|
||||
render::ChunkVertex
|
||||
};
|
||||
|
||||
pub enum ChunkTask {
|
||||
LoadChunk {
|
||||
position: IVec3
|
||||
},
|
||||
GenerateMesh {
|
||||
position: IVec3,
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
pub enum ChunkTaskResponse {
|
||||
LoadedChunk {
|
||||
position: IVec3,
|
||||
chunk_data: BlockData,
|
||||
},
|
||||
GeneratedMesh {
|
||||
position: IVec3,
|
||||
vertices: Vec<ChunkVertex>,
|
||||
indexes: Vec<u32>
|
||||
},
|
||||
}
|
||||
|
||||
pub struct ChunkTaskManager {
|
||||
channel: (Sender<ChunkTaskResponse>, Receiver<ChunkTaskResponse>),
|
||||
}
|
||||
impl ChunkTaskManager {
|
||||
pub fn new() -> Self {
|
||||
Self {
|
||||
channel: flume::bounded::<ChunkTaskResponse>(0),
|
||||
}
|
||||
}
|
||||
pub fn spawn_task() {
|
||||
|
||||
}
|
||||
}
|
Loading…
Reference in a new issue