diff options
author | Kae <80987908+Novaenia@users.noreply.github.com> | 2024-04-01 10:30:03 +1100 |
---|---|---|
committer | Kae <80987908+Novaenia@users.noreply.github.com> | 2024-04-01 10:30:03 +1100 |
commit | 02632b248c9fcf9c71d9099e2ac857d8b3d44393 (patch) | |
tree | ad7b7ff23d7671ae5fd283f8ac0b7291dde2bd8a /source/game/StarWorldClient.cpp | |
parent | b556f714735a912dcf48257bccfda615855f3695 (diff) |
Fix more cases of tile collision not taking object material spaces into account
Fixes #53
Diffstat (limited to 'source/game/StarWorldClient.cpp')
-rw-r--r-- | source/game/StarWorldClient.cpp | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/source/game/StarWorldClient.cpp b/source/game/StarWorldClient.cpp index 535980b..b1ad698 100644 --- a/source/game/StarWorldClient.cpp +++ b/source/game/StarWorldClient.cpp @@ -256,7 +256,7 @@ void WorldClient::forEachCollisionBlock(RectI const& region, function<void(Colli const_cast<WorldClient*>(this)->freshenCollision(region); m_tileArray->tileEach(region, [iterator](Vec2I const& pos, ClientTile const& tile) { - if (tile.collision == CollisionKind::Null) { + if (tile.getCollision() == CollisionKind::Null) { iterator(CollisionBlock::nullBlock(pos)); } else { starAssert(!tile.collisionCacheDirty); @@ -1760,7 +1760,7 @@ void WorldClient::initWorld(WorldStartPacket const& startPacket) { m_weather.setup(m_geometry, [this](Vec2I const& pos) { auto const& tile = m_tileArray->tile(pos); - return !isRealMaterial(tile.background) && !isSolidColliding(tile.collision); + return !isRealMaterial(tile.background) && !isSolidColliding(tile.getCollision()); }); m_weather.readUpdate(startPacket.weatherData); |