X-Git-Url: https://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fui%2FInterface.hpp;h=0cffd762cc29ea79af24b2204a94f0d4299c9e29;hb=5cd73a8f2b40e59ec13aa2a6af33bc8e2a6b9a6c;hp=0c140fb88ff40ad18357cd3b42cfce17fbfda5e2;hpb=b7d09e1e35ef90282c97509e0020b20db3c7ea9f;p=blank.git diff --git a/src/ui/Interface.hpp b/src/ui/Interface.hpp index 0c140fb..0cffd76 100644 --- a/src/ui/Interface.hpp +++ b/src/ui/Interface.hpp @@ -1,21 +1,26 @@ #ifndef BLANK_UI_INTERFACE_HPP_ #define BLANK_UI_INTERFACE_HPP_ +#include "FixedText.hpp" #include "HUD.hpp" +#include "MessageBox.hpp" #include "../app/FPSController.hpp" #include "../app/IntervalTimer.hpp" +#include "../audio/Sound.hpp" #include "../model/geometry.hpp" #include "../model/OutlineModel.hpp" #include "../world/Block.hpp" -#include +#include #include +#include namespace blank { class Chunk; -class DirectionalLighting; +class Environment; +class Viewport; class World; class Interface { @@ -28,10 +33,11 @@ public: bool keyboard_disabled = false; bool mouse_disabled = false; + bool audio_disabled = false; bool visual_disabled = false; }; - Interface(const Config &, World &); + Interface(const Config &, Environment &, World &); void HandlePress(const SDL_KeyboardEvent &); void HandleRelease(const SDL_KeyboardEvent &); @@ -39,11 +45,12 @@ public: void HandlePress(const SDL_MouseButtonEvent &); void HandleRelease(const SDL_MouseButtonEvent &); void Handle(const SDL_MouseWheelEvent &); - void Handle(const SDL_WindowEvent &) noexcept; void FaceBlock(); void TurnBlock(); + void ToggleCollision(); + void PickBlock(); void PlaceBlock(); void RemoveBlock() noexcept; @@ -57,14 +64,27 @@ public: void SelectNext(); void SelectPrevious(); + void ToggleAudio(); + void ToggleVisual(); + + void ToggleDebug(); + void UpdateCounter(); + void UpdatePosition(); + + void PostMessage(const char *); + void PostMessage(const std::string &msg) { + PostMessage(msg.c_str()); + } + void Update(int dt); - void Render(DirectionalLighting &) noexcept; + void Render(Viewport &) noexcept; private: void CheckAim(); private: + Environment &env; World &world; FPSController ctrl; HUD hud; @@ -77,6 +97,11 @@ private: OutlineModel outline; glm::mat4 outline_transform; + FixedText counter_text; + FixedText position_text; + MessageBox messages; + IntervalTimer msg_timer; + Config config; IntervalTimer place_timer; @@ -85,7 +110,10 @@ private: Block remove; Block selection; - glm::tvec3 fwd, rev; + Sound place_sound; + Sound remove_sound; + + glm::ivec3 fwd, rev; };