mirror of
https://github.com/griffi-gh/kubi.git
synced 2025-01-10 06:08:21 -06:00
update
This commit is contained in:
parent
c1cd48101b
commit
5f9f0ad72f
36
src/block_placement.rs
Normal file
36
src/block_placement.rs
Normal file
|
@ -0,0 +1,36 @@
|
||||||
|
use glam::Vec3;
|
||||||
|
use shipyard::{UniqueViewMut, UniqueView, View, IntoIter};
|
||||||
|
use crate::{
|
||||||
|
player::MainPlayer,
|
||||||
|
world::{raycast::LookingAtBlock, ChunkStorage, block::Block},
|
||||||
|
input::Inputs
|
||||||
|
};
|
||||||
|
|
||||||
|
pub fn block_placement_system(
|
||||||
|
main_player: View<MainPlayer>,
|
||||||
|
raycast: View<LookingAtBlock>,
|
||||||
|
input: UniqueView<Inputs>,
|
||||||
|
mut world: UniqueViewMut<ChunkStorage>
|
||||||
|
) {
|
||||||
|
//this cant process both place and break btw
|
||||||
|
if input.action_a || input.action_b {
|
||||||
|
//get raycast info
|
||||||
|
let Some(ray) = (&main_player, &raycast).iter().next().unwrap().1/**/.0 else { return };
|
||||||
|
//update block
|
||||||
|
let is_place = input.action_b;
|
||||||
|
let place_position = if is_place {
|
||||||
|
let position = (ray.position - ray.direction * 0.5).floor().as_ivec3();
|
||||||
|
let Some(block) = world.get_block_mut(position) else { return };
|
||||||
|
*block = Block::Dirt;
|
||||||
|
position
|
||||||
|
} else {
|
||||||
|
let Some(block) = world.get_block_mut(ray.block_position) else { return };
|
||||||
|
*block = Block::Air;
|
||||||
|
ray.block_position
|
||||||
|
};
|
||||||
|
//mark chunk as dirty
|
||||||
|
let (chunk_pos, _) = ChunkStorage::to_chunk_coords(place_position);
|
||||||
|
let chunk = world.chunks.get_mut(&chunk_pos).unwrap();
|
||||||
|
chunk.dirty = true;
|
||||||
|
}
|
||||||
|
}
|
|
@ -24,6 +24,7 @@ pub(crate) mod camera;
|
||||||
pub(crate) mod events;
|
pub(crate) mod events;
|
||||||
pub(crate) mod input;
|
pub(crate) mod input;
|
||||||
pub(crate) mod fly_controller;
|
pub(crate) mod fly_controller;
|
||||||
|
pub(crate) mod block_placement;
|
||||||
|
|
||||||
use rendering::{
|
use rendering::{
|
||||||
Renderer,
|
Renderer,
|
||||||
|
@ -34,7 +35,7 @@ use rendering::{
|
||||||
use world::{
|
use world::{
|
||||||
init_game_world,
|
init_game_world,
|
||||||
loading::update_loaded_world_around_player,
|
loading::update_loaded_world_around_player,
|
||||||
raycast::{update_raycasts, break_block_test_only}
|
raycast::update_raycasts
|
||||||
};
|
};
|
||||||
use player::spawn_player;
|
use player::spawn_player;
|
||||||
use prefabs::load_prefabs;
|
use prefabs::load_prefabs;
|
||||||
|
@ -47,6 +48,7 @@ use rendering::{
|
||||||
selection_box::render_selection_box,
|
selection_box::render_selection_box,
|
||||||
world::draw_world,
|
world::draw_world,
|
||||||
};
|
};
|
||||||
|
use block_placement::block_placement_system;
|
||||||
|
|
||||||
#[derive(Unique)]
|
#[derive(Unique)]
|
||||||
pub(crate) struct DeltaTime(Duration);
|
pub(crate) struct DeltaTime(Duration);
|
||||||
|
@ -65,7 +67,7 @@ fn update() -> Workload {
|
||||||
update_controllers,
|
update_controllers,
|
||||||
update_loaded_world_around_player,
|
update_loaded_world_around_player,
|
||||||
update_raycasts,
|
update_raycasts,
|
||||||
break_block_test_only,
|
block_placement_system,
|
||||||
compute_cameras
|
compute_cameras
|
||||||
).into_workload()
|
).into_workload()
|
||||||
}
|
}
|
||||||
|
|
|
@ -47,7 +47,6 @@ impl Block {
|
||||||
collision: CollisionType::Solid,
|
collision: CollisionType::Solid,
|
||||||
raycast_collision: true,
|
raycast_collision: true,
|
||||||
},
|
},
|
||||||
_ => todo!()
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -59,11 +58,11 @@ pub struct BlockDescriptor {
|
||||||
pub collision: CollisionType,
|
pub collision: CollisionType,
|
||||||
pub raycast_collision: bool,
|
pub raycast_collision: bool,
|
||||||
}
|
}
|
||||||
impl BlockDescriptor {
|
// impl BlockDescriptor {
|
||||||
pub fn of(block: Block) -> Self {
|
// pub fn of(block: Block) -> Self {
|
||||||
block.descriptor()
|
// block.descriptor()
|
||||||
}
|
// }
|
||||||
}
|
// }
|
||||||
|
|
||||||
#[derive(Clone, Copy, Debug)]
|
#[derive(Clone, Copy, Debug)]
|
||||||
pub struct CubeTexture {
|
pub struct CubeTexture {
|
||||||
|
|
|
@ -42,7 +42,12 @@ pub fn update_chunks_if_player_moved(
|
||||||
|
|
||||||
//If it did, get it's position and current chunk
|
//If it did, get it's position and current chunk
|
||||||
let player_position = transform.0.to_scale_rotation_translation().2;
|
let player_position = transform.0.to_scale_rotation_translation().2;
|
||||||
let player_at_chunk = player_position.as_ivec3() / CHUNK_SIZE as i32;
|
let player_position_ivec3 = player_position.as_ivec3();
|
||||||
|
let player_at_chunk = ivec3(
|
||||||
|
player_position_ivec3.x.div_euclid(CHUNK_SIZE as i32),
|
||||||
|
player_position_ivec3.y.div_euclid(CHUNK_SIZE as i32),
|
||||||
|
player_position_ivec3.z.div_euclid(CHUNK_SIZE as i32),
|
||||||
|
);
|
||||||
|
|
||||||
//Then, mark *ALL* chunks with ToUnload
|
//Then, mark *ALL* chunks with ToUnload
|
||||||
for (_, chunk) in &mut vm_world.chunks {
|
for (_, chunk) in &mut vm_world.chunks {
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
use glam::{Vec3, IVec3};
|
use glam::{Vec3, IVec3};
|
||||||
use shipyard::{View, Component, ViewMut, IntoIter, UniqueView, UniqueViewMut};
|
use shipyard::{View, Component, ViewMut, IntoIter, UniqueView};
|
||||||
use crate::{player::MainPlayer, transform::Transform, input::Inputs};
|
use crate::transform::Transform;
|
||||||
|
|
||||||
use super::{ChunkStorage, block::Block};
|
use super::{ChunkStorage, block::Block};
|
||||||
|
|
||||||
|
@ -10,6 +10,7 @@ const RAYCAST_STEP: f32 = 0.25;
|
||||||
pub struct RaycastReport {
|
pub struct RaycastReport {
|
||||||
pub length: f32,
|
pub length: f32,
|
||||||
pub position: Vec3,
|
pub position: Vec3,
|
||||||
|
pub direction: Vec3,
|
||||||
pub block_position: IVec3,
|
pub block_position: IVec3,
|
||||||
pub block: Block,
|
pub block: Block,
|
||||||
}
|
}
|
||||||
|
@ -24,7 +25,13 @@ impl ChunkStorage {
|
||||||
let block_position = position.floor().as_ivec3();
|
let block_position = position.floor().as_ivec3();
|
||||||
if let Some(block) = self.get_block(block_position) {
|
if let Some(block) = self.get_block(block_position) {
|
||||||
if block.descriptor().raycast_collision {
|
if block.descriptor().raycast_collision {
|
||||||
return Some(RaycastReport { length, position, block_position, block });
|
return Some(RaycastReport {
|
||||||
|
length,
|
||||||
|
position,
|
||||||
|
direction,
|
||||||
|
block_position,
|
||||||
|
block
|
||||||
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
length += RAYCAST_STEP;
|
length += RAYCAST_STEP;
|
||||||
|
@ -56,21 +63,3 @@ pub fn update_raycasts(
|
||||||
*report = LookingAtBlock(world.raycast(position, direction, Some(30.)));
|
*report = LookingAtBlock(world.raycast(position, direction, Some(30.)));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn break_block_test_only(
|
|
||||||
raycast: View<LookingAtBlock>,
|
|
||||||
input: UniqueView<Inputs>,
|
|
||||||
mut world: UniqueViewMut<ChunkStorage>
|
|
||||||
) {
|
|
||||||
if input.action_a {
|
|
||||||
//get raycast info
|
|
||||||
let Some(ray) = raycast.iter().next().unwrap().0 else { return };
|
|
||||||
//update block
|
|
||||||
let Some(block) = world.get_block_mut(ray.block_position) else { return };
|
|
||||||
*block = Block::Air;
|
|
||||||
//mark chunk as dirty
|
|
||||||
let (chunk_pos, _) = ChunkStorage::to_chunk_coords(ray.block_position);
|
|
||||||
let chunk = world.chunks.get_mut(&chunk_pos).unwrap();
|
|
||||||
chunk.dirty = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
Loading…
Reference in a new issue