Merge pull request #29331 from KoBeWi/animation_time_machine
Add track_set_key_time() to Animation
This commit is contained in:
commit
7770f8cb7e
@ -562,6 +562,19 @@
|
|||||||
Set the value of an existing key.
|
Set the value of an existing key.
|
||||||
</description>
|
</description>
|
||||||
</method>
|
</method>
|
||||||
|
<method name="track_set_key_time">
|
||||||
|
<return type="void">
|
||||||
|
</return>
|
||||||
|
<argument index="0" name="idx" type="int">
|
||||||
|
</argument>
|
||||||
|
<argument index="1" name="key_idx" type="int">
|
||||||
|
</argument>
|
||||||
|
<argument index="2" name="time" type="float">
|
||||||
|
</argument>
|
||||||
|
<description>
|
||||||
|
Set the time of an existing key.
|
||||||
|
</description>
|
||||||
|
</method>
|
||||||
<method name="track_set_path">
|
<method name="track_set_path">
|
||||||
<return type="void">
|
<return type="void">
|
||||||
</return>
|
</return>
|
||||||
|
@ -1298,6 +1298,78 @@ float Animation::track_get_key_time(int p_track, int p_key_idx) const {
|
|||||||
ERR_FAIL_V(-1);
|
ERR_FAIL_V(-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Animation::track_set_key_time(int p_track, int p_key_idx, float p_time) {
|
||||||
|
|
||||||
|
ERR_FAIL_INDEX(p_track, tracks.size());
|
||||||
|
Track *t = tracks[p_track];
|
||||||
|
|
||||||
|
switch (t->type) {
|
||||||
|
|
||||||
|
case TYPE_TRANSFORM: {
|
||||||
|
|
||||||
|
TransformTrack *tt = static_cast<TransformTrack *>(t);
|
||||||
|
ERR_FAIL_INDEX(p_key_idx, tt->transforms.size());
|
||||||
|
TKey<TransformKey> key = tt->transforms[p_key_idx];
|
||||||
|
key.time = p_time;
|
||||||
|
tt->transforms.remove(p_key_idx);
|
||||||
|
_insert(p_time, tt->transforms, key);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
case TYPE_VALUE: {
|
||||||
|
|
||||||
|
ValueTrack *vt = static_cast<ValueTrack *>(t);
|
||||||
|
ERR_FAIL_INDEX(p_key_idx, vt->values.size());
|
||||||
|
TKey<Variant> key = vt->values[p_key_idx];
|
||||||
|
key.time = p_time;
|
||||||
|
vt->values.remove(p_key_idx);
|
||||||
|
_insert(p_time, vt->values, key);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
case TYPE_METHOD: {
|
||||||
|
|
||||||
|
MethodTrack *mt = static_cast<MethodTrack *>(t);
|
||||||
|
ERR_FAIL_INDEX(p_key_idx, mt->methods.size());
|
||||||
|
MethodKey key = mt->methods[p_key_idx];
|
||||||
|
key.time = p_time;
|
||||||
|
mt->methods.remove(p_key_idx);
|
||||||
|
_insert(p_time, mt->methods, key);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
case TYPE_BEZIER: {
|
||||||
|
|
||||||
|
BezierTrack *bt = static_cast<BezierTrack *>(t);
|
||||||
|
ERR_FAIL_INDEX(p_key_idx, bt->values.size());
|
||||||
|
TKey<BezierKey> key = bt->values[p_key_idx];
|
||||||
|
key.time = p_time;
|
||||||
|
bt->values.remove(p_key_idx);
|
||||||
|
_insert(p_time, bt->values, key);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
case TYPE_AUDIO: {
|
||||||
|
|
||||||
|
AudioTrack *at = static_cast<AudioTrack *>(t);
|
||||||
|
ERR_FAIL_INDEX(p_key_idx, at->values.size());
|
||||||
|
TKey<AudioKey> key = at->values[p_key_idx];
|
||||||
|
key.time = p_time;
|
||||||
|
at->values.remove(p_key_idx);
|
||||||
|
_insert(p_time, at->values, key);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
case TYPE_ANIMATION: {
|
||||||
|
|
||||||
|
AnimationTrack *at = static_cast<AnimationTrack *>(t);
|
||||||
|
ERR_FAIL_INDEX(p_key_idx, at->values.size());
|
||||||
|
TKey<StringName> key = at->values[p_key_idx];
|
||||||
|
key.time = p_time;
|
||||||
|
at->values.remove(p_key_idx);
|
||||||
|
_insert(p_time, at->values, key);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
ERR_FAIL();
|
||||||
|
}
|
||||||
|
|
||||||
float Animation::track_get_key_transition(int p_track, int p_key_idx) const {
|
float Animation::track_get_key_transition(int p_track, int p_key_idx) const {
|
||||||
|
|
||||||
ERR_FAIL_INDEX_V(p_track, tracks.size(), -1);
|
ERR_FAIL_INDEX_V(p_track, tracks.size(), -1);
|
||||||
@ -2691,6 +2763,7 @@ void Animation::_bind_methods() {
|
|||||||
ClassDB::bind_method(D_METHOD("track_remove_key_at_position", "idx", "position"), &Animation::track_remove_key_at_position);
|
ClassDB::bind_method(D_METHOD("track_remove_key_at_position", "idx", "position"), &Animation::track_remove_key_at_position);
|
||||||
ClassDB::bind_method(D_METHOD("track_set_key_value", "idx", "key", "value"), &Animation::track_set_key_value);
|
ClassDB::bind_method(D_METHOD("track_set_key_value", "idx", "key", "value"), &Animation::track_set_key_value);
|
||||||
ClassDB::bind_method(D_METHOD("track_set_key_transition", "idx", "key_idx", "transition"), &Animation::track_set_key_transition);
|
ClassDB::bind_method(D_METHOD("track_set_key_transition", "idx", "key_idx", "transition"), &Animation::track_set_key_transition);
|
||||||
|
ClassDB::bind_method(D_METHOD("track_set_key_time", "idx", "key_idx", "time"), &Animation::track_set_key_time);
|
||||||
ClassDB::bind_method(D_METHOD("track_get_key_transition", "idx", "key_idx"), &Animation::track_get_key_transition);
|
ClassDB::bind_method(D_METHOD("track_get_key_transition", "idx", "key_idx"), &Animation::track_get_key_transition);
|
||||||
|
|
||||||
ClassDB::bind_method(D_METHOD("track_get_key_count", "idx"), &Animation::track_get_key_count);
|
ClassDB::bind_method(D_METHOD("track_get_key_count", "idx"), &Animation::track_get_key_count);
|
||||||
|
@ -305,6 +305,7 @@ public:
|
|||||||
void track_insert_key(int p_track, float p_time, const Variant &p_key, float p_transition = 1);
|
void track_insert_key(int p_track, float p_time, const Variant &p_key, float p_transition = 1);
|
||||||
void track_set_key_transition(int p_track, int p_key_idx, float p_transition);
|
void track_set_key_transition(int p_track, int p_key_idx, float p_transition);
|
||||||
void track_set_key_value(int p_track, int p_key_idx, const Variant &p_value);
|
void track_set_key_value(int p_track, int p_key_idx, const Variant &p_value);
|
||||||
|
void track_set_key_time(int p_track, int p_key_idx, float p_time);
|
||||||
int track_find_key(int p_track, float p_time, bool p_exact = false) const;
|
int track_find_key(int p_track, float p_time, bool p_exact = false) const;
|
||||||
void track_remove_key(int p_track, int p_idx);
|
void track_remove_key(int p_track, int p_idx);
|
||||||
void track_remove_key_at_position(int p_track, float p_pos);
|
void track_remove_key_at_position(int p_track, float p_pos);
|
||||||
|
Loading…
Reference in New Issue
Block a user