浏览代码

Merge pull request #81127 from KoBeWi/errors_begone

Prevent errors if Tween callback's object is freed
Rémi Verschelde 2 年之前
父节点
当前提交
922689c801
共有 3 个文件被更改,包括 10 次插入0 次删除
  1. 1 0
      doc/classes/CallbackTweener.xml
  2. 1 0
      doc/classes/MethodTweener.xml
  3. 8 0
      scene/animation/tween.cpp

+ 1 - 0
doc/classes/CallbackTweener.xml

@@ -5,6 +5,7 @@
 	</brief_description>
 	</brief_description>
 	<description>
 	<description>
 		[CallbackTweener] is used to call a method in a tweening sequence. See [method Tween.tween_callback] for more usage information.
 		[CallbackTweener] is used to call a method in a tweening sequence. See [method Tween.tween_callback] for more usage information.
+		The tweener will finish automatically if the callback's target object is freed.
 		[b]Note:[/b] [method Tween.tween_callback] is the only correct way to create [CallbackTweener]. Any [CallbackTweener] created manually will not function correctly.
 		[b]Note:[/b] [method Tween.tween_callback] is the only correct way to create [CallbackTweener]. Any [CallbackTweener] created manually will not function correctly.
 	</description>
 	</description>
 	<tutorials>
 	<tutorials>

+ 1 - 0
doc/classes/MethodTweener.xml

@@ -5,6 +5,7 @@
 	</brief_description>
 	</brief_description>
 	<description>
 	<description>
 		[MethodTweener] is similar to a combination of [CallbackTweener] and [PropertyTweener]. It calls a method providing an interpolated value as a parameter. See [method Tween.tween_method] for more usage information.
 		[MethodTweener] is similar to a combination of [CallbackTweener] and [PropertyTweener]. It calls a method providing an interpolated value as a parameter. See [method Tween.tween_method] for more usage information.
+		The tweener will finish automatically if the callback's target object is freed.
 		[b]Note:[/b] [method Tween.tween_method] is the only correct way to create [MethodTweener]. Any [MethodTweener] created manually will not function correctly.
 		[b]Note:[/b] [method Tween.tween_method] is the only correct way to create [MethodTweener]. Any [MethodTweener] created manually will not function correctly.
 	</description>
 	</description>
 	<tutorials>
 	<tutorials>

+ 8 - 0
scene/animation/tween.cpp

@@ -675,6 +675,10 @@ bool CallbackTweener::step(double &r_delta) {
 		return false;
 		return false;
 	}
 	}
 
 
+	if (!callback.get_object()) {
+		return false;
+	}
+
 	elapsed_time += r_delta;
 	elapsed_time += r_delta;
 	if (elapsed_time >= delay) {
 	if (elapsed_time >= delay) {
 		Variant result;
 		Variant result;
@@ -736,6 +740,10 @@ bool MethodTweener::step(double &r_delta) {
 		return false;
 		return false;
 	}
 	}
 
 
+	if (!callback.get_object()) {
+		return false;
+	}
+
 	elapsed_time += r_delta;
 	elapsed_time += r_delta;
 
 
 	if (elapsed_time < delay) {
 	if (elapsed_time < delay) {