Merge pull request #4724 from Cybolic/optional-loop-interpolation

Added toggle for loop interpolation based on adolson's code
This commit is contained in:
Rémi Verschelde 2016-06-19 12:30:22 +02:00 committed by GitHub
commit 3520902194
6 changed files with 58 additions and 2 deletions

View file

@ -540,6 +540,7 @@ void AnimationPlayer::_animation_process_data(PlaybackData &cd,float p_delta,flo
float len=cd.from->animation->get_length();
bool loop=cd.from->animation->has_loop();
bool loop_interpolation=cd.from->animation->has_loop_interpolation();
if (!loop) {
@ -565,10 +566,21 @@ void AnimationPlayer::_animation_process_data(PlaybackData &cd,float p_delta,flo
}
} else {
} else if (loop_interpolation) {
next_pos=Math::fposmod(next_pos,len);
} else {
if (next_pos<0 or next_pos>len) {
if (!backwards)
next_pos=0;
else if (backwards)
next_pos=len;
}
// fix delta - not sure if needed here
delta=next_pos-cd.pos;
}
cd.pos=next_pos;

View file

@ -38,6 +38,8 @@ bool Animation::_set(const StringName& p_name, const Variant& p_value) {
set_length(p_value);
else if (name=="loop")
set_loop(p_value);
else if (name=="loop_interpolation")
set_loop_interpolation(p_value);
else if (name=="step")
set_step(p_value);
else if (name.begins_with("tracks/")) {
@ -1233,7 +1235,7 @@ T Animation::_interpolate( const Vector< TKey<T> >& p_keys, float p_time, Inter
float c=0;
// prepare for all cases of interpolation
if (loop) {
if (loop and loop_interpolation) {
// loop
if (idx>=0) {
@ -1621,10 +1623,19 @@ void Animation::set_loop(bool p_enabled) {
loop=p_enabled;
emit_changed();
}
void Animation::set_loop_interpolation(bool p_enabled) {
loop_interpolation=p_enabled;
emit_changed();
}
bool Animation::has_loop() const {
return loop;
}
bool Animation::has_loop_interpolation() const {
return loop_interpolation;
}
void Animation::track_move_up(int p_track) {
@ -1703,7 +1714,9 @@ void Animation::_bind_methods() {
ObjectTypeDB::bind_method(_MD("get_length"),&Animation::get_length);
ObjectTypeDB::bind_method(_MD("set_loop","enabled"),&Animation::set_loop);
ObjectTypeDB::bind_method(_MD("set_loop_interpolation","enabled"),&Animation::set_loop_interpolation);
ObjectTypeDB::bind_method(_MD("has_loop"),&Animation::has_loop);
ObjectTypeDB::bind_method(_MD("has_loop_interpolation"),&Animation::has_loop_interpolation);
ObjectTypeDB::bind_method(_MD("set_step","size_sec"),&Animation::set_step);
ObjectTypeDB::bind_method(_MD("get_step"),&Animation::get_step);
@ -1731,6 +1744,7 @@ void Animation::clear() {
memdelete( tracks[i] );
tracks.clear();
loop=false;
loop_interpolation=true;
length=1;
}
@ -1990,6 +2004,7 @@ Animation::Animation() {
step=0.1;
loop=false;
loop_interpolation=true;
length=1;
}

View file

@ -171,6 +171,7 @@ private:
float length;
float step;
bool loop;
bool loop_interpolation;
// bind helpers
private:
@ -274,7 +275,9 @@ public:
float get_length() const;
void set_loop(bool p_enabled);
void set_loop_interpolation(bool p_enabled);
bool has_loop() const;
bool has_loop_interpolation() const;
void set_step(float p_step);
float get_step() const;

View file

@ -2922,6 +2922,7 @@ void AnimationKeyEditor::_notification(int p_what) {
edit_button->connect("pressed",this,"_toggle_edit_curves");
loop->set_icon(get_icon("Loop","EditorIcons"));
loop_interpolation->set_icon(get_icon("LoopInterpolation","EditorIcons"));
curve_edit->connect("transition_changed",this,"_curve_transition_changed");
//edit_button->add_color_override("font_color",get_color("font_color","Tree"));
@ -3012,6 +3013,7 @@ void AnimationKeyEditor::_update_menu() {
length->set_val(animation->get_length());
loop->set_pressed(animation->has_loop());
loop_interpolation->set_pressed(animation->has_loop_interpolation());
step->set_val(animation->get_step());
}
@ -3467,6 +3469,21 @@ void AnimationKeyEditor::_animation_loop_changed() {
}
void AnimationKeyEditor::_animation_loop_interpolation_changed() {
if (updating)
return;
if (!animation.is_null()) {
undo_redo->create_action(TTR("Change Anim Loop Interpolation"));
undo_redo->add_do_method(animation.ptr(),"set_loop_interpolation",loop_interpolation->is_pressed());
undo_redo->add_undo_method(animation.ptr(),"set_loop_interpolation",!loop_interpolation->is_pressed());
undo_redo->commit_action();
}
}
void AnimationKeyEditor::_create_value_item(int p_type) {
@ -3752,6 +3769,7 @@ void AnimationKeyEditor::_bind_methods() {
ObjectTypeDB::bind_method(_MD("_animation_loop_changed"),&AnimationKeyEditor::_animation_loop_changed);
ObjectTypeDB::bind_method(_MD("_animation_loop_interpolation_changed"),&AnimationKeyEditor::_animation_loop_interpolation_changed);
ObjectTypeDB::bind_method(_MD("_animation_len_changed"),&AnimationKeyEditor::_animation_len_changed);
ObjectTypeDB::bind_method(_MD("_create_value_item"),&AnimationKeyEditor::_create_value_item);
ObjectTypeDB::bind_method(_MD("_pane_drag"),&AnimationKeyEditor::_pane_drag);
@ -3862,6 +3880,12 @@ AnimationKeyEditor::AnimationKeyEditor() {
hb->add_child(loop);
loop->set_tooltip(TTR("Enable/Disable looping in animation."));
loop_interpolation = memnew( ToolButton );
loop_interpolation->set_toggle_mode(true);
loop_interpolation->connect("pressed",this,"_animation_loop_interpolation_changed");
hb->add_child(loop_interpolation);
loop_interpolation->set_tooltip(TTR("Enable/Disable interpolation when looping animation."));
hb->add_child( memnew( VSeparator ) );
menu_add_track = memnew( MenuButton );

View file

@ -173,6 +173,7 @@ class AnimationKeyEditor : public VBoxContainer {
//MenuButton *menu;
SpinBox *length;
Button *loop;
Button *loop_interpolation;
bool keying;
ToolButton *edit_button;
ToolButton *move_up_button;
@ -238,6 +239,7 @@ class AnimationKeyEditor : public VBoxContainer {
void _animation_len_changed(float p_len);
void _animation_loop_changed();
void _animation_loop_interpolation_changed();
void _step_changed(float p_len);
struct InsertData {

Binary file not shown.

After

Width:  |  Height:  |  Size: 342 B