summaryrefslogtreecommitdiffstats
path: root/scene/resources/animation.cpp
diff options
context:
space:
mode:
authorMichael Wörner <michael.woerner@blickshift.de>2023-12-11 22:41:16 +0100
committerMichael Wörner <michael.woerner@blickshift.de>2023-12-13 00:24:46 +0100
commit12ce2e33b237d7aec91ef314a23edae5dde3fd4f (patch)
tree7e3614f3703a1e203c6cc0d2015e7919e51d8ac2 /scene/resources/animation.cpp
parent6882e5042d1ebada62f07130a44a85b032944c31 (diff)
downloadredot-engine-12ce2e33b237d7aec91ef314a23edae5dde3fd4f.tar.gz
Restored the ability for linear interpolation to work on a mix of integer and float keyframes.
Diffstat (limited to 'scene/resources/animation.cpp')
-rw-r--r--scene/resources/animation.cpp46
1 files changed, 31 insertions, 15 deletions
diff --git a/scene/resources/animation.cpp b/scene/resources/animation.cpp
index b1b3bab937..52850cac4a 100644
--- a/scene/resources/animation.cpp
+++ b/scene/resources/animation.cpp
@@ -5485,7 +5485,7 @@ Variant Animation::cast_to_blendwise(const Variant p_value) {
switch (p_value.get_type()) {
case Variant::BOOL:
case Variant::INT: {
- return p_value.operator real_t();
+ return p_value.operator double();
} break;
case Variant::STRING:
case Variant::STRING_NAME: {
@@ -5521,7 +5521,7 @@ Variant Animation::cast_from_blendwise(const Variant p_value, const Variant::Typ
return p_value.operator real_t() >= 0.5;
} break;
case Variant::INT: {
- return (int)Math::round(p_value.operator real_t());
+ return (int64_t)Math::round(p_value.operator double());
} break;
case Variant::STRING: {
return array_to_string(p_value);
@@ -5594,8 +5594,12 @@ Variant Animation::array_to_string(const Variant p_value) {
}
Variant Animation::add_variant(const Variant &a, const Variant &b) {
- if (a.get_type() != b.get_type() && !a.is_array()) {
- return a;
+ if (a.get_type() != b.get_type()) {
+ if (a.is_num() && b.is_num()) {
+ return add_variant(cast_to_blendwise(a), cast_to_blendwise(b));
+ } else if (!a.is_array()) {
+ return a;
+ }
}
switch (a.get_type()) {
@@ -5603,7 +5607,7 @@ Variant Animation::add_variant(const Variant &a, const Variant &b) {
return Variant();
} break;
case Variant::FLOAT: {
- return (a.operator real_t()) + (b.operator real_t());
+ return (a.operator double()) + (b.operator double());
} break;
case Variant::RECT2: {
const Rect2 ra = a.operator Rect2();
@@ -5704,8 +5708,12 @@ Variant Animation::add_variant(const Variant &a, const Variant &b) {
}
Variant Animation::subtract_variant(const Variant &a, const Variant &b) {
- if (a.get_type() != b.get_type() && !a.is_array()) {
- return a;
+ if (a.get_type() != b.get_type()) {
+ if (a.is_num() && b.is_num()) {
+ return subtract_variant(cast_to_blendwise(a), cast_to_blendwise(b));
+ } else if (!a.is_array()) {
+ return a;
+ }
}
switch (a.get_type()) {
@@ -5713,7 +5721,7 @@ Variant Animation::subtract_variant(const Variant &a, const Variant &b) {
return Variant();
} break;
case Variant::FLOAT: {
- return (a.operator real_t()) - (b.operator real_t());
+ return (a.operator double()) - (b.operator double());
} break;
case Variant::RECT2: {
const Rect2 ra = a.operator Rect2();
@@ -5814,8 +5822,12 @@ Variant Animation::subtract_variant(const Variant &a, const Variant &b) {
}
Variant Animation::blend_variant(const Variant &a, const Variant &b, float c) {
- if (a.get_type() != b.get_type() && !a.is_array()) {
- return a;
+ if (a.get_type() != b.get_type()) {
+ if (a.is_num() && b.is_num()) {
+ return blend_variant(cast_to_blendwise(a), cast_to_blendwise(b), c);
+ } else if (!a.is_array()) {
+ return a;
+ }
}
switch (a.get_type()) {
@@ -5823,7 +5835,7 @@ Variant Animation::blend_variant(const Variant &a, const Variant &b, float c) {
return Variant();
} break;
case Variant::FLOAT: {
- return (a.operator real_t()) + (b.operator real_t()) * c;
+ return (a.operator double()) + (b.operator double()) * c;
} break;
case Variant::VECTOR2: {
return (a.operator Vector2()) + (b.operator Vector2()) * c;
@@ -5947,8 +5959,12 @@ Variant Animation::blend_variant(const Variant &a, const Variant &b, float c) {
}
Variant Animation::interpolate_variant(const Variant &a, const Variant &b, float c, bool p_snap_array_element) {
- if (a.get_type() != b.get_type() && !a.is_array()) {
- return a;
+ if (a.get_type() != b.get_type()) {
+ if (a.is_num() && b.is_num()) {
+ return interpolate_variant(cast_to_blendwise(a), cast_to_blendwise(b), c);
+ } else if (!a.is_array()) {
+ return a;
+ }
}
switch (a.get_type()) {
@@ -5956,8 +5972,8 @@ Variant Animation::interpolate_variant(const Variant &a, const Variant &b, float
return Variant();
} break;
case Variant::FLOAT: {
- const real_t va = a.operator real_t();
- return va + ((b.operator real_t()) - va) * c;
+ const double va = a.operator double();
+ return va + ((b.operator double()) - va) * c;
} break;
case Variant::VECTOR2: {
return (a.operator Vector2()).lerp(b.operator Vector2(), c);