WIP Chunk loading

This commit is contained in:
griffi-gh 2023-01-21 03:40:23 +01:00
parent e3ef07df67
commit 5b0817b318
4 changed files with 59 additions and 12 deletions

View file

@ -25,6 +25,7 @@ use rendering::{Rederer, RenderTarget, BackgroundColor, clear_background};
use player::spawn_player; use player::spawn_player;
use world::{GameWorld, loading::load_world_around_player}; use world::{GameWorld, loading::load_world_around_player};
use prefabs::load_prefabs; use prefabs::load_prefabs;
use settings::GameSettings;
#[derive(Unique)] #[derive(Unique)]
pub(crate) struct DeltaTime(Duration); pub(crate) struct DeltaTime(Duration);
@ -64,6 +65,7 @@ fn main() {
); );
world.add_unique(BackgroundColor(vec3(0.5, 0.5, 1.))); world.add_unique(BackgroundColor(vec3(0.5, 0.5, 1.)));
world.add_unique(DeltaTime(Duration::default())); world.add_unique(DeltaTime(Duration::default()));
world.add_unique(GameSettings::default());
//Register workloads //Register workloads
world.add_workload(startup); world.add_workload(startup);

View file

@ -3,22 +3,28 @@ use shipyard::{Component, EntitiesViewMut, ViewMut};
use crate::transform::Transform; use crate::transform::Transform;
#[derive(Component)]
pub struct LocalPlayer;
#[derive(Component)] #[derive(Component)]
pub struct Player; pub struct Player;
pub fn spawn_player ( pub fn spawn_player (
mut entities: EntitiesViewMut, mut entities: EntitiesViewMut,
mut vm_player: ViewMut<Player>, mut vm_player: ViewMut<Player>,
mut vm_local_player: ViewMut<LocalPlayer>,
mut vm_transform: ViewMut<Transform> mut vm_transform: ViewMut<Transform>
) { ) {
log::info!("spawning player"); log::info!("spawning player");
entities.add_entity( entities.add_entity(
( (
&mut vm_player, &mut vm_player,
&mut vm_local_player,
&mut vm_transform &mut vm_transform
), ),
( (
Player, Player,
LocalPlayer,
Transform(Mat4::default()) Transform(Mat4::default())
) )
); );

View file

@ -3,7 +3,7 @@ use shipyard::Unique;
#[derive(Unique)] #[derive(Unique)]
pub struct GameSettings { pub struct GameSettings {
//there's a 1 chunk border of loaded but invisible around this //there's a 1 chunk border of loaded but invisible around this
pub render_distance: usize, pub render_distance: u8,
} }
impl Default for GameSettings { impl Default for GameSettings {
fn default() -> Self { fn default() -> Self {

View file

@ -1,13 +1,52 @@
use shipyard::{View, UniqueViewMut, NonSendSync, IntoIter}; use glam::ivec3;
use crate::{player::Player, transform::Transform}; use shipyard::{View, UniqueView, UniqueViewMut, NonSendSync, IntoIter, Workload, IntoWorkload};
use super::GameWorld; use crate::{player::LocalPlayer, transform::Transform, settings::GameSettings};
use super::{GameWorld, chunk::{ChunkState, CHUNK_SIZE}};
pub fn load_world_around_player( pub fn load_world_around_player() -> Workload {
v_player: View<Player>, (
mark_chunks,
).into_workload()
}
pub fn mark_chunks(
v_settings: UniqueView<GameSettings>,
v_local_player: View<LocalPlayer>,
v_transform: View<Transform>, v_transform: View<Transform>,
vm_world: NonSendSync<UniqueViewMut<GameWorld>>, mut vm_world: NonSendSync<UniqueViewMut<GameWorld>>,
) { ) {
for (player, transform) in (&v_player, v_transform.inserted_or_modified()).iter() { //Read game settings
let load_distance = (v_settings.render_distance + 1) as i32;
//Check if a player moved
let Some((_, transform)) = (&v_local_player, v_transform.inserted_or_modified()).iter().next() else {
return
};
//If it did, get it's position and current chunk
let position = transform.0.to_scale_rotation_translation().2;
let at_chunk = position.as_ivec3() / CHUNK_SIZE as i32;
//Then, mark *ALL* chunks with ToUnload
for (_, chunk) in &mut vm_world.chunks {
chunk.desired_state = ChunkState::ToUnload;
}
//Then mark chunks that are near to the player
for x in -load_distance..=load_distance {
for y in -load_distance..=load_distance {
for z in -load_distance..=load_distance {
let chunk_pos_offset = ivec3(x, y, z);
let is_border = chunk_pos_offset.to_array()
.iter().any(|x| x.abs() == load_distance);
let desired = match is_border {
true => ChunkState::Loaded,
false => ChunkState::Rendered,
};
} }
} }
}
//TODO
todo!()
}