X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fmap%2FMapState.h;h=af66d241d40b6efe4a5a312e2b31f8735ff84559;hb=cc3d698b8c1ad09d7a3f9e3f28bc84e0ac1735ea;hp=c565632569a766552ee4c693d6b8f963eea23f15;hpb=85d247c6e6b1bb2a6e0b177ef71a4541e69380d1;p=l2e.git diff --git a/src/map/MapState.h b/src/map/MapState.h index c565632..af66d24 100644 --- a/src/map/MapState.h +++ b/src/map/MapState.h @@ -1,10 +1,3 @@ -/* - * MapState.h - * - * Created on: Sep 29, 2012 - * Author: holy - */ - #ifndef MAP_MAPSTATE_H_ #define MAP_MAPSTATE_H_ @@ -12,6 +5,8 @@ #include "fwd.h" #include "../app/State.h" #include "../common/fwd.h" +#include "../common/ScriptHost.h" +#include "../common/ScriptRunner.h" #include "../geometry/Vector.h" #include "../graphics/Camera.h" @@ -19,20 +14,16 @@ namespace map { +/// Shows a map and its entities an optionally control a single entity. class MapState -: public app::State { +: public app::State +, public common::ScriptHost { public: explicit MapState(common::GameConfig *, Map *); virtual ~MapState() { } public: - virtual void EnterState(app::Application &ctrl, SDL_Surface *screen); - virtual void ExitState(app::Application &ctrl, SDL_Surface *screen); - virtual void ResumeState(app::Application &ctrl, SDL_Surface *screen); - virtual void PauseState(app::Application &ctrl, SDL_Surface *screen); - virtual void Resize(int width, int height); - virtual void HandleEvents(const app::Input &); virtual void UpdateWorld(float deltaT); virtual void Render(SDL_Surface *); @@ -45,6 +36,16 @@ public: void Transition(Map *, const geometry::Vector &coordinates); + virtual void HandleSyscall(common::ScriptRunner &); + +private: + virtual void OnEnterState(SDL_Surface *screen); + virtual void OnExitState(SDL_Surface *screen); + virtual void OnResumeState(SDL_Surface *screen); + virtual void OnPauseState(SDL_Surface *screen); + + virtual void OnResize(int width, int height); + private: static bool ZCompare(const Entity *lhs, const Entity *rhs); @@ -63,16 +64,23 @@ private: void LockEntities(); bool CheckMonster(); - bool CheckTrigger(); + + bool CheckLockTrigger(); + bool CheckMoveTrigger(); + void RunTrigger(Trigger &); + + enum Syscalls { + TRANSITION = 1, + WARP = 2, + }; private: common::GameConfig *game; - app::Application *ctrl; Map *map; Entity *controlled; Entity *pushed; + common::ScriptRunner runner; app::Timer moveTimer; - geometry::Vector tempTarget; geometry::Vector lastLock; graphics::Camera camera; std::vector entities;