summaryrefslogtreecommitdiffstats
path: root/chromium/third_party/WebKit/Source/core/animation/InterpolableValue.cpp
blob: e1b43a9345c5e603959cf9f0b577d27bc68b8e4f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
// Copyright 2014 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/InterpolableValue.h"

namespace WebCore {

DEFINE_EMPTY_DESTRUCTOR_WILL_BE_REMOVED(InterpolableValue);

PassOwnPtrWillBeRawPtr<InterpolableValue> InterpolableNumber::interpolate(const InterpolableValue &to, const double progress) const
{
    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);
}

PassOwnPtrWillBeRawPtr<InterpolableValue> InterpolableBool::interpolate(const InterpolableValue &to, const double progress) const
{
    if (progress < 0.5) {
        return clone();
    }
    return to.clone();
}

PassOwnPtrWillBeRawPtr<InterpolableValue> InterpolableList::interpolate(const InterpolableValue &to, const double progress) const
{
    const InterpolableList* toList = toInterpolableList(&to);
    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();
}

void InterpolableList::trace(Visitor* visitor)
{
#if ENABLE_OILPAN
    visitor->trace(m_values);
#endif
    InterpolableValue::trace(visitor);
}

PassOwnPtrWillBeRawPtr<InterpolableValue> InterpolableAnimatableValue::interpolate(const InterpolableValue &other, const double percentage) const
{
    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));
}

void InterpolableAnimatableValue::trace(Visitor* visitor)
{
    visitor->trace(m_value);
    InterpolableValue::trace(visitor);
}

}