]> git.localhorst.tv Git - blank.git/blobdiff - src/ui/HUD.hpp
test random ints of various widths
[blank.git] / src / ui / HUD.hpp
index 32a167b865d2979209f763a1e12341280f3b2f28..cbe28762727c81e90c47f973298bce545f3a6393 100644 (file)
@@ -4,9 +4,8 @@
 #include "FixedText.hpp"
 #include "MessageBox.hpp"
 #include "../graphics/EntityMesh.hpp"
-#include "../graphics/OutlineMesh.hpp"
-
-#include <glm/glm.hpp>
+#include "../graphics/glm.hpp"
+#include "../graphics/PrimitiveMesh.hpp"
 
 
 namespace blank {
@@ -14,6 +13,7 @@ namespace blank {
 class Block;
 class BlockTypeRegistry;
 class Config;
+class CongestionControl;
 class Environment;
 class Font;
 class Player;
@@ -42,11 +42,16 @@ public:
        void UpdatePosition();
        void UpdateOrientation();
 
+       // net stats
+       void UpdateNetStats(const CongestionControl &);
+
        // message box
        void PostMessage(const char *);
        void PostMessage(const std::string &msg) {
                PostMessage(msg.c_str());
        }
+       // whether to always render message box regardless of last post
+       void KeepMessages(bool k) { msg_keep = k; }
 
        void Update(int dt);
        void Render(Viewport &) noexcept;
@@ -57,7 +62,7 @@ private:
        const Player &player;
 
        // block focus
-       OutlineMesh outline;
+       PrimitiveMesh outline;
        glm::mat4 outline_transform;
        bool outline_visible;
 
@@ -77,12 +82,19 @@ private:
        bool show_block;
        bool show_entity;
 
+       // net stats
+       FixedText bandwidth_text;
+       FixedText rtt_text;
+       FixedText packet_loss_text;
+       bool show_net;
+
        // message box
        MessageBox messages;
-       IntervalTimer msg_timer;
+       CoarseTimer msg_timer;
+       bool msg_keep;
 
        // crosshair
-       OutlineMesh crosshair;
+       PrimitiveMesh crosshair;
 
 };