]> git.localhorst.tv Git - blank.git/blobdiff - src/client/InteractiveState.hpp
centralize entity controllers
[blank.git] / src / client / InteractiveState.hpp
index 49c54745f8f88c57b94af1b52d6a7f72fb12fd68..ab6513813e49f01c3049dfa45f336ea758ff2268 100644 (file)
@@ -6,6 +6,7 @@
 
 #include "ChunkReceiver.hpp"
 #include "NetworkedInput.hpp"
+#include "../app/ChatState.hpp"
 #include "../app/IntervalTimer.hpp"
 #include "../audio/SoundBank.hpp"
 #include "../graphics/SkyBox.hpp"
@@ -31,7 +32,8 @@ class MasterState;
 
 class InteractiveState
 : public State
-, public ClientController {
+, public ClientController
+, public ChatState::Responder {
 
 public:
        explicit InteractiveState(MasterState &, std::uint32_t player_id);
@@ -41,7 +43,11 @@ public:
        PlayerController &GetPlayerController() noexcept { return input; }
        ChunkReceiver &GetChunkReceiver() noexcept { return chunk_receiver; }
 
-       void OnEnter() override;
+       void OnResume() override;
+       void OnPause() override;
+
+       void OnFocus() override;
+       void OnBlur() override;
 
        void Handle(const SDL_Event &) override;
        void Update(int dt) override;
@@ -52,6 +58,7 @@ public:
        void Handle(const Packet::EntityUpdate &);
        void Handle(const Packet::PlayerCorrection &);
        void Handle(const Packet::BlockUpdate &);
+       void Handle(const Packet::Message &);
 
        void SetAudio(bool) override;
        void SetVideo(bool) override;
@@ -59,6 +66,8 @@ public:
        void SetDebug(bool) override;
        void Exit() override;
 
+       void OnLineSubmit(const std::string &) override;
+
 private:
        /// flag entity as updated by given packet
        /// returns false if the update should be ignored
@@ -79,7 +88,7 @@ private:
        Interface interface;
        ChunkReceiver chunk_receiver;
        ChunkRenderer chunk_renderer;
-       IntervalTimer loop_timer;
+       CoarseTimer loop_timer;
 
        SkyBox sky;
 
@@ -89,6 +98,8 @@ private:
        };
        std::map<std::uint32_t, UpdateStatus> update_status;
 
+       ChatState chat;
+
 };
 
 }