1 /*
2  * Copyright (c) 2024 Huawei Device Co., Ltd.
3  * Licensed under the Apache License, Version 2.0 (the "License");
4  * you may not use this file except in compliance with the License.
5  * You may obtain a copy of the License at
6  *
7  *     http://www.apache.org/licenses/LICENSE-2.0
8  *
9  * Unless required by applicable law or agreed to in writing, software
10  * distributed under the License is distributed on an "AS IS" BASIS,
11  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12  * See the License for the specific language governing permissions and
13  * limitations under the License.
14  */
15 
16 #include "bridge/cj_frontend/interfaces/cj_ffi/cj_rect_ffi.h"
17 
18 #include <cinttypes>
19 
20 #include "bridge/cj_frontend/cppview/shape_abstract.h"
21 #include "bridge/cj_frontend/interfaces/cj_ffi/cj_shape_ffi.h"
22 #include "bridge/declarative_frontend/view_stack_processor.h"
23 #include "core/components_ng/pattern/shape/rect_model.h"
24 #include "core/components_ng/pattern/shape/rect_model_ng.h"
25 
26 using namespace OHOS::Ace;
27 
28 extern "C" {
FfiOHOSAceFrameworkRectCreate(double width,int32_t widthUnit,double height,int32_t heightUnit)29 void FfiOHOSAceFrameworkRectCreate(double width, int32_t widthUnit, double height, int32_t heightUnit)
30 {
31     RectModel::GetInstance()->Create();
32     if (width > 0.0) {
33         FfiOHOSAceFrameworkShapeSetWidth(width, widthUnit);
34     }
35     if (height > 0.0) {
36         FfiOHOSAceFrameworkShapeSetHeight(height, heightUnit);
37     }
38 }
39 
FfiOHOSAceFrameworkRectInsCreate(double width,int32_t widthUnit,double height,int32_t heightUnit)40 int64_t FfiOHOSAceFrameworkRectInsCreate(double width, int32_t widthUnit, double height, int32_t heightUnit)
41 {
42     OHOS::Ace::Dimension dWidth(width, static_cast<OHOS::Ace::DimensionUnit>(widthUnit));
43     OHOS::Ace::Dimension dHeight(height, static_cast<OHOS::Ace::DimensionUnit>(heightUnit));
44     auto ret_ = OHOS::FFI::FFIData::Create<OHOS::Ace::Framework::NativeRect>(dWidth, dHeight);
45     if (ret_ == nullptr) {
46         return FFI_ERROR_CODE;
47     }
48     return ret_->GetID();
49 }
50 
FfiOHOSAceFrameworkRectSetRadiusWidth(double radiusWidth,int32_t radiusWidthUnit)51 void FfiOHOSAceFrameworkRectSetRadiusWidth(double radiusWidth, int32_t radiusWidthUnit)
52 {
53     Dimension value(radiusWidth, static_cast<DimensionUnit>(radiusWidthUnit));
54     RectModel::GetInstance()->SetRadiusWidth(value);
55 }
56 
FfiOHOSAceFrameworkRectSetRadiusHeight(double radiusHeight,int32_t radiusHeightUnit)57 void FfiOHOSAceFrameworkRectSetRadiusHeight(double radiusHeight, int32_t radiusHeightUnit)
58 {
59     Dimension value(radiusHeight, static_cast<DimensionUnit>(radiusHeightUnit));
60     RectModel::GetInstance()->SetRadiusHeight(value);
61 }
62 
FfiOHOSAceFrameworkRectSetRadius(double radius,int32_t radiusUnit)63 void FfiOHOSAceFrameworkRectSetRadius(double radius, int32_t radiusUnit)
64 {
65     Dimension value(radius, static_cast<DimensionUnit>(radiusUnit));
66     RectModel::GetInstance()->SetRadiusWidth(value);
67     RectModel::GetInstance()->SetRadiusHeight(value);
68 }
69 
FfiOHOSAceFrameworkRectSetRadiusArray(VectorDoubleHandle voidValue,VectorInt32Handle voidUnit)70 void FfiOHOSAceFrameworkRectSetRadiusArray(VectorDoubleHandle voidValue, VectorInt32Handle voidUnit)
71 {
72     std::vector<double>* vecValue = (std::vector<double>*)voidValue;
73     std::vector<int32_t>* vecUnit = (std::vector<int32_t>*)voidUnit;
74 
75     if (vecValue == nullptr) {
76         LOGE("rect radius array is empty");
77         return;
78     }
79     unsigned int length = vecValue->size() > 4 ? 4 : vecValue->size();
80     for (unsigned int i = 0; i < length; ++i) {
81         DimensionUnit unit = DimensionUnit::VP;
82         if (vecUnit != nullptr && i < vecUnit->size()) {
83             unit = static_cast<DimensionUnit>(vecUnit->at(i));
84         }
85 
86         Dimension value(vecValue->at(i), static_cast<DimensionUnit>(unit));
87         RectModel::GetInstance()->SetRadiusValue(value, value, i);
88     }
89 }
90 
FfiOHOSAceFrameworkRectSetRadiusTupleArray(VectorDoubleHandle voidWidthValue,VectorInt32Handle voidWidthUnit,VectorDoubleHandle voidHeightValue,VectorInt32Handle voidHeightUnit)91 void FfiOHOSAceFrameworkRectSetRadiusTupleArray(VectorDoubleHandle voidWidthValue, VectorInt32Handle voidWidthUnit,
92     VectorDoubleHandle voidHeightValue, VectorInt32Handle voidHeightUnit)
93 {
94     std::vector<double>* vecWidthValue = (std::vector<double>*)voidWidthValue;
95     std::vector<int32_t>* vecWidthUnit = (std::vector<int32_t>*)voidWidthUnit;
96     std::vector<double>* vecHeightValue = (std::vector<double>*)voidHeightValue;
97     std::vector<int32_t>* vecHeightUnit = (std::vector<int32_t>*)voidHeightUnit;
98 
99     if (vecWidthValue == nullptr) {
100         LOGE("rect radius array is empty");
101         return;
102     }
103     unsigned int length = vecWidthValue->size() > 4 ? 4 : vecWidthValue->size();
104     for (unsigned int i = 0; i < length; ++i) {
105         DimensionUnit widthUnit = DimensionUnit::VP;
106         DimensionUnit heightUnit = DimensionUnit::VP;
107 
108         if (vecWidthUnit != nullptr && i < vecWidthUnit->size()) {
109             widthUnit = static_cast<DimensionUnit>(vecWidthUnit->at(i));
110         }
111 
112         if (vecHeightUnit != nullptr && i < vecHeightUnit->size()) {
113             heightUnit = static_cast<DimensionUnit>(vecHeightUnit->at(i));
114         }
115 
116         Dimension width(vecWidthValue->at(i), widthUnit);
117         Dimension height(vecHeightValue->at(i), heightUnit);
118 
119         RectModel::GetInstance()->SetRadiusValue(width, height, i);
120     }
121 }
122 
FfiOHOSAceFrameworkRectSetInsRadiusWidth(int64_t shapeId,double radiusWidth,int32_t radiusWidthUnit)123 void FfiOHOSAceFrameworkRectSetInsRadiusWidth(int64_t shapeId, double radiusWidth, int32_t radiusWidthUnit)
124 {
125     auto context = OHOS::FFI::FFIData::GetData<OHOS::Ace::Framework::NativeRect>(shapeId);
126     if (context != nullptr) {
127         Dimension dValue(radiusWidth, static_cast<DimensionUnit>(radiusWidthUnit));
128         context->SetRadiusWidth(dValue);
129     } else {
130         LOGI("set shape radiusWidth error, Cannot get NativeShape by id: %{public}" PRId64, shapeId);
131     }
132 }
133 
FfiOHOSAceFrameworkRectSetInsRadiusHeight(int64_t shapeId,double radiusHeight,int32_t radiusHeightUnit)134 void FfiOHOSAceFrameworkRectSetInsRadiusHeight(int64_t shapeId, double radiusHeight, int32_t radiusHeightUnit)
135 {
136     auto context = OHOS::FFI::FFIData::GetData<OHOS::Ace::Framework::NativeRect>(shapeId);
137     if (context != nullptr) {
138         Dimension dValue(radiusHeight, static_cast<DimensionUnit>(radiusHeightUnit));
139         context->SetRadiusHeight(dValue);
140     } else {
141         LOGI("set shape radiusHeight error, Cannot get NativeShape by id: %{public}" PRId64, shapeId);
142     }
143 }
144 
FfiOHOSAceFrameworkRectSetInsRadius(int64_t shapeId,double radius,int32_t radiusUnit)145 void FfiOHOSAceFrameworkRectSetInsRadius(int64_t shapeId, double radius, int32_t radiusUnit)
146 {
147     auto context = OHOS::FFI::FFIData::GetData<OHOS::Ace::Framework::NativeRect>(shapeId);
148     if (context != nullptr) {
149         Dimension dValue(radius, static_cast<DimensionUnit>(radiusUnit));
150         context->SetRadius(dValue);
151     } else {
152         LOGI("set shape radius error, Cannot get NativeShape by id: %{public}" PRId64, shapeId);
153     }
154 }
155 }
156