| Index: third_party/WebKit/Source/core/animation/SVGNumberListInterpolationType.cpp
|
| diff --git a/third_party/WebKit/Source/core/animation/SVGNumberListInterpolationType.cpp b/third_party/WebKit/Source/core/animation/SVGNumberListInterpolationType.cpp
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..c8a7c511c66416cd4b1885462bee1c3fdd7fc123
|
| --- /dev/null
|
| +++ b/third_party/WebKit/Source/core/animation/SVGNumberListInterpolationType.cpp
|
| @@ -0,0 +1,74 @@
|
| +// Copyright 2015 The Chromium Authors. All rights reserved.
|
| +// Use of this source code is governed by a BSD-style license that can be
|
| +// found in the LICENSE file.
|
| +
|
| +#include "config.h"
|
| +#include "core/animation/SVGNumberListInterpolationType.h"
|
| +
|
| +#include "core/animation/InterpolationEnvironment.h"
|
| +#include "core/svg/SVGNumberList.h"
|
| +#include "core/svg/properties/SVGAnimatedProperty.h"
|
| +
|
| +namespace blink {
|
| +
|
| +PassOwnPtr<InterpolationValue> SVGNumberListInterpolationType::maybeConvertNeutral() const
|
| +{
|
| + return InterpolationValue::create(*this, InterpolableList::create(0));
|
| +}
|
| +
|
| +PassOwnPtr<InterpolationValue> SVGNumberListInterpolationType::maybeConvertSVGValue(const SVGPropertyBase& svgValue) const
|
| +{
|
| + if (svgValue.type() != AnimatedNumberList)
|
| + return nullptr;
|
| + const SVGNumberList& svgList = static_cast<const SVGNumberList&>(svgValue);
|
| + OwnPtr<InterpolableList> result = InterpolableList::create(svgList.length());
|
| + for (size_t i = 0; i < svgList.length(); i++)
|
| + result->set(i, InterpolableNumber::create(svgList.at(i)->value()));
|
| + return InterpolationValue::create(*this, result.release());
|
| +}
|
| +
|
| +PassOwnPtr<InterpolationValue> SVGNumberListInterpolationType::maybeConvertUnderlyingValue(const InterpolationEnvironment& environment) const
|
| +{
|
| + return maybeConvertSVGValue(environment.svgBaseValue());
|
| +}
|
| +
|
| +RefPtrWillBeRawPtr<SVGPropertyBase> SVGNumberListInterpolationType::appliedSVGValue(const InterpolableValue& interpolableValue, const NonInterpolableValue*) const
|
| +{
|
| + RefPtrWillBeRawPtr<SVGNumberList> result = SVGNumberList::create();
|
| + const InterpolableList& list = toInterpolableList(interpolableValue);
|
| + for (size_t i = 0; i < list.length(); ++i)
|
| + result->append(SVGNumber::create(toInterpolableNumber(list.get(i))->value()));
|
| + return result.release();
|
| +}
|
| +
|
| +PassOwnPtr<InterpolableList> padWithZeroes(PassOwnPtr<InterpolableValue> listValue, size_t paddedLength)
|
| +{
|
| + ASSERT(listValue && listValue->isList());
|
| + InterpolableList& list = toInterpolableList(*listValue);
|
| + OwnPtr<InterpolableList> result = InterpolableList::create(paddedLength);
|
| + for (size_t i = 0; i < list.length(); ++i)
|
| + result->set(i, list.getMutable(i).release());
|
| + for (size_t i = list.length(); i < paddedLength; ++i)
|
| + result->set(i, InterpolableNumber::create(0));
|
| +
|
| + return result.release();
|
| +}
|
| +
|
| +PassOwnPtr<PairwisePrimitiveInterpolation> SVGNumberListInterpolationType::mergeSingleConversions(InterpolationValue& startValue, InterpolationValue& endValue) const
|
| +{
|
| + OwnPtr<InterpolableValue> start = startValue.mutableComponent().interpolableValue.release();
|
| + OwnPtr<InterpolableValue> end = endValue.mutableComponent().interpolableValue.release();
|
| +
|
| + size_t startLength = toInterpolableList(*start).length();
|
| + size_t endLength = toInterpolableList(*end).length();
|
| + if (startLength < endLength)
|
| + start = padWithZeroes(start.release(), endLength);
|
| + if (endLength < startLength)
|
| + end = padWithZeroes(end.release(), startLength);
|
| +
|
| + RELEASE_ASSERT(toInterpolableList(*start).length() == toInterpolableList(*end).length());
|
| +
|
| + return PairwisePrimitiveInterpolation::create(*this, start.release(), end.release(), nullptr);
|
| +}
|
| +
|
| +} // namespace blink
|
|
|