1 /*
2 * Copyright (c) 2025 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 "effect/rs_render_effect_template.h"
17
18 #include "effect/rs_render_mask_base.h"
19 #include "ge_visual_effect.h"
20 #include "ge_visual_effect_container.h"
21 #include "render/rs_path.h"
22 #include "render/rs_pixel_map_util.h"
23
24 namespace OHOS {
25 namespace Rosen {
UpdateVisualEffectParamImpl(Drawing::GEVisualEffect & geFilter,const std::string & desc,float value)26 void RSNGRenderEffectHelper::UpdateVisualEffectParamImpl(Drawing::GEVisualEffect& geFilter,
27 const std::string& desc, float value)
28 {
29 geFilter.SetParam(desc, value);
30 }
31
UpdateVisualEffectParamImpl(Drawing::GEVisualEffect & geFilter,const std::string & desc,bool value)32 void RSNGRenderEffectHelper::UpdateVisualEffectParamImpl(Drawing::GEVisualEffect& geFilter,
33 const std::string& desc, bool value)
34 {
35 geFilter.SetParam(desc, value);
36 }
37
UpdateVisualEffectParamImpl(Drawing::GEVisualEffect & geFilter,const std::string & desc,const Vector4f & value)38 void RSNGRenderEffectHelper::UpdateVisualEffectParamImpl(Drawing::GEVisualEffect& geFilter,
39 const std::string& desc, const Vector4f& value)
40 {
41 geFilter.SetParam(desc, value);
42 }
43
UpdateVisualEffectParamImpl(Drawing::GEVisualEffect & geFilter,const std::string & desc,const Vector3f & value)44 void RSNGRenderEffectHelper::UpdateVisualEffectParamImpl(Drawing::GEVisualEffect& geFilter,
45 const std::string& desc, const Vector3f& value)
46 {
47 geFilter.SetParam(desc, value);
48 }
49
UpdateVisualEffectParamImpl(Drawing::GEVisualEffect & geFilter,const std::string & desc,const Vector2f & value)50 void RSNGRenderEffectHelper::UpdateVisualEffectParamImpl(Drawing::GEVisualEffect& geFilter,
51 const std::string& desc, const Vector2f& value)
52 {
53 geFilter.SetParam(desc, std::make_pair(value.x_, value.y_));
54 }
55
UpdateVisualEffectParamImpl(Drawing::GEVisualEffect & geFilter,const std::string & desc,std::shared_ptr<RSNGRenderMaskBase> value)56 void RSNGRenderEffectHelper::UpdateVisualEffectParamImpl(Drawing::GEVisualEffect& geFilter,
57 const std::string& desc, std::shared_ptr<RSNGRenderMaskBase> value)
58 {
59 std::shared_ptr<Drawing::GEVisualEffect> geVisualEffect = value ? value->GenerateGEVisualEffect() : nullptr;
60 std::shared_ptr<Drawing::GEShaderMask> geMask = geVisualEffect ? geVisualEffect->GenerateShaderMask() : nullptr;
61 geFilter.SetParam(desc, geMask);
62 }
63
UpdateVisualEffectParamImpl(Drawing::GEVisualEffect & geFilter,const std::string & desc,const VectorVector2F & value)64 void RSNGRenderEffectHelper::UpdateVisualEffectParamImpl(Drawing::GEVisualEffect& geFilter,
65 const std::string& desc, const VectorVector2F& value)
66 {
67 geFilter.SetParam(desc, value);
68 }
69
UpdateVisualEffectParamImpl(Drawing::GEVisualEffect & geFilter,const std::string & desc,std::shared_ptr<Media::PixelMap> value)70 void RSNGRenderEffectHelper::UpdateVisualEffectParamImpl(Drawing::GEVisualEffect& geFilter,
71 const std::string& desc, std::shared_ptr<Media::PixelMap> value)
72 {
73 auto image = RSPixelMapUtil::ExtractDrawingImage(value);
74 geFilter.SetParam(desc, image);
75 }
76
UpdateVisualEffectParamImpl(Drawing::GEVisualEffect & geFilter,const std::string & desc,const std::vector<float> & value)77 void RSNGRenderEffectHelper::UpdateVisualEffectParamImpl(Drawing::GEVisualEffect& geFilter,
78 const std::string& desc, const std::vector<float>& value)
79 {
80 geFilter.SetParam(desc, value);
81 }
82
CalculatePropTagHashImpl(uint32_t & hash,float value)83 void RSNGRenderEffectHelper::CalculatePropTagHashImpl(uint32_t& hash, float value)
84 {
85 hash = hashFunc_(&value, sizeof(value), hash);
86 }
87
CalculatePropTagHashImpl(uint32_t & hash,bool value)88 void RSNGRenderEffectHelper::CalculatePropTagHashImpl(uint32_t& hash, bool value)
89 {
90 hash = hashFunc_(&value, sizeof(value), hash);
91 }
92
CalculatePropTagHashImpl(uint32_t & hash,const Vector4f & value)93 void RSNGRenderEffectHelper::CalculatePropTagHashImpl(uint32_t& hash, const Vector4f& value)
94 {
95 hash = hashFunc_(&value.data_, Vector4f::DATA_SIZE, hash);
96 }
97
CalculatePropTagHashImpl(uint32_t & hash,const Vector3f & value)98 void RSNGRenderEffectHelper::CalculatePropTagHashImpl(uint32_t& hash, const Vector3f& value)
99 {
100 hash = hashFunc_(&value.data_, Vector3f::DATA_SIZE, hash);
101 }
102
CalculatePropTagHashImpl(uint32_t & hash,const Vector2f & value)103 void RSNGRenderEffectHelper::CalculatePropTagHashImpl(uint32_t& hash, const Vector2f& value)
104 {
105 hash = hashFunc_(&value.data_, Vector2f::DATA_SIZE, hash);
106 }
107
CalculatePropTagHashImpl(uint32_t & hash,std::shared_ptr<RSNGRenderMaskBase> value)108 void RSNGRenderEffectHelper::CalculatePropTagHashImpl(uint32_t& hash, std::shared_ptr<RSNGRenderMaskBase> value)
109 {
110 if (!value) {
111 return;
112 }
113
114 uint32_t maskHash = value->CalculateHash();
115 hash = hashFunc_(&maskHash, sizeof(maskHash), hash);
116 }
117
CalculatePropTagHashImpl(uint32_t & hash,const VectorVector2F & value)118 void RSNGRenderEffectHelper::CalculatePropTagHashImpl(uint32_t& hash, const VectorVector2F& value)
119 {
120 for (const auto& vec : value) {
121 hash = hashFunc_(vec.data_, Vector2f::DATA_SIZE, hash);
122 }
123 }
124
CalculatePropTagHashImpl(uint32_t & hash,std::shared_ptr<Media::PixelMap> value)125 void RSNGRenderEffectHelper::CalculatePropTagHashImpl(uint32_t& hash, std::shared_ptr<Media::PixelMap> value)
126 {
127 auto image = RSPixelMapUtil::ExtractDrawingImage(value);
128 if (!image) {
129 return;
130 }
131
132 auto imageUniqueID = image->GetUniqueID();
133 hash = hashFunc_(&imageUniqueID, sizeof(imageUniqueID), hash);
134 }
135
CalculatePropTagHashImpl(uint32_t & hash,const std::vector<float> & value)136 void RSNGRenderEffectHelper::CalculatePropTagHashImpl(uint32_t& hash, const std::vector<float>& value)
137 {
138 for (size_t i = 0; i < value.size(); i++) {
139 hash = hashFunc_(&value[i], sizeof(float), hash);
140 }
141 }
142
CreateGEVisualEffect(RSNGEffectType type)143 std::shared_ptr<Drawing::GEVisualEffect> RSNGRenderEffectHelper::CreateGEVisualEffect(RSNGEffectType type)
144 {
145 return std::make_shared<Drawing::GEVisualEffect>(GetEffectTypeString(type), Drawing::DrawingPaintType::BRUSH);
146 }
147
AppendToGEContainer(std::shared_ptr<Drawing::GEVisualEffectContainer> & ge,std::shared_ptr<Drawing::GEVisualEffect> geShader)148 void RSNGRenderEffectHelper::AppendToGEContainer(std::shared_ptr<Drawing::GEVisualEffectContainer>& ge,
149 std::shared_ptr<Drawing::GEVisualEffect> geShader)
150 {
151 if (!ge) {
152 return;
153 }
154 ge->AddToChainedFilter(geShader);
155 }
156 } // namespace Rosen
157 } // namespace OHOS
158