]> git.localhorst.tv Git - blank.git/blobdiff - src/client/InteractiveState.hpp
fix this whole sky box mess
[blank.git] / src / client / InteractiveState.hpp
index eaca4c9c78880d8679755c24d71f2558f7ea1977..5a43cd89e63b18757d4675bb7a001e0775db7884 100644 (file)
@@ -1,8 +1,11 @@
 #ifndef BLANK_CLIENT_INTERACTIVESTATE_HPP_
 #define BLANK_CLIENT_INTERACTIVESTATE_HPP_
 
+#include "ChunkReceiver.hpp"
+#include "ChunkRequester.hpp"
 #include "../app/IntervalTimer.hpp"
 #include "../app/State.hpp"
+#include "../graphics/SkyBox.hpp"
 #include "../io/WorldSave.hpp"
 #include "../model/Skeletons.hpp"
 #include "../ui/Interface.hpp"
@@ -30,6 +33,7 @@ public:
 
        World &GetWorld() noexcept { return world; }
        Interface &GetInterface() noexcept { return interface; }
+       ChunkReceiver &GetChunkReceiver() noexcept { return chunk_receiver; }
        Skeletons &GetSkeletons() noexcept { return skeletons; }
 
        void OnEnter() override;
@@ -38,7 +42,7 @@ public:
        void Update(int dt) override;
        void Render(Viewport &) override;
 
-       void PushPlayerUpdate(const Entity &);
+       void PushPlayerUpdate(const Entity &, int dt);
        void MergePlayerCorrection(std::uint16_t, const EntityState &);
 
 private:
@@ -47,16 +51,20 @@ private:
        WorldSave save;
        World world;
        Interface interface;
+       ChunkRequester chunk_requester;
+       ChunkReceiver chunk_receiver;
        ChunkRenderer chunk_renderer;
        Skeletons skeletons;
        IntervalTimer loop_timer;
-       IntervalTimer update_timer;
+
+       SkyBox sky;
 
        struct PlayerHistory {
                EntityState state;
+               int delta_t;
                std::uint16_t packet;
-               PlayerHistory(EntityState s, std::uint16_t p)
-               : state(s), packet(p) { }
+               PlayerHistory(EntityState s, int dt, std::uint16_t p)
+               : state(s), delta_t(dt), packet(p) { }
        };
        std::list<PlayerHistory> player_hist;