mirror of
https://github.com/flutter/flutter.git
synced 2026-02-20 02:29:02 +08:00
I wrote a script to do this which is attached to the bug. TBR=abarth@chromium.org BUG=435361 Review URL: https://codereview.chromium.org/736373003
158 lines
5.1 KiB
C++
158 lines
5.1 KiB
C++
// 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.
|
|
|
|
#ifndef SKY_ENGINE_CORE_ANIMATION_INTERPOLABLEVALUE_H_
|
|
#define SKY_ENGINE_CORE_ANIMATION_INTERPOLABLEVALUE_H_
|
|
|
|
#include "sky/engine/core/animation/animatable/AnimatableValue.h"
|
|
#include "sky/engine/wtf/OwnPtr.h"
|
|
#include "sky/engine/wtf/PassOwnPtr.h"
|
|
#include "sky/engine/wtf/Vector.h"
|
|
|
|
namespace blink {
|
|
|
|
class InterpolableValue {
|
|
DECLARE_EMPTY_VIRTUAL_DESTRUCTOR_WILL_BE_REMOVED(InterpolableValue);
|
|
public:
|
|
virtual bool isNumber() const { return false; }
|
|
virtual bool isBool() const { return false; }
|
|
virtual bool isList() const { return false; }
|
|
virtual bool isAnimatableValue() const { return false; }
|
|
|
|
virtual PassOwnPtr<InterpolableValue> clone() const = 0;
|
|
|
|
private:
|
|
virtual PassOwnPtr<InterpolableValue> interpolate(const InterpolableValue &to, const double progress) const = 0;
|
|
|
|
friend class Interpolation;
|
|
|
|
// Keep interpolate private, but allow calls within the hierarchy without
|
|
// knowledge of type.
|
|
friend class DeferredLegacyStyleInterpolation;
|
|
friend class InterpolableNumber;
|
|
friend class InterpolableBool;
|
|
friend class InterpolableList;
|
|
};
|
|
|
|
class InterpolableNumber : public InterpolableValue {
|
|
public:
|
|
static PassOwnPtr<InterpolableNumber> create(double value)
|
|
{
|
|
return adoptPtr(new InterpolableNumber(value));
|
|
}
|
|
|
|
virtual bool isNumber() const override final { return true; }
|
|
double value() const { return m_value; }
|
|
virtual PassOwnPtr<InterpolableValue> clone() const override final { return create(m_value); }
|
|
|
|
private:
|
|
virtual PassOwnPtr<InterpolableValue> interpolate(const InterpolableValue &to, const double progress) const override final;
|
|
double m_value;
|
|
|
|
explicit InterpolableNumber(double value)
|
|
: m_value(value)
|
|
{
|
|
}
|
|
|
|
};
|
|
|
|
class InterpolableBool : public InterpolableValue {
|
|
public:
|
|
static PassOwnPtr<InterpolableBool> create(bool value)
|
|
{
|
|
return adoptPtr(new InterpolableBool(value));
|
|
}
|
|
|
|
virtual bool isBool() const override final { return true; }
|
|
bool value() const { return m_value; }
|
|
virtual PassOwnPtr<InterpolableValue> clone() const override final { return create(m_value); }
|
|
|
|
private:
|
|
virtual PassOwnPtr<InterpolableValue> interpolate(const InterpolableValue &to, const double progress) const override final;
|
|
bool m_value;
|
|
|
|
explicit InterpolableBool(bool value)
|
|
: m_value(value)
|
|
{
|
|
}
|
|
|
|
};
|
|
|
|
class InterpolableList : public InterpolableValue {
|
|
public:
|
|
static PassOwnPtr<InterpolableList> create(const InterpolableList &other)
|
|
{
|
|
return adoptPtr(new InterpolableList(other));
|
|
}
|
|
|
|
static PassOwnPtr<InterpolableList> create(size_t size)
|
|
{
|
|
return adoptPtr(new InterpolableList(size));
|
|
}
|
|
|
|
virtual bool isList() const override final { return true; }
|
|
void set(size_t position, PassOwnPtr<InterpolableValue> value)
|
|
{
|
|
ASSERT(position < m_size);
|
|
m_values[position] = value;
|
|
}
|
|
const InterpolableValue* get(size_t position) const
|
|
{
|
|
ASSERT(position < m_size);
|
|
return m_values[position].get();
|
|
}
|
|
size_t length() const { return m_size; }
|
|
virtual PassOwnPtr<InterpolableValue> clone() const override final { return create(*this); }
|
|
|
|
private:
|
|
virtual PassOwnPtr<InterpolableValue> interpolate(const InterpolableValue &other, const double progress) const override final;
|
|
explicit InterpolableList(size_t size)
|
|
: m_size(size)
|
|
, m_values(m_size)
|
|
{
|
|
}
|
|
|
|
InterpolableList(const InterpolableList& other)
|
|
: m_size(other.m_size)
|
|
, m_values(m_size)
|
|
{
|
|
for (size_t i = 0; i < m_size; i++)
|
|
set(i, other.m_values[i]->clone());
|
|
}
|
|
|
|
size_t m_size;
|
|
Vector<OwnPtr<InterpolableValue> > m_values;
|
|
};
|
|
|
|
// FIXME: Remove this when we can.
|
|
class InterpolableAnimatableValue : public InterpolableValue {
|
|
public:
|
|
static PassOwnPtr<InterpolableAnimatableValue> create(PassRefPtr<AnimatableValue> value)
|
|
{
|
|
return adoptPtr(new InterpolableAnimatableValue(value));
|
|
}
|
|
|
|
virtual bool isAnimatableValue() const override final { return true; }
|
|
AnimatableValue* value() const { return m_value.get(); }
|
|
virtual PassOwnPtr<InterpolableValue> clone() const override final { return create(m_value); }
|
|
|
|
private:
|
|
virtual PassOwnPtr<InterpolableValue> interpolate(const InterpolableValue &other, const double progress) const override final;
|
|
RefPtr<AnimatableValue> m_value;
|
|
|
|
InterpolableAnimatableValue(PassRefPtr<AnimatableValue> value)
|
|
: m_value(value)
|
|
{
|
|
}
|
|
};
|
|
|
|
DEFINE_TYPE_CASTS(InterpolableNumber, InterpolableValue, value, value->isNumber(), value.isNumber());
|
|
DEFINE_TYPE_CASTS(InterpolableBool, InterpolableValue, value, value->isBool(), value.isBool());
|
|
DEFINE_TYPE_CASTS(InterpolableList, InterpolableValue, value, value->isList(), value.isList());
|
|
DEFINE_TYPE_CASTS(InterpolableAnimatableValue, InterpolableValue, value, value->isAnimatableValue(), value.isAnimatableValue());
|
|
|
|
}
|
|
|
|
#endif // SKY_ENGINE_CORE_ANIMATION_INTERPOLABLEVALUE_H_
|