X-Git-Url: https://git.localhorst.tv/?a=blobdiff_plain;ds=sidebyside;f=src%2Fmap%2FMapState.h;h=4ba149db1d96c3e05749c4a5b32f411b5938dfc5;hb=07cdc452aeaad73ca9f8f9a3cf9868d2b6c9d5b3;hp=e180d4832b6b3c1aead07b2dd45cffd86896af65;hpb=a550d5e73bef77a8bb98a31034dcaad83a43677a;p=l2e.git diff --git a/src/map/MapState.h b/src/map/MapState.h index e180d48..4ba149d 100644 --- a/src/map/MapState.h +++ b/src/map/MapState.h @@ -22,7 +22,7 @@ class MapState : public app::State { public: - explicit MapState(const Map *); + explicit MapState(Map *); virtual ~MapState() { } public: @@ -40,15 +40,36 @@ public: void AddEntity(Entity *e) { entities.push_back(e); } void ControlEntity(Entity *e) { controlled = e; camera.SetTarget(&e->Position()); } + void SetWalkingSpeed(float s) { walkingSpeed = s; } + private: static bool ZCompare(const Entity *lhs, const Entity *rhs); + bool CheckBlocking() const; + + void OnTileLock(); + void OnGridLock(); + void OnMove(bool); + + void UpdateFollower(Entity &); + void StopFollowers(Entity &); + + void LockEntities(); + void CheckMonster(); + void CheckTrigger(); + private: - const Map *map; + Map *map; Entity *controlled; + app::Timer moveTimer; geometry::Vector tempTarget; + geometry::Vector lastLock; graphics::Camera camera; std::vector entities; + float walkingSpeed; + int nextDirection; + bool afterLock; + bool debug; };