18bf80f4bSopenharmony_ci/*
28bf80f4bSopenharmony_ci * Copyright (c) 2024 Huawei Device Co., Ltd.
38bf80f4bSopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
48bf80f4bSopenharmony_ci * you may not use this file except in compliance with the License.
58bf80f4bSopenharmony_ci * You may obtain a copy of the License at
68bf80f4bSopenharmony_ci *
78bf80f4bSopenharmony_ci *     http://www.apache.org/licenses/LICENSE-2.0
88bf80f4bSopenharmony_ci *
98bf80f4bSopenharmony_ci * Unless required by applicable law or agreed to in writing, software
108bf80f4bSopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
118bf80f4bSopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
128bf80f4bSopenharmony_ci * See the License for the specific language governing permissions and
138bf80f4bSopenharmony_ci * limitations under the License.
148bf80f4bSopenharmony_ci */
158bf80f4bSopenharmony_ci#ifndef META_SRC_CUBIC_BEZIER_EASING_CURVE_H
168bf80f4bSopenharmony_ci#define META_SRC_CUBIC_BEZIER_EASING_CURVE_H
178bf80f4bSopenharmony_ci
188bf80f4bSopenharmony_ci#include <meta/base/namespace.h>
198bf80f4bSopenharmony_ci#include <meta/interface/animation/builtin_animations.h>
208bf80f4bSopenharmony_ci#include <meta/interface/builtin_objects.h>
218bf80f4bSopenharmony_ci#include <meta/interface/curves/intf_bezier.h>
228bf80f4bSopenharmony_ci#include <meta/interface/curves/intf_easing_curve.h>
238bf80f4bSopenharmony_ci
248bf80f4bSopenharmony_ci#include "../meta_object.h"
258bf80f4bSopenharmony_ci
268bf80f4bSopenharmony_ciMETA_BEGIN_NAMESPACE()
278bf80f4bSopenharmony_ci
288bf80f4bSopenharmony_cinamespace Curves {
298bf80f4bSopenharmony_cinamespace Easing {
308bf80f4bSopenharmony_ci
318bf80f4bSopenharmony_ciclass CubicBezierEasingCurve final : public META_NS::Internal::MetaObjectFwd<CubicBezierEasingCurve,
328bf80f4bSopenharmony_ci                                         ClassId::CubicBezierEasingCurve, IEasingCurve, ICubicBezier> {
338bf80f4bSopenharmony_ci    using Super = META_NS::Internal::MetaObjectFwd<CubicBezierEasingCurve, ClassId::CubicBezierEasingCurve,
348bf80f4bSopenharmony_ci        IEasingCurve, ICubicBezier>;
358bf80f4bSopenharmony_ci    META_IMPLEMENT_INTERFACE_PROPERTY(ICubicBezier, BASE_NS::Math::Vec2, ControlPoint1, BASE_NS::Math::Vec2(0, 0))
368bf80f4bSopenharmony_ci    META_IMPLEMENT_INTERFACE_PROPERTY(ICubicBezier, BASE_NS::Math::Vec2, ControlPoint2, BASE_NS::Math::Vec2(1, 1))
378bf80f4bSopenharmony_ci
388bf80f4bSopenharmony_cipublic:
398bf80f4bSopenharmony_ci    bool Build(const IMetadata::Ptr& meta) override;
408bf80f4bSopenharmony_ci    float Transform(float t) const override;
418bf80f4bSopenharmony_ci
428bf80f4bSopenharmony_ciprivate:
438bf80f4bSopenharmony_ci    void UpdateCoefficients();
448bf80f4bSopenharmony_ci    float GetLinearX(float t) const noexcept;
458bf80f4bSopenharmony_ci
468bf80f4bSopenharmony_ci    constexpr float GetX(float t) const noexcept
478bf80f4bSopenharmony_ci    {
488bf80f4bSopenharmony_ci        return ((coeff_[0].x * t + coeff_[1].x) * t + coeff_[2].x) * t;
498bf80f4bSopenharmony_ci    }
508bf80f4bSopenharmony_ci    constexpr float GetY(float t) const noexcept
518bf80f4bSopenharmony_ci    {
528bf80f4bSopenharmony_ci        return ((coeff_[0].y * t + coeff_[1].y) * t + coeff_[2].y) * t;
538bf80f4bSopenharmony_ci    }
548bf80f4bSopenharmony_ci    constexpr float GetDX(float t) const noexcept
558bf80f4bSopenharmony_ci    {
568bf80f4bSopenharmony_ci        return (3.f * coeff_[0].x * t + 2.f * coeff_[1].x) * t + coeff_[2].x;
578bf80f4bSopenharmony_ci    }
588bf80f4bSopenharmony_ci
598bf80f4bSopenharmony_ci    BASE_NS::Math::Vec2 coeff_[3];
608bf80f4bSopenharmony_ci};
618bf80f4bSopenharmony_ci
628bf80f4bSopenharmony_ci} // namespace Easing
638bf80f4bSopenharmony_ci} // namespace Curves
648bf80f4bSopenharmony_ci
658bf80f4bSopenharmony_ciMETA_END_NAMESPACE()
668bf80f4bSopenharmony_ci
678bf80f4bSopenharmony_ci#endif // META_SRC_CUBIC_BEZIER_EASING_CURVE_H
68