2 * Copyright (c) 2021 Samsung Electronics Co., Ltd.
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
18 #include <dali-toolkit/internal/visuals/visual-factory-impl.h>
21 #include <dali/devel-api/scripting/scripting.h>
22 #include <dali/integration-api/debug.h>
23 #include <dali/public-api/object/property-array.h>
24 #include <dali/public-api/object/type-registry-helper.h>
25 #include <dali/public-api/object/type-registry.h>
28 #include <dali-toolkit/devel-api/asset-manager/asset-manager.h>
29 #include <dali-toolkit/devel-api/visuals/visual-properties-devel.h>
30 #include <dali-toolkit/internal/visuals/animated-gradient/animated-gradient-visual.h>
31 #include <dali-toolkit/internal/visuals/animated-image/animated-image-visual.h>
32 #include <dali-toolkit/internal/visuals/animated-vector-image/animated-vector-image-visual.h>
33 #include <dali-toolkit/internal/visuals/arc/arc-visual.h>
34 #include <dali-toolkit/internal/visuals/border/border-visual.h>
35 #include <dali-toolkit/internal/visuals/color/color-visual.h>
36 #include <dali-toolkit/internal/visuals/gradient/gradient-visual.h>
37 #include <dali-toolkit/internal/visuals/image-visual-shader-factory.h>
38 #include <dali-toolkit/internal/visuals/image/image-visual.h>
39 #include <dali-toolkit/internal/visuals/mesh/mesh-visual.h>
40 #include <dali-toolkit/internal/visuals/npatch/npatch-visual.h>
41 #include <dali-toolkit/internal/visuals/primitive/primitive-visual.h>
42 #include <dali-toolkit/internal/visuals/svg/svg-visual.h>
43 #include <dali-toolkit/internal/visuals/text/text-visual.h>
44 #include <dali-toolkit/internal/visuals/visual-factory-cache.h>
45 #include <dali-toolkit/internal/visuals/visual-string-constants.h>
46 #include <dali-toolkit/internal/visuals/visual-url.h>
47 #include <dali-toolkit/internal/visuals/wireframe/wireframe-visual.h>
48 #include <dali-toolkit/public-api/visuals/image-visual-properties.h>
49 #include <dali-toolkit/public-api/visuals/text-visual-properties.h>
50 #include <dali-toolkit/public-api/visuals/visual-properties.h>
60 #if defined(DEBUG_ENABLED)
61 Debug::Filter* gLogFilter = Debug::Filter::New(Debug::NoLogging, false, "LOG_CONTROL_VISUALS");
64 static constexpr int32_t COUNT_BROKEN_IMAGE_MAX = 3;
68 BaseHandle handle = Toolkit::VisualFactory::Get();
73 DALI_TYPE_REGISTRATION_BEGIN_CREATE(Toolkit::VisualFactory, Dali::BaseHandle, Create, true)
74 DALI_TYPE_REGISTRATION_END()
75 const char* const BROKEN_IMAGE_FILE_NAME = "broken.png"; ///< The file name of the broken image.
79 VisualFactory::VisualFactory(bool debugEnabled)
81 mImageVisualShaderFactory(),
83 mDebugEnabled(debugEnabled),
84 mPreMultiplyOnLoad(true)
88 VisualFactory::~VisualFactory()
92 void VisualFactory::OnStyleChangedSignal(Toolkit::StyleManager styleManager, StyleChange::Type type)
94 if(type == StyleChange::THEME_CHANGE)
96 SetBrokenImageUrl(styleManager);
100 Toolkit::Visual::Base VisualFactory::CreateVisual(const Property::Map& propertyMap)
102 Visual::BasePtr visualPtr;
104 Property::Value* typeValue = propertyMap.Find(Toolkit::Visual::Property::TYPE, VISUAL_TYPE);
105 Toolkit::DevelVisual::Type visualType = Toolkit::DevelVisual::IMAGE; // Default to IMAGE type.
108 Scripting::GetEnumerationProperty(*typeValue, VISUAL_TYPE_TABLE, VISUAL_TYPE_TABLE_COUNT, visualType);
113 case Toolkit::Visual::BORDER:
115 visualPtr = BorderVisual::New(GetFactoryCache(), propertyMap);
119 case Toolkit::Visual::COLOR:
121 visualPtr = ColorVisual::New(GetFactoryCache(), propertyMap);
125 case Toolkit::Visual::GRADIENT:
127 visualPtr = GradientVisual::New(GetFactoryCache(), propertyMap);
131 case Toolkit::Visual::IMAGE:
133 Property::Value* imageURLValue = propertyMap.Find(Toolkit::ImageVisual::Property::URL, IMAGE_URL_NAME);
134 std::string imageUrl;
137 if(imageURLValue->Get(imageUrl))
139 if(!imageUrl.empty())
141 VisualUrl visualUrl(imageUrl);
143 switch(visualUrl.GetType())
145 case VisualUrl::N_PATCH:
147 visualPtr = NPatchVisual::New(GetFactoryCache(), GetImageVisualShaderFactory(), visualUrl, propertyMap);
152 visualPtr = SvgVisual::New(GetFactoryCache(), GetImageVisualShaderFactory(), visualUrl, propertyMap);
156 case VisualUrl::WEBP:
158 visualPtr = AnimatedImageVisual::New(GetFactoryCache(), GetImageVisualShaderFactory(), visualUrl, propertyMap);
161 case VisualUrl::JSON:
163 visualPtr = AnimatedVectorImageVisual::New(GetFactoryCache(), GetImageVisualShaderFactory(), imageUrl, propertyMap);
166 case VisualUrl::REGULAR_IMAGE:
168 visualPtr = ImageVisual::New(GetFactoryCache(), GetImageVisualShaderFactory(), visualUrl, propertyMap);
176 Property::Array* array = imageURLValue->GetArray();
179 visualPtr = AnimatedImageVisual::New(GetFactoryCache(), GetImageVisualShaderFactory(), *array, propertyMap);
186 case Toolkit::Visual::MESH:
188 visualPtr = MeshVisual::New(GetFactoryCache(), propertyMap);
192 case Toolkit::Visual::PRIMITIVE:
194 visualPtr = PrimitiveVisual::New(GetFactoryCache(), propertyMap);
198 case Toolkit::Visual::WIREFRAME:
200 visualPtr = WireframeVisual::New(GetFactoryCache(), propertyMap);
204 case Toolkit::Visual::TEXT:
206 visualPtr = TextVisual::New(GetFactoryCache(), propertyMap);
210 case Toolkit::Visual::N_PATCH:
212 Property::Value* imageURLValue = propertyMap.Find(Toolkit::ImageVisual::Property::URL, IMAGE_URL_NAME);
213 std::string imageUrl;
214 if(imageURLValue && imageURLValue->Get(imageUrl))
216 visualPtr = NPatchVisual::New(GetFactoryCache(), GetImageVisualShaderFactory(), imageUrl, propertyMap);
221 case Toolkit::Visual::SVG:
223 Property::Value* imageURLValue = propertyMap.Find(Toolkit::ImageVisual::Property::URL, IMAGE_URL_NAME);
224 std::string imageUrl;
225 if(imageURLValue && imageURLValue->Get(imageUrl))
227 visualPtr = SvgVisual::New(GetFactoryCache(), GetImageVisualShaderFactory(), imageUrl, propertyMap);
232 case Toolkit::Visual::ANIMATED_IMAGE:
234 Property::Value* imageURLValue = propertyMap.Find(Toolkit::ImageVisual::Property::URL, IMAGE_URL_NAME);
235 std::string imageUrl;
238 if(imageURLValue->Get(imageUrl))
240 visualPtr = AnimatedImageVisual::New(GetFactoryCache(), GetImageVisualShaderFactory(), imageUrl, propertyMap);
244 Property::Array* array = imageURLValue->GetArray();
247 visualPtr = AnimatedImageVisual::New(GetFactoryCache(), GetImageVisualShaderFactory(), *array, propertyMap);
254 case Toolkit::DevelVisual::ANIMATED_GRADIENT:
256 visualPtr = AnimatedGradientVisual::New(GetFactoryCache(), propertyMap);
260 case Toolkit::DevelVisual::ANIMATED_VECTOR_IMAGE:
262 Property::Value* imageURLValue = propertyMap.Find(Toolkit::ImageVisual::Property::URL, IMAGE_URL_NAME);
263 std::string imageUrl;
264 if(imageURLValue && imageURLValue->Get(imageUrl))
266 visualPtr = AnimatedVectorImageVisual::New(GetFactoryCache(), GetImageVisualShaderFactory(), imageUrl, propertyMap);
271 case Toolkit::DevelVisual::ARC:
273 visualPtr = ArcVisual::New(GetFactoryCache(), propertyMap);
278 DALI_LOG_INFO(gLogFilter, Debug::Concise, "VisualFactory::CreateVisual( VisualType:%s %s%s)\n", Scripting::GetEnumerationName<Toolkit::DevelVisual::Type>(visualType, VISUAL_TYPE_TABLE, VISUAL_TYPE_TABLE_COUNT), (visualType == Toolkit::DevelVisual::IMAGE) ? "url:" : "", (visualType == Toolkit::DevelVisual::IMAGE) ? (([&]() {
279 // Return URL if present in PropertyMap else return "not found message"
280 Property::Value* imageURLValue = propertyMap.Find(Toolkit::ImageVisual::Property::URL, IMAGE_URL_NAME);
281 return (imageURLValue) ? imageURLValue->Get<std::string>().c_str() : "url not found in PropertyMap";
287 DALI_LOG_ERROR("VisualType unknown\n");
290 if(mDebugEnabled && visualType != Toolkit::DevelVisual::WIREFRAME)
292 //Create a WireframeVisual if we have debug enabled
293 visualPtr = WireframeVisual::New(GetFactoryCache(), visualPtr, propertyMap);
296 return Toolkit::Visual::Base(visualPtr.Get());
299 Toolkit::Visual::Base VisualFactory::CreateVisual(const std::string& url, ImageDimensions size)
301 Visual::BasePtr visualPtr;
305 // first resolve url type to know which visual to create
306 VisualUrl visualUrl(url);
307 switch(visualUrl.GetType())
309 case VisualUrl::N_PATCH:
311 visualPtr = NPatchVisual::New(GetFactoryCache(), GetImageVisualShaderFactory(), visualUrl);
316 visualPtr = SvgVisual::New(GetFactoryCache(), GetImageVisualShaderFactory(), visualUrl);
320 case VisualUrl::WEBP:
322 visualPtr = AnimatedImageVisual::New(GetFactoryCache(), GetImageVisualShaderFactory(), visualUrl);
325 case VisualUrl::JSON:
327 visualPtr = AnimatedVectorImageVisual::New(GetFactoryCache(), GetImageVisualShaderFactory(), visualUrl);
330 case VisualUrl::REGULAR_IMAGE:
332 visualPtr = ImageVisual::New(GetFactoryCache(), GetImageVisualShaderFactory(), visualUrl, size);
340 //Create a WireframeVisual if we have debug enabled
341 visualPtr = WireframeVisual::New(GetFactoryCache(), visualPtr);
344 return Toolkit::Visual::Base(visualPtr.Get());
347 void VisualFactory::SetPreMultiplyOnLoad(bool preMultiply)
349 if(mPreMultiplyOnLoad != preMultiply)
351 GetFactoryCache().SetPreMultiplyOnLoad(preMultiply);
353 mPreMultiplyOnLoad = preMultiply;
356 bool VisualFactory::GetPreMultiplyOnLoad() const
358 return mPreMultiplyOnLoad;
361 Internal::TextureManager& VisualFactory::GetTextureManager()
363 return GetFactoryCache().GetTextureManager();
366 void VisualFactory::SetBrokenImageUrl(Toolkit::StyleManager& styleManager)
368 const std::string imageDirPath = AssetManager::GetDaliImagePath();
369 std::string brokenImageUrl = imageDirPath + BROKEN_IMAGE_FILE_NAME;
370 std::string customBrokenImageUrl[COUNT_BROKEN_IMAGE_MAX];
374 Property::Map config = Toolkit::DevelStyleManager::GetConfigurations(styleManager);
375 config["brokenImageUrl"].Get(brokenImageUrl);
376 styleManager.StyleChangedSignal().Connect(mSlotDelegate, &VisualFactory::OnStyleChangedSignal);
378 bool findCustomBrokenImage = false;
379 for(int i=0;i<COUNT_BROKEN_IMAGE_MAX;i++)
381 customBrokenImageUrl[i] = Toolkit::DevelStyleManager::GetBrokenImageUrl(styleManager,Toolkit::DevelStyleManager::BrokenImageType(i));
382 if(!customBrokenImageUrl[i].empty())
384 findCustomBrokenImage = true;
388 if(findCustomBrokenImage)
390 std::string customDefaultBrokenUrl = "";
391 mFactoryCache->EnableCustomBrokenImage(true);
392 customDefaultBrokenUrl = customBrokenImageUrl[0];
394 for(int i=0;i<COUNT_BROKEN_IMAGE_MAX;i++)
396 if(customDefaultBrokenUrl.empty())
398 if(!customBrokenImageUrl[i].empty())
400 customDefaultBrokenUrl = customBrokenImageUrl[i];
401 mFactoryCache->SetBrokenImageUrl(Toolkit::Internal::VisualFactoryCache::BrokenImageType::SMALL, customBrokenImageUrl[i]);
404 mFactoryCache->SetBrokenImageUrl(Toolkit::Internal::VisualFactoryCache::BrokenImageType(i), customBrokenImageUrl[i]);
409 mFactoryCache->SetBrokenImageUrl(Toolkit::Internal::VisualFactoryCache::BrokenImageType::SMALL, brokenImageUrl);
414 mFactoryCache->SetBrokenImageUrl(Toolkit::Internal::VisualFactoryCache::BrokenImageType::SMALL, brokenImageUrl);
418 Internal::VisualFactoryCache& VisualFactory::GetFactoryCache()
422 mFactoryCache = std::unique_ptr<VisualFactoryCache>(new VisualFactoryCache(mPreMultiplyOnLoad));
423 Toolkit::StyleManager styleManager = Toolkit::StyleManager::Get();
424 SetBrokenImageUrl(styleManager);
426 return *mFactoryCache;
429 ImageVisualShaderFactory& VisualFactory::GetImageVisualShaderFactory()
431 if(!mImageVisualShaderFactory)
433 mImageVisualShaderFactory = std::unique_ptr<ImageVisualShaderFactory>(new ImageVisualShaderFactory());
435 return *mImageVisualShaderFactory;
438 } // namespace Internal
440 } // namespace Toolkit