blob: 5bad355eaeef240088660312c8289494046811a8 [file] [log] [blame]
/*
* Copyright (C) 2000 Lars Knoll (knoll@kde.org)
* (C) 2000 Antti Koivisto (koivisto@kde.org)
* (C) 2000 Dirk Mueller (mueller@kde.org)
* Copyright (C) 2003, 2005, 2006, 2007, 2008 Apple Inc. All rights reserved.
* Copyright (C) 2006 Graham Dennis (graham.dennis@gmail.com)
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Library General Public License for more details.
*
* You should have received a copy of the GNU Library General Public License
* along with this library; see the file COPYING.LIB. If not, write to
* the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
* Boston, MA 02110-1301, USA.
*
*/
#ifndef TimingFunction_h
#define TimingFunction_h
#include "cc/animation/timing_function.h"
#include "platform/PlatformExport.h"
#include "wtf/Assertions.h"
#include "wtf/PassRefPtr.h"
#include "wtf/RefCounted.h"
#include "wtf/StdLibExtras.h"
#include "wtf/text/WTFString.h"
namespace blink {
class PLATFORM_EXPORT TimingFunction : public RefCounted<TimingFunction> {
public:
using Type = cc::TimingFunction::Type;
virtual ~TimingFunction() {}
Type getType() const { return m_type; }
virtual String toString() const = 0;
// Evaluates the timing function at the given fraction. The accuracy parameter
// provides a hint as to the required accuracy and is not guaranteed.
virtual double evaluate(double fraction, double accuracy) const = 0;
// This function returns the minimum and maximum values obtainable when
// calling evaluate();
virtual void range(double* minValue, double* maxValue) const = 0;
// Create CC instance.
virtual std::unique_ptr<cc::TimingFunction> cloneToCC() const = 0;
protected:
TimingFunction(Type type) : m_type(type) {}
private:
Type m_type;
};
class PLATFORM_EXPORT LinearTimingFunction final : public TimingFunction {
public:
static LinearTimingFunction* shared() {
DEFINE_STATIC_REF(LinearTimingFunction, linear,
(adoptRef(new LinearTimingFunction())));
return linear;
}
~LinearTimingFunction() override {}
// TimingFunction implementation.
String toString() const override;
double evaluate(double fraction, double) const override;
void range(double* minValue, double* maxValue) const override;
std::unique_ptr<cc::TimingFunction> cloneToCC() const override;
private:
LinearTimingFunction() : TimingFunction(Type::LINEAR) {}
};
class PLATFORM_EXPORT CubicBezierTimingFunction final : public TimingFunction {
public:
using EaseType = cc::CubicBezierTimingFunction::EaseType;
static PassRefPtr<CubicBezierTimingFunction> create(double x1,
double y1,
double x2,
double y2) {
return adoptRef(new CubicBezierTimingFunction(x1, y1, x2, y2));
}
static CubicBezierTimingFunction* preset(EaseType easeType) {
DEFINE_STATIC_REF(
CubicBezierTimingFunction, ease,
(adoptRef(new CubicBezierTimingFunction(EaseType::EASE))));
DEFINE_STATIC_REF(
CubicBezierTimingFunction, easeIn,
(adoptRef(new CubicBezierTimingFunction(EaseType::EASE_IN))));
DEFINE_STATIC_REF(
CubicBezierTimingFunction, easeOut,
(adoptRef(new CubicBezierTimingFunction(EaseType::EASE_OUT))));
DEFINE_STATIC_REF(
CubicBezierTimingFunction, easeInOut,
(adoptRef(new CubicBezierTimingFunction(EaseType::EASE_IN_OUT))));
switch (easeType) {
case EaseType::EASE:
return ease;
case EaseType::EASE_IN:
return easeIn;
case EaseType::EASE_OUT:
return easeOut;
case EaseType::EASE_IN_OUT:
return easeInOut;
default:
NOTREACHED();
return nullptr;
}
}
~CubicBezierTimingFunction() override {}
// TimingFunction implementation.
String toString() const override;
double evaluate(double fraction, double accuracy) const override;
void range(double* minValue, double* maxValue) const override;
std::unique_ptr<cc::TimingFunction> cloneToCC() const override;
double x1() const {
DCHECK_EQ(getEaseType(), EaseType::CUSTOM);
return m_x1;
}
double y1() const {
DCHECK_EQ(getEaseType(), EaseType::CUSTOM);
return m_y1;
}
double x2() const {
DCHECK_EQ(getEaseType(), EaseType::CUSTOM);
return m_x2;
}
double y2() const {
DCHECK_EQ(getEaseType(), EaseType::CUSTOM);
return m_y2;
}
EaseType getEaseType() const { return m_bezier->ease_type(); }
private:
explicit CubicBezierTimingFunction(EaseType easeType)
: TimingFunction(Type::CUBIC_BEZIER),
m_bezier(cc::CubicBezierTimingFunction::CreatePreset(easeType)),
m_x1(),
m_y1(),
m_x2(),
m_y2() {}
CubicBezierTimingFunction(double x1, double y1, double x2, double y2)
: TimingFunction(Type::CUBIC_BEZIER),
m_bezier(cc::CubicBezierTimingFunction::Create(x1, y1, x2, y2)),
m_x1(x1),
m_y1(y1),
m_x2(x2),
m_y2(y2) {}
std::unique_ptr<cc::CubicBezierTimingFunction> m_bezier;
// TODO(loyso): Get these values from m_bezier->bezier_ (gfx::CubicBezier)
const double m_x1;
const double m_y1;
const double m_x2;
const double m_y2;
};
class PLATFORM_EXPORT StepsTimingFunction final : public TimingFunction {
public:
using StepPosition = cc::StepsTimingFunction::StepPosition;
static PassRefPtr<StepsTimingFunction> create(int steps,
StepPosition stepPosition) {
return adoptRef(new StepsTimingFunction(steps, stepPosition));
}
static StepsTimingFunction* preset(StepPosition position) {
DEFINE_STATIC_REF(StepsTimingFunction, start,
create(1, StepPosition::START));
DEFINE_STATIC_REF(StepsTimingFunction, middle,
create(1, StepPosition::MIDDLE));
DEFINE_STATIC_REF(StepsTimingFunction, end, create(1, StepPosition::END));
switch (position) {
case StepPosition::START:
return start;
case StepPosition::MIDDLE:
return middle;
case StepPosition::END:
return end;
default:
NOTREACHED();
return end;
}
}
~StepsTimingFunction() override {}
// TimingFunction implementation.
String toString() const override;
double evaluate(double fraction, double) const override;
void range(double* minValue, double* maxValue) const override;
std::unique_ptr<cc::TimingFunction> cloneToCC() const override;
int numberOfSteps() const { return m_steps->steps(); }
StepPosition getStepPosition() const { return m_steps->step_position(); }
private:
StepsTimingFunction(int steps, StepPosition stepPosition)
: TimingFunction(Type::STEPS),
m_steps(cc::StepsTimingFunction::Create(steps, stepPosition)) {}
std::unique_ptr<cc::StepsTimingFunction> m_steps;
};
PLATFORM_EXPORT PassRefPtr<TimingFunction> createCompositorTimingFunctionFromCC(
const cc::TimingFunction*);
PLATFORM_EXPORT bool operator==(const LinearTimingFunction&,
const TimingFunction&);
PLATFORM_EXPORT bool operator==(const CubicBezierTimingFunction&,
const TimingFunction&);
PLATFORM_EXPORT bool operator==(const StepsTimingFunction&,
const TimingFunction&);
PLATFORM_EXPORT bool operator==(const TimingFunction&, const TimingFunction&);
PLATFORM_EXPORT bool operator!=(const TimingFunction&, const TimingFunction&);
#define DEFINE_TIMING_FUNCTION_TYPE_CASTS(typeName, enumName) \
DEFINE_TYPE_CASTS(typeName##TimingFunction, TimingFunction, value, \
value->getType() == TimingFunction::Type::enumName, \
value.getType() == TimingFunction::Type::enumName)
DEFINE_TIMING_FUNCTION_TYPE_CASTS(Linear, LINEAR);
DEFINE_TIMING_FUNCTION_TYPE_CASTS(CubicBezier, CUBIC_BEZIER);
DEFINE_TIMING_FUNCTION_TYPE_CASTS(Steps, STEPS);
} // namespace blink
#endif // TimingFunction_h