123b3eb3cSopenharmony_ci/*
223b3eb3cSopenharmony_ci * Copyright (c) 2021-2022 Huawei Device Co., Ltd.
323b3eb3cSopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
423b3eb3cSopenharmony_ci * you may not use this file except in compliance with the License.
523b3eb3cSopenharmony_ci * You may obtain a copy of the License at
623b3eb3cSopenharmony_ci *
723b3eb3cSopenharmony_ci *     http://www.apache.org/licenses/LICENSE-2.0
823b3eb3cSopenharmony_ci *
923b3eb3cSopenharmony_ci * Unless required by applicable law or agreed to in writing, software
1023b3eb3cSopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
1123b3eb3cSopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
1223b3eb3cSopenharmony_ci * See the License for the specific language governing permissions and
1323b3eb3cSopenharmony_ci * limitations under the License.
1423b3eb3cSopenharmony_ci */
1523b3eb3cSopenharmony_ci
1623b3eb3cSopenharmony_ci#ifndef FOUNDATION_ACE_FRAMEWORKS_BASE_GEOMETRY_DIMENSION_OFFSET_H
1723b3eb3cSopenharmony_ci#define FOUNDATION_ACE_FRAMEWORKS_BASE_GEOMETRY_DIMENSION_OFFSET_H
1823b3eb3cSopenharmony_ci
1923b3eb3cSopenharmony_ci#include <cmath>
2023b3eb3cSopenharmony_ci#include <limits>
2123b3eb3cSopenharmony_ci#include <optional>
2223b3eb3cSopenharmony_ci
2323b3eb3cSopenharmony_ci#include "base/geometry/dimension.h"
2423b3eb3cSopenharmony_ci#include "base/geometry/ng/offset_t.h"
2523b3eb3cSopenharmony_ci#include "base/geometry/offset.h"
2623b3eb3cSopenharmony_ci
2723b3eb3cSopenharmony_cinamespace OHOS::Ace {
2823b3eb3cSopenharmony_ci
2923b3eb3cSopenharmony_ciclass DimensionOffset {
3023b3eb3cSopenharmony_cipublic:
3123b3eb3cSopenharmony_ci    DimensionOffset() = default;
3223b3eb3cSopenharmony_ci    ~DimensionOffset() = default;
3323b3eb3cSopenharmony_ci    DimensionOffset(const Dimension& deltaX, const Dimension& deltaY) : deltaX_(deltaX), deltaY_(deltaY) {}
3423b3eb3cSopenharmony_ci    DimensionOffset(const Offset& offset) : deltaX_(Dimension(offset.GetX(), DimensionUnit::PX)),
3523b3eb3cSopenharmony_ci        deltaY_(Dimension(offset.GetY(), DimensionUnit::PX)) {}
3623b3eb3cSopenharmony_ci
3723b3eb3cSopenharmony_ci    explicit DimensionOffset(const NG::OffsetF& offset)
3823b3eb3cSopenharmony_ci        : deltaX_(Dimension(offset.GetX())), deltaY_(Dimension(offset.GetY()))
3923b3eb3cSopenharmony_ci    {}
4023b3eb3cSopenharmony_ci
4123b3eb3cSopenharmony_ci    const Dimension& GetX() const
4223b3eb3cSopenharmony_ci    {
4323b3eb3cSopenharmony_ci        return deltaX_;
4423b3eb3cSopenharmony_ci    }
4523b3eb3cSopenharmony_ci
4623b3eb3cSopenharmony_ci    const Dimension& GetY() const
4723b3eb3cSopenharmony_ci    {
4823b3eb3cSopenharmony_ci        return deltaY_;
4923b3eb3cSopenharmony_ci    }
5023b3eb3cSopenharmony_ci
5123b3eb3cSopenharmony_ci    const std::optional<Dimension>& GetZ() const
5223b3eb3cSopenharmony_ci    {
5323b3eb3cSopenharmony_ci        return deltaZ_;
5423b3eb3cSopenharmony_ci    }
5523b3eb3cSopenharmony_ci
5623b3eb3cSopenharmony_ci    void SetX(Dimension& x)
5723b3eb3cSopenharmony_ci    {
5823b3eb3cSopenharmony_ci        deltaX_ = x;
5923b3eb3cSopenharmony_ci    }
6023b3eb3cSopenharmony_ci
6123b3eb3cSopenharmony_ci    void SetY(Dimension& y)
6223b3eb3cSopenharmony_ci    {
6323b3eb3cSopenharmony_ci        deltaY_ = y;
6423b3eb3cSopenharmony_ci    }
6523b3eb3cSopenharmony_ci
6623b3eb3cSopenharmony_ci    void SetZ(const Dimension& z)
6723b3eb3cSopenharmony_ci    {
6823b3eb3cSopenharmony_ci        deltaZ_ = z;
6923b3eb3cSopenharmony_ci    }
7023b3eb3cSopenharmony_ci
7123b3eb3cSopenharmony_ci    DimensionOffset operator+(const DimensionOffset& dimensionOffset) const
7223b3eb3cSopenharmony_ci    {
7323b3eb3cSopenharmony_ci        return DimensionOffset(deltaX_ + dimensionOffset.deltaX_, deltaY_ + dimensionOffset.deltaY_);
7423b3eb3cSopenharmony_ci    }
7523b3eb3cSopenharmony_ci
7623b3eb3cSopenharmony_ci    DimensionOffset operator-(const DimensionOffset& dimensionOffset) const
7723b3eb3cSopenharmony_ci    {
7823b3eb3cSopenharmony_ci        return DimensionOffset(deltaX_ - dimensionOffset.deltaX_, deltaY_ - dimensionOffset.deltaY_);
7923b3eb3cSopenharmony_ci    }
8023b3eb3cSopenharmony_ci
8123b3eb3cSopenharmony_ci    DimensionOffset operator*(double value) const
8223b3eb3cSopenharmony_ci    {
8323b3eb3cSopenharmony_ci        return DimensionOffset(deltaX_ * value, deltaY_ * value);
8423b3eb3cSopenharmony_ci    }
8523b3eb3cSopenharmony_ci
8623b3eb3cSopenharmony_ci    bool operator==(const DimensionOffset& dimensionOffset) const
8723b3eb3cSopenharmony_ci    {
8823b3eb3cSopenharmony_ci        return deltaX_ == dimensionOffset.deltaX_ && deltaY_ == dimensionOffset.deltaY_ && deltaZ_ == deltaZ_;
8923b3eb3cSopenharmony_ci    }
9023b3eb3cSopenharmony_ci
9123b3eb3cSopenharmony_ciprivate:
9223b3eb3cSopenharmony_ci    Dimension deltaX_;
9323b3eb3cSopenharmony_ci    Dimension deltaY_;
9423b3eb3cSopenharmony_ci    std::optional<Dimension> deltaZ_;
9523b3eb3cSopenharmony_ci};
9623b3eb3cSopenharmony_ci
9723b3eb3cSopenharmony_ci} // namespace OHOS::Ace
9823b3eb3cSopenharmony_ci
9923b3eb3cSopenharmony_ci#endif // FOUNDATION_ACE_FRAMEWORKS_BASE_GEOMETRY_DIMENSION_OFFSET_H
100