Index: Source/core/animation/InterpolableValue.cpp |
diff --git a/Source/core/animation/InterpolableValue.cpp b/Source/core/animation/InterpolableValue.cpp |
index 67bcfb8aa68320cd7388f64b4fff11ce474abfe9..ed84e275a5f2e89e129256a2eed5f202252404a4 100644 |
--- a/Source/core/animation/InterpolableValue.cpp |
+++ b/Source/core/animation/InterpolableValue.cpp |
@@ -4,48 +4,43 @@ |
#include "config.h" |
#include "core/animation/InterpolableValue.h" |
+#include "platform/animation/AnimationUtilities.h" |
namespace blink { |
DEFINE_EMPTY_DESTRUCTOR_WILL_BE_REMOVED(InterpolableValue); |
-PassOwnPtrWillBeRawPtr<InterpolableValue> InterpolableNumber::interpolate(const InterpolableValue &to, const double progress) const |
+void InterpolableNumber::assignInterpolation(const InterpolableValue& from, const InterpolableValue& to, const double progress) |
{ |
+ const InterpolableNumber& fromNumber = toInterpolableNumber(from); |
const InterpolableNumber& toNumber = toInterpolableNumber(to); |
- if (!progress) |
- return create(m_value); |
- if (progress == 1) |
- return create(toNumber.m_value); |
- return create(m_value * (1 - progress) + toNumber.m_value * progress); |
+ if (progress == 0) |
+ m_value = fromNumber.m_value; |
+ else if (progress == 1) |
+ m_value = toNumber.m_value; |
+ else |
+ m_value = blend(fromNumber.m_value, toNumber.m_value, progress); |
} |
-PassOwnPtrWillBeRawPtr<InterpolableValue> InterpolableBool::interpolate(const InterpolableValue &to, const double progress) const |
+void InterpolableBool::assignInterpolation(const InterpolableValue& from, const InterpolableValue& to, const double progress) |
{ |
- if (progress < 0.5) { |
- return clone(); |
- } |
- return to.clone(); |
+ const InterpolableBool& fromBool = toInterpolableBool(from); |
+ const InterpolableBool& toBool = toInterpolableBool(to); |
+ if (progress < 0.5) |
+ m_value = fromBool.m_value; |
+ else |
+ m_value = toBool.m_value; |
} |
-PassOwnPtrWillBeRawPtr<InterpolableValue> InterpolableList::interpolate(const InterpolableValue &to, const double progress) const |
+void InterpolableList::assignInterpolation(const InterpolableValue& from, const InterpolableValue& to, const double progress) |
{ |
+ const InterpolableList& fromList = toInterpolableList(from); |
const InterpolableList& toList = toInterpolableList(to); |
+ ASSERT(fromList.m_size == m_size); |
ASSERT(toList.m_size == m_size); |
- if (!progress) { |
- return create(*this); |
- } |
- if (progress == 1) { |
- return InterpolableList::create(toList); |
- } |
- |
- OwnPtrWillBeRawPtr<InterpolableList> result = create(m_size); |
- for (size_t i = 0; i < m_size; i++) { |
- ASSERT(m_values[i]); |
- ASSERT(toList.m_values[i]); |
- result->set(i, m_values[i]->interpolate(*(toList.m_values[i]), progress)); |
- } |
- return result.release(); |
+ for (size_t i = 0; i < m_size; ++i) |
+ m_values.at(i)->assignInterpolation(*fromList.m_values.at(i), *toList.m_values.at(i), progress); |
} |
void InterpolableList::trace(Visitor* visitor) |
@@ -56,14 +51,16 @@ void InterpolableList::trace(Visitor* visitor) |
InterpolableValue::trace(visitor); |
} |
-PassOwnPtrWillBeRawPtr<InterpolableValue> InterpolableAnimatableValue::interpolate(const InterpolableValue &other, const double percentage) const |
+void InterpolableAnimatableValue::assignInterpolation(const InterpolableValue& from, const InterpolableValue& to, const double progress) |
{ |
- const InterpolableAnimatableValue& otherValue = toInterpolableAnimatableValue(other); |
- if (!percentage) |
- return create(m_value); |
- if (percentage == 1) |
- return create(otherValue.m_value); |
- return create(AnimatableValue::interpolate(m_value.get(), otherValue.m_value.get(), percentage)); |
+ const InterpolableAnimatableValue& fromValue = toInterpolableAnimatableValue(from); |
+ const InterpolableAnimatableValue& toValue = toInterpolableAnimatableValue(to); |
+ if (progress == 0) |
+ m_value = fromValue.m_value; |
+ else if (progress == 1) |
+ m_value = toValue.m_value; |
+ else |
+ m_value = AnimatableValue::interpolate(fromValue.m_value.get(), toValue.m_value.get(), progress); |
} |
void InterpolableAnimatableValue::trace(Visitor* visitor) |