]> git.rm.cloudns.org Git - xonotic/xonotic-data.pk3dir.git/commitdiff
Add align option to debug_text_3d
authorterencehill <piuntn@gmail.com>
Sat, 24 Feb 2018 21:35:09 +0000 (22:35 +0100)
committerterencehill <piuntn@gmail.com>
Sat, 24 Feb 2018 21:35:09 +0000 (22:35 +0100)
qcsrc/common/debug.qh
xonotic-server.cfg

index e05d67fcd16a2aa5d25e505be0557761b4b53443..7144bf3da5ed6bb4166c3cc5b3f8f4895d416a7f 100644 (file)
@@ -394,14 +394,16 @@ CLASS(DebugText3d, Object)
        // reusing existing fields
        ATTRIB(DebugText3d, origin, vector);
        ATTRIB(DebugText3d, message, string); // the text (i wanted to use the .text field but then this whole macro-based-inheritance thing shat itself)
+       ATTRIB(DebugText3d, health, float); // text alignment (recycled field)
        ATTRIB(DebugText3d, hit_time, float); // when it was created
        ATTRIB(DebugText3d, fade_rate, float); // how fast is should disappear
        ATTRIB(DebugText3d, velocity, vector);
 
-       CONSTRUCTOR(DebugText3d, vector pos, string msg, float fade_rate_, vector vel) {
+       CONSTRUCTOR(DebugText3d, vector pos, string msg, float align, float fade_rate_, vector vel) {
                CONSTRUCT(DebugText3d);
                this.origin = pos;
                this.message = strzone(msg);
+               this.health = align;
                this.hit_time = time;
                this.fade_rate = fade_rate_;
                this.velocity = vel;
@@ -421,12 +423,15 @@ CLASS(DebugText3d, Object)
                        return;
                }
 
+               int size = 8;
                vector screen_pos = project_3d_to_2d(this.origin) + since_created * this.velocity;
+               float align = this.health;
+               if (align > 0)
+                       screen_pos.x -= stringwidth(this.message, true, size * '1 1 0') * min(1, align);
                if (screen_pos.z < 0) return; // behind camera
                screen_pos.z = 0;
 
                vector rgb = '1 1 0';
-               int size = 8;
                drawcolorcodedstring2_builtin(screen_pos, this.message, size * '1 1 0', rgb, alpha_, DRAWFLAG_NORMAL);
        }
        ATTRIB(DebugText3d, draw2d, void(DebugText3d), DebugText3d_draw2d);
@@ -435,9 +440,10 @@ ENDCLASS(DebugText3d)
 NET_HANDLE(debug_text_3d, bool is_new) {
        vector pos = ReadVector();
        string msg = ReadString();
+       float align = ReadFloat();
        float duration = ReadFloat();
        vector vel = ReadVector();
-       make_impure(NEW(DebugText3d, pos, msg, 1 / duration, vel));
+       make_impure(NEW(DebugText3d, pos, msg, align, 1 / duration, vel));
        return true;
 }
 
@@ -447,14 +453,17 @@ NET_HANDLE(debug_text_3d, bool is_new) {
 
 // can't use autocvars because they give unused warning unless the macros are expanded
 #define debug_text_3d(...) EVAL(OVERLOAD(debug_text_3d, __VA_ARGS__))
-#define debug_text_3d_2(pos, msg) debug_text_3d_3(pos, msg, cvar("debug_text_3d_default_duration"))
-#define debug_text_3d_3(pos, msg, dur) debug_text_3d_4(pos, msg, dur, stov(cvar_string("debug_text_3d_default_velocity")))
-#define debug_text_3d_4(pos, msg, dur, vel) debug_text_3d_fn(pos, msg, dur, vel)
+#define debug_text_3d_2(pos, msg) debug_text_3d_3(pos, msg, cvar("debug_text_3d_default_align"))
+#define debug_text_3d_3(pos, msg, align) debug_text_3d_4(pos, msg, align, cvar("debug_text_3d_default_duration"))
+#define debug_text_3d_4(pos, msg, align, dur) debug_text_3d_5(pos, msg, align, dur, stov(cvar_string("debug_text_3d_default_velocity")))
+#define debug_text_3d_5(pos, msg, align, dur, vel) debug_text_3d_fn(pos, msg, align, dur, vel)
 
-void debug_text_3d_fn(vector pos, string msg, float duration, vector velocity) {
+ERASEABLE
+void debug_text_3d_fn(vector pos, string msg, float align, float duration, vector velocity) {
        WriteHeader(MSG_BROADCAST, debug_text_3d);
        WriteVector(MSG_BROADCAST, pos);
        WriteString(MSG_BROADCAST, msg);
+       WriteFloat(MSG_BROADCAST, align);
        WriteFloat(MSG_BROADCAST, duration);
        WriteVector(MSG_BROADCAST, velocity);
 }
index dcd61c09cd54ddb30102bc1d154d96307c41d7f8..7b6504d5162875ab34d7c6f61710366352c78605 100644 (file)
@@ -469,6 +469,7 @@ set sv_accuracy_data_send 1 "1 send weapon accuracy data statistics and improved
 set _independent_players 0 "DO NOT TOUCH"
 set _notarget 0 "NO, REALLY, DON'T"
 
+set debug_text_3d_default_align 0 "Default text alignment for debug_text_3d()"
 set debug_text_3d_default_duration 10 "Default duration for debug_text_3d()"
 set debug_text_3d_default_velocity "0 -10 0" "Default velocity for debug_text_3d() in screen coords (X and Y from top left)"