浏览代码

Merge pull request #3980 from JoshuaGrams/timescale-remainder

TimeScale node: scale return value (time remaining).
Rémi Verschelde 9 年之前
父节点
当前提交
6ef3c3b645
共有 1 个文件被更改,包括 7 次插入2 次删除
  1. 7 2
      scene/animation/animation_tree_player.cpp

+ 7 - 2
scene/animation/animation_tree_player.cpp

@@ -637,10 +637,15 @@ float AnimationTreePlayer::_process_node(const StringName& p_node,AnimationNode
 		} break;
 		case NODE_TIMESCALE: {
 			TimeScaleNode *tsn = static_cast<TimeScaleNode*>(nb);
+			float rem;
 			if (p_seek)
-				return _process_node(tsn->inputs[0].node,r_prev_anim,p_weight,p_time,switched,true,p_filter,p_reverse_weight);
+				rem = _process_node(tsn->inputs[0].node,r_prev_anim,p_weight,p_time,switched,true,p_filter,p_reverse_weight);
+			else
+				rem = _process_node(tsn->inputs[0].node,r_prev_anim,p_weight,p_time*tsn->scale,switched,false,p_filter,p_reverse_weight);
+			if (tsn->scale == 0)
+				return INFINITY;
 			else
-				return _process_node(tsn->inputs[0].node,r_prev_anim,p_weight,p_time*tsn->scale,switched,false,p_filter,p_reverse_weight);
+				return rem / tsn->scale;
 
 		} break;
 		case NODE_TIMESEEK: {