mirror of
https://github.com/griffi-gh/kubi.git
synced 2024-11-26 00:38:44 -06:00
ok
This commit is contained in:
parent
25238acd9b
commit
2cc4b6f2e0
|
@ -9,3 +9,4 @@ image = { version = "0.24", default_features = false, features = ["png"] }
|
||||||
log = "0.4"
|
log = "0.4"
|
||||||
env_logger = "0.10"
|
env_logger = "0.10"
|
||||||
strum = { version = "0.24", features = ["derive"] }
|
strum = { version = "0.24", features = ["derive"] }
|
||||||
|
glam = { version = "0.22", features = ["debug-glam-assert", "mint", "fast-math"] }
|
||||||
|
|
|
@ -1,3 +1,11 @@
|
||||||
|
#[derive(Clone, Debug)]
|
||||||
pub struct GameOptions {
|
pub struct GameOptions {
|
||||||
pub render_distance: u8,
|
pub render_distance: u8,
|
||||||
}
|
}
|
||||||
|
impl Default for GameOptions {
|
||||||
|
fn default() -> Self {
|
||||||
|
Self {
|
||||||
|
render_distance: 8,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -1,13 +1,20 @@
|
||||||
|
use glam::{Vec2, IVec2};
|
||||||
use std::collections::HashMap;
|
use std::collections::HashMap;
|
||||||
|
use crate::game::options::GameOptions;
|
||||||
|
|
||||||
mod chunk;
|
mod chunk;
|
||||||
use chunk::Chunk;
|
mod thread;
|
||||||
|
|
||||||
|
use chunk::{Chunk, CHUNK_SIZE};
|
||||||
|
|
||||||
pub struct World {
|
pub struct World {
|
||||||
chunks: HashMap<(i32, i32), Chunk>
|
pub chunks: HashMap<IVec2, Chunk>
|
||||||
}
|
}
|
||||||
impl World {
|
impl World {
|
||||||
// pub fn update_loaded_chunks(around: ) {
|
pub fn update_loaded_chunks(&mut self, around_position: Vec2, game_opt: &GameOptions) {
|
||||||
|
let render_dist = game_opt.render_distance as i32;
|
||||||
|
let inside_chunk = (around_position / CHUNK_SIZE as f32).as_ivec2();
|
||||||
|
|
||||||
// }
|
todo!()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
use glam::IVec2;
|
||||||
use glium::VertexBuffer;
|
use glium::VertexBuffer;
|
||||||
use crate::game::{
|
use crate::game::{
|
||||||
blocks::Block,
|
blocks::Block,
|
||||||
|
@ -8,16 +9,37 @@ pub const CHUNK_SIZE: usize = 16;
|
||||||
pub const CHUNK_HEIGHT: usize = 255;
|
pub const CHUNK_HEIGHT: usize = 255;
|
||||||
|
|
||||||
pub enum ChunkState {
|
pub enum ChunkState {
|
||||||
//AwaitsLoading,
|
AwaitsLoading,
|
||||||
//Loaded,
|
Loaded,
|
||||||
//AwaitsMesh,
|
AwaitsMesh,
|
||||||
//Rendered,
|
Rendered,
|
||||||
//AwaitsUnload
|
AwaitsUnload
|
||||||
}
|
}
|
||||||
|
|
||||||
pub struct Chunk {
|
pub enum DesiredState {
|
||||||
pub coords: (i32, i32),
|
Unloaded,
|
||||||
pub block_data: Option<[[[Block; CHUNK_SIZE]; CHUNK_HEIGHT]; CHUNK_SIZE]>,
|
Loaded,
|
||||||
pub vertex_buffer: Option<VertexBuffer<ChunkVertex>>,
|
Rendered,
|
||||||
pub state: ChunkState
|
}
|
||||||
|
|
||||||
|
pub type ChunkData = [[[Block; CHUNK_SIZE]; CHUNK_HEIGHT]; CHUNK_SIZE];
|
||||||
|
pub type ChunkMesh = VertexBuffer<ChunkVertex>;
|
||||||
|
|
||||||
|
pub struct Chunk {
|
||||||
|
pub position: IVec2,
|
||||||
|
pub block_data: Option<ChunkData>,
|
||||||
|
pub vertex_buffer: Option<ChunkMesh>,
|
||||||
|
pub state: ChunkState,
|
||||||
|
pub desired: DesiredState,
|
||||||
|
}
|
||||||
|
impl Chunk {
|
||||||
|
pub fn new(position: IVec2) -> Self {
|
||||||
|
Self {
|
||||||
|
position,
|
||||||
|
block_data: None,
|
||||||
|
vertex_buffer: None,
|
||||||
|
state: ChunkState::AwaitsLoading,
|
||||||
|
desired: DesiredState::Loaded,
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
47
src/game/world/thread.rs
Normal file
47
src/game/world/thread.rs
Normal file
|
@ -0,0 +1,47 @@
|
||||||
|
use glam::IVec2;
|
||||||
|
use std::{
|
||||||
|
thread::{self, JoinHandle},
|
||||||
|
collections::HashMap,
|
||||||
|
mem
|
||||||
|
};
|
||||||
|
use super::chunk::{ChunkData, Chunk};
|
||||||
|
|
||||||
|
mod world_gen;
|
||||||
|
mod mesh_gen;
|
||||||
|
|
||||||
|
struct WorldThreading {
|
||||||
|
//drain_filter is not stable yet so
|
||||||
|
//Options are needed here to take ownership,
|
||||||
|
//None values should never appear here!
|
||||||
|
pub load_tasks: HashMap<IVec2, Option<JoinHandle<ChunkData>>>,
|
||||||
|
pub mesh_tasks: HashMap<IVec2, Option<JoinHandle<ChunkData>>>,
|
||||||
|
}
|
||||||
|
impl WorldThreading {
|
||||||
|
pub fn is_done(&self) -> bool {
|
||||||
|
self.load_tasks.is_empty() &&
|
||||||
|
self.mesh_tasks.is_empty()
|
||||||
|
}
|
||||||
|
pub fn queue_load(&mut self, position: IVec2) {
|
||||||
|
let handle = thread::spawn(|| {
|
||||||
|
world_gen::generate_chunk()
|
||||||
|
});
|
||||||
|
if self.load_tasks.insert(position, Some(handle)).is_some() {
|
||||||
|
log::warn!("load: discarded {}, reason: new task started", position);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
pub fn apply_tasks(&mut self, chunks: &mut HashMap<IVec2, Chunk>) {
|
||||||
|
self.load_tasks.retain(|position, handle| {
|
||||||
|
if !chunks.contains_key(position) {
|
||||||
|
log::warn!("load: discarded {}, reason: chunk no longer exists", position);
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
if !handle.as_ref().expect("Something went terribly wrong").is_finished() {
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
let handle = mem::take(handle).unwrap();
|
||||||
|
let data = handle.join().unwrap();
|
||||||
|
chunks.get_mut(position).unwrap().block_data = Some(data);
|
||||||
|
false
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
0
src/game/world/thread/mesh_gen.rs
Normal file
0
src/game/world/thread/mesh_gen.rs
Normal file
8
src/game/world/thread/world_gen.rs
Normal file
8
src/game/world/thread/world_gen.rs
Normal file
|
@ -0,0 +1,8 @@
|
||||||
|
use crate::game::{
|
||||||
|
world::chunk::{ChunkData, CHUNK_SIZE, CHUNK_HEIGHT},
|
||||||
|
blocks::Block
|
||||||
|
};
|
||||||
|
|
||||||
|
pub fn generate_chunk() -> ChunkData {
|
||||||
|
[[[Block::Stone; CHUNK_SIZE]; CHUNK_HEIGHT]; CHUNK_SIZE]
|
||||||
|
}
|
Loading…
Reference in a new issue