mirror of
https://github.com/Relintai/pandemonium_engine.git
synced 2025-01-03 01:19:38 +01:00
Cast between float and ints in SceneTreeTween.tween_property()
(cherry picked from commit 2b18a4002c8e500597bc8f5d605f9be8d1b22236)
This commit is contained in:
parent
c708c44180
commit
9086bef38d
@ -65,10 +65,17 @@ Ref<PropertyTweener> SceneTreeTween::tween_property(Object *p_target, NodePath p
|
||||
ERR_FAIL_COND_V_MSG(!valid, nullptr, "SceneTreeTween invalid. Either finished or created outside scene tree.");
|
||||
ERR_FAIL_COND_V_MSG(started, nullptr, "Can't append to a SceneTreeTween that has started. Use stop() first.");
|
||||
|
||||
#ifdef DEBUG_ENABLED
|
||||
Variant::Type property_type = p_target->get_indexed(p_property.get_as_property_path().get_subnames()).get_type();
|
||||
ERR_FAIL_COND_V_MSG(property_type != p_to.get_type(), Ref<PropertyTweener>(), "Type mismatch between property and final value: " + Variant::get_type_name(property_type) + " and " + Variant::get_type_name(p_to.get_type()));
|
||||
#endif
|
||||
if (property_type != p_to.get_type()) {
|
||||
// Cast p_to between floats and ints to avoid minor annoyances.
|
||||
if (property_type == Variant::REAL && p_to.get_type() == Variant::INT) {
|
||||
p_to = float(p_to);
|
||||
} else if (property_type == Variant::INT && p_to.get_type() == Variant::REAL) {
|
||||
p_to = int(p_to);
|
||||
} else {
|
||||
ERR_FAIL_V_MSG(Ref<PropertyTweener>(), "Type mismatch between property and final value: " + Variant::get_type_name(property_type) + " and " + Variant::get_type_name(p_to.get_type()));
|
||||
}
|
||||
}
|
||||
|
||||
Ref<PropertyTweener> tweener = memnew(PropertyTweener(p_target, p_property, p_to, p_duration));
|
||||
append(tweener);
|
||||
|
Loading…
Reference in New Issue
Block a user