diff options
| author | Mel <einebeere@gmail.com> | 2024-02-02 16:16:25 +0100 |
|---|---|---|
| committer | Mel <einebeere@gmail.com> | 2024-02-02 16:16:25 +0100 |
| commit | a4a61ac2e6389af0968ac4fb305b82c6eb90bf0e (patch) | |
| tree | 800749ed6a5d503837a6bf0c389c133fcb59143d /src/World/World.cpp | |
| parent | 250e37c742f3ad46f093f4534098cdf8f68a29a9 (diff) | |
| download | meowcraft-a4a61ac2e6389af0968ac4fb305b82c6eb90bf0e.tar.zst meowcraft-a4a61ac2e6389af0968ac4fb305b82c6eb90bf0e.zip | |
Placing blocks
Diffstat (limited to 'src/World/World.cpp')
| -rw-r--r-- | src/World/World.cpp | 11 |
1 files changed, 7 insertions, 4 deletions
diff --git a/src/World/World.cpp b/src/World/World.cpp index cc5d91f..2b5848b 100644 --- a/src/World/World.cpp +++ b/src/World/World.cpp @@ -47,17 +47,20 @@ Chunk::BlockData World::block_at(Position::BlockWorld pos) { return {}; } -void World::break_block(Position::BlockWorld pos) { +void World::set_block(Position::BlockWorld pos, BlockType type) { auto& chunk_data = m_registry.find(pos); if (!chunk_data.chunk.has_value()) return; auto& block_data = chunk_data.chunk->at(pos.to_local()); - if (!block_data.type.is_solid()) return; - - block_data.type = {}; + block_data.type = type; chunk_data.damage(); } +void World::break_block(Position::BlockWorld pos) { + if (!block_at(pos).type.is_solid()) return; + set_block(pos, BlockType::Air); +} + std::vector<ChunkIndex> World::get_visible_chunk_indices(const Position::World position) const { ChunkIndex center = ChunkIndex::from_position(position.round_to_block()); |
