]> git.xonotic.org Git - xonotic/xonotic-data.pk3dir.git/blobdiff - qcsrc/menu/anim/keyframe.qc
take3: format 903 files
[xonotic/xonotic-data.pk3dir.git] / qcsrc / menu / anim / keyframe.qc
index 3bcda94e692939b733c668cf09e46b27e59364c6..f6e5b5de0cc2424b4190a0fa39f73894cac7c2ea 100644 (file)
-#ifdef INTERFACE
-CLASS(Keyframe) EXTENDS(Animation)
-       METHOD(Keyframe, addEasing, entity(entity, float, float, float(float, float, float, float)))
-       METHOD(Keyframe, addAnim, void(entity, entity))
-       METHOD(Keyframe, calcValue, float(entity, float, float, float, float))
-       ATTRIB(Keyframe, currentChild, entity, NULL)
-       ATTRIB(Keyframe, firstChild, entity, NULL)
-       ATTRIB(Keyframe, lastChild, entity, NULL)
-ENDCLASS(Keyframe)
-entity makeHostedKeyframe(entity, void(entity, float), float, float, float);
-entity makeKeyframe(entity, void(entity, float), float, float, float);
-float getNewChildStart(entity);
-float getNewChildDuration(entity, float);
-float getNewChildValue(entity);
-#endif
-
-#ifdef IMPLEMENTATION
+#include "keyframe.qh"
+
+#include "../menu.qh"
+#include "easing.qh"
+
+#include "../item/container.qh"
+
+.entity parent;
+
 entity makeHostedKeyframe(entity obj, void(entity, float) objSetter, float animDuration, float animStart, float animEnd)
 {
-       entity me;
-       me = makeKeyframe(obj, objSetter, animDuration, animStart, animEnd);
-       anim.addAnim(anim, me);
-       return me;
+       entity this = makeKeyframe(obj, objSetter, animDuration, animStart, animEnd);
+       anim.addAnim(anim, this);
+       return this;
 }
 
 entity makeKeyframe(entity obj, void(entity, float) objSetter, float animDuration, float animStart, float animEnd)
 {
-       entity me;
-       me = spawnKeyframe();
-       me.configureAnimation(me, obj, objSetter, time, animDuration, animStart, animEnd);
-       return me;
+       entity this = NEW(Keyframe);
+       this.configureAnimation(this, obj, objSetter, time, animDuration, animStart, animEnd);
+       return this;
 }
 
-entity Keyframe_addEasing(entity me, float animDurationTime, float animEnd, float(float, float, float, float) func)
+METHOD(Keyframe, addEasing, entity(entity this, float animDurationTime, float animEnd, float(float, float, float, float) func))
 {
-       entity other;
-       other = makeEasing(me.object, me.setter, func, getNewChildStart(me), getNewChildDuration(me, animDurationTime), getNewChildValue(me), animEnd);
-       me.addAnim(me, other);
+       entity other = makeEasing(this.object, this.setter, func, getNewChildStart(this), getNewChildDuration(this, animDurationTime), getNewChildValue(this), animEnd);
+       this.addAnim(this, other);
        return other;
 }
 
-float getNewChildStart(entity me)
+float getNewChildStart(entity this)
 {
-       if (me.lastChild)
-               return (me.lastChild.startTime + me.lastChild.duration);
-       else
-               return 0;
+       if (this.lastChild) { return this.lastChild.startTime + this.lastChild.duration; } else { return 0; }
 }
 
-float getNewChildDuration(entity me, float durationTime)
+float getNewChildDuration(entity this, float durationTime)
 {
-       float dura, maxDura;
-       maxDura = me.duration;
-       if (me.lastChild) maxDura = maxDura - (me.lastChild.startTime + me.lastChild.duration);
-       dura = durationTime;
-       if (0 >= dura || dura > maxDura) dura = maxDura;
+       float maxDura = this.duration;
+       if (this.lastChild) { maxDura = maxDura - (this.lastChild.startTime + this.lastChild.duration); }
+       float dura = durationTime;
+       if (0 >= dura || dura > maxDura) { dura = maxDura; }
        return dura;
 }
 
-float getNewChildValue(entity me)
+float getNewChildValue(entity this)
 {
-       if (me.lastChild)
-               return (me.lastChild.startValue + me.lastChild.delta);
-       else
-               return me.startValue;
+       if (this.lastChild) { return this.lastChild.startValue + this.lastChild.delta; } else { return this.startValue; }
 }
 
-void Keyframe_addAnim(entity me, entity other)
+METHOD(Keyframe, addAnim, void(entity this, entity other))
 {
-       if(other.parent)
-               error("Can't add already added anim!");
+       if (other.parent) { error("Can't add already added anim!"); }
 
-       if(other.isFinished(other))
-               error("Can't add finished anim!");
+       if (other.isFinished(other)) { error("Can't add finished anim!"); }
 
-       other.parent = me;
+       other.parent = this;
 
-       entity l;
-       l = me.lastChild;
+       entity l = this.lastChild;
 
-       if(l)
+       if (l) {
                l.nextSibling = other;
-       else
-       {
-               me.currentChild = other;
-               me.firstChild = other;
+       } else {
+               this.currentChild = other;
+               this.firstChild = other;
        }
 
        other.prevSibling = l;
        other.nextSibling = NULL;
-       me.lastChild = other;
+       this.lastChild = other;
 }
 
-float Keyframe_calcValue(entity me, float tickTime, float animDuration, float animStartValue, float animDelta)
+METHOD(Keyframe, calcValue, float(entity this, float tickTime, float animDuration, float animStartValue, float animDelta))
 {
-       if (me.currentChild)
-               if (me.currentChild.isFinished(me.currentChild))
-                       me.currentChild = me.currentChild.nextSibling;
-
-       if (me.currentChild)
-       {
-               me.currentChild.tick(me.currentChild, tickTime);
-               return me.currentChild.value;
+       if (this.currentChild) {
+               if (this.currentChild.isFinished(this.currentChild)) { this.currentChild = this.currentChild.nextSibling; } }
+
+       if (this.currentChild) {
+               this.currentChild.tick(this.currentChild, tickTime);
+               return this.currentChild.value;
        }
 
        return animStartValue + animDelta;
 }
-#endif