C++程序  |  136行  |  3.45 KB

/*
 * Copyright (C) 2014 The Android Open Source Project
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
#ifndef INTERPOLATOR_H
#define INTERPOLATOR_H

#include <stddef.h>
#include <memory>

#include <cutils/compiler.h>
#include <vector>

namespace android {
namespace uirenderer {

class Interpolator {
public:
    virtual ~Interpolator() {}

    virtual float interpolate(float input) = 0;

    static Interpolator* createDefaultInterpolator();

protected:
    Interpolator() {}
};

class ANDROID_API AccelerateDecelerateInterpolator : public Interpolator {
public:
    virtual float interpolate(float input) override;
};

class ANDROID_API AccelerateInterpolator : public Interpolator {
public:
    explicit AccelerateInterpolator(float factor) : mFactor(factor), mDoubleFactor(factor * 2) {}
    virtual float interpolate(float input) override;

private:
    const float mFactor;
    const float mDoubleFactor;
};

class ANDROID_API AnticipateInterpolator : public Interpolator {
public:
    explicit AnticipateInterpolator(float tension) : mTension(tension) {}
    virtual float interpolate(float input) override;

private:
    const float mTension;
};

class ANDROID_API AnticipateOvershootInterpolator : public Interpolator {
public:
    explicit AnticipateOvershootInterpolator(float tension) : mTension(tension) {}
    virtual float interpolate(float input) override;

private:
    const float mTension;
};

class ANDROID_API BounceInterpolator : public Interpolator {
public:
    virtual float interpolate(float input) override;
};

class ANDROID_API CycleInterpolator : public Interpolator {
public:
    explicit CycleInterpolator(float cycles) : mCycles(cycles) {}
    virtual float interpolate(float input) override;

private:
    const float mCycles;
};

class ANDROID_API DecelerateInterpolator : public Interpolator {
public:
    explicit DecelerateInterpolator(float factor) : mFactor(factor) {}
    virtual float interpolate(float input) override;

private:
    const float mFactor;
};

class ANDROID_API LinearInterpolator : public Interpolator {
public:
    virtual float interpolate(float input) override { return input; }
};

class ANDROID_API OvershootInterpolator : public Interpolator {
public:
    explicit OvershootInterpolator(float tension) : mTension(tension) {}
    virtual float interpolate(float input) override;

private:
    const float mTension;
};

class ANDROID_API PathInterpolator : public Interpolator {
public:
    explicit PathInterpolator(std::vector<float>&& x, std::vector<float>&& y) : mX(x), mY(y) {}
    virtual float interpolate(float input) override;

private:
    std::vector<float> mX;
    std::vector<float> mY;
};

class ANDROID_API LUTInterpolator : public Interpolator {
public:
    LUTInterpolator(float* values, size_t size);
    ~LUTInterpolator();

    virtual float interpolate(float input) override;

private:
    std::unique_ptr<float[]> mValues;
    size_t mSize;
};

} /* namespace uirenderer */
} /* namespace android */

#endif /* INTERPOLATOR_H */