diff options
-rw-r--r-- | chunk.cpp | 10 | ||||
-rw-r--r-- | chunk.hpp | 3 | ||||
-rw-r--r-- | main.cpp | 1 | ||||
-rw-r--r-- | tile.hpp | 11 |
4 files changed, 12 insertions, 13 deletions
@@ -5,10 +5,12 @@ namespace Magnum::Examples { chunk_sampler_array::chunk_sampler_array() { samplers.reserve(MAX_SAMPLERS); + samplers.push_back(nullptr); } void chunk_sampler_array::ensure_sampler(std::size_t tile_id, const shared_sampler& x) { + CORRADE_INTERNAL_ASSERT(x != nullptr); CORRADE_INTERNAL_ASSERT(tile_id < TILE_COUNT); if (std::size_t id = sampler_map[tile_id]; id != 0) { @@ -26,20 +28,22 @@ void chunk_sampler_array::clear() { Magnum::GL::AbstractTexture::unbindImages(0, samplers.size()); samplers.clear(); + samplers.push_back(nullptr); sampler_map = {}; } void chunk_sampler_array::bind() { Magnum::GL::AbstractTexture::unbindImages(0, MAX_SAMPLERS); - for (std::size_t i = 0; i < samplers.size(); i++) - samplers[i]->texture().bind((int)i + 1); + for (std::size_t i = 1; i < samplers.size(); i++) + samplers[i]->texture().bind((int)i); } std::shared_ptr<tile_atlas> chunk_sampler_array::operator[](std::size_t tile_id) const { CORRADE_INTERNAL_ASSERT(tile_id < TILE_COUNT); - std::size_t sampler_id = sampler_map[tile_id] - 1; + std::size_t sampler_id = sampler_map[tile_id]; + CORRADE_INTERNAL_ASSERT(sampler_id != 0); CORRADE_INTERNAL_ASSERT(sampler_id < samplers.size()); const auto& sampler = samplers[sampler_id]; CORRADE_INTERNAL_ASSERT(sampler != nullptr); @@ -27,9 +27,8 @@ struct chunk_coords final { struct chunk_sampler_array final { using shared_sampler = std::shared_ptr<tile_atlas>; - using sampler_tuple = std::pair<shared_sampler, int>; + static constexpr inline int MAX_SAMPLERS = 32; - static constexpr inline int MAX_SAMPLERS = 16; std::vector<std::shared_ptr<tile_atlas>> samplers; std::array<UnsignedInt, TILE_COUNT> sampler_map = {}; @@ -76,7 +76,6 @@ struct app final : Platform::Application chunk c; float get_dt(); - static constexpr Vector3 TILE_SIZE = { 50, 50, 50 }; }; using namespace Math::Literals; @@ -13,7 +13,7 @@ namespace Magnum::Examples { -static constexpr Vector3 TILE_SIZE = { 50, 50, 50 }; +constexpr inline Vector3 TILE_SIZE = { 50, 50, 50 }; struct tile_image final { @@ -25,14 +25,11 @@ struct tile_image final struct tile final { - enum class pass_mode : std::uint8_t { pass_blocked, pass_yes, pass_shoot_through, pass_obscured }; + enum class pass_mode : std::uint8_t { pass_blocked, pass_ok, pass_shoot_through, }; using enum pass_mode; - tile_image ground_image_, wall_west_, wall_north_; - pass_mode passability_ = pass_shoot_through; - - //explicit operator bool() const noexcept { return !!ground_image_.atlas; } + tile_image ground_image, wall_west, wall_north; + pass_mode passability = pass_shoot_through; }; - } //namespace Magnum::Examples |