Encapsulated visual URL in new VisualUrl class.
[platform/core/uifw/dali-toolkit.git] / dali-toolkit / internal / visuals / visual-factory-impl.cpp
1  /*
2  * Copyright (c) 2016 Samsung Electronics Co., Ltd.
3  *
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
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
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.
15  */
16
17 // CLASS HEADER
18 #include <dali-toolkit/internal/visuals/visual-factory-impl.h>
19
20 // EXTERNAL INCLUDES
21 #include <dali/integration-api/debug.h>
22 #include <dali/public-api/images/image.h>
23 #include <dali/public-api/object/property-array.h>
24 #include <dali/public-api/object/type-registry.h>
25 #include <dali/public-api/object/type-registry-helper.h>
26 #include <dali/devel-api/scripting/scripting.h>
27
28 // INTERNAL INCLUDES
29 #include <dali-toolkit/public-api/visuals/image-visual-properties.h>
30 #include <dali-toolkit/devel-api/visuals/image-visual-properties-devel.h>
31 #include <dali-toolkit/devel-api/visuals/text-visual-properties.h>
32 #include <dali-toolkit/devel-api/visuals/visual-properties-devel.h>
33 #include <dali-toolkit/internal/visuals/border/border-visual.h>
34 #include <dali-toolkit/internal/visuals/color/color-visual.h>
35 #include <dali-toolkit/internal/visuals/gradient/gradient-visual.h>
36 #include <dali-toolkit/internal/visuals/image/image-visual.h>
37 #include <dali-toolkit/internal/visuals/mesh/mesh-visual.h>
38 #include <dali-toolkit/internal/visuals/npatch/npatch-visual.h>
39 #include <dali-toolkit/internal/visuals/primitive/primitive-visual.h>
40 #include <dali-toolkit/internal/visuals/svg/svg-visual.h>
41 #include <dali-toolkit/internal/visuals/text/text-visual.h>
42 #include <dali-toolkit/internal/visuals/animated-image/animated-image-visual.h>
43 #include <dali-toolkit/internal/visuals/wireframe/wireframe-visual.h>
44 #include <dali-toolkit/internal/visuals/visual-factory-cache.h>
45 #include <dali-toolkit/internal/visuals/visual-url.h>
46 #include <dali-toolkit/internal/visuals/visual-string-constants.h>
47
48 namespace Dali
49 {
50
51 namespace Toolkit
52 {
53
54 namespace Internal
55 {
56
57 namespace
58 {
59
60 BaseHandle Create()
61 {
62   BaseHandle handle = Toolkit::VisualFactory::Get();
63
64   return handle;
65 }
66
67 DALI_TYPE_REGISTRATION_BEGIN_CREATE( Toolkit::VisualFactory, Dali::BaseHandle, Create, true )
68 DALI_TYPE_REGISTRATION_END()
69
70 } // namespace
71
72 VisualFactory::VisualFactory( bool debugEnabled )
73 :mDebugEnabled( debugEnabled )
74 {
75 }
76
77 VisualFactory::~VisualFactory()
78 {
79 }
80
81 Toolkit::Visual::Base VisualFactory::CreateVisual( const Property::Map& propertyMap )
82 {
83   // Create factory cache if it hasn't already been
84   if( !mFactoryCache )
85   {
86     mFactoryCache = new VisualFactoryCache();
87   }
88
89   Visual::BasePtr visualPtr;
90
91   Property::Value* typeValue = propertyMap.Find( Toolkit::DevelVisual::Property::TYPE, VISUAL_TYPE );
92   Toolkit::DevelVisual::Type visualType = Toolkit::DevelVisual::IMAGE; // Default to IMAGE type.
93   if( typeValue )
94   {
95     Scripting::GetEnumerationProperty( *typeValue, VISUAL_TYPE_TABLE, VISUAL_TYPE_TABLE_COUNT, visualType );
96   }
97
98   switch( visualType )
99   {
100     case Toolkit::Visual::BORDER:
101     {
102       visualPtr = BorderVisual::New( *( mFactoryCache.Get() ), propertyMap );
103       break;
104     }
105
106     case Toolkit::Visual::COLOR:
107     {
108       visualPtr = ColorVisual::New( *( mFactoryCache.Get() ), propertyMap );
109       break;
110     }
111
112     case Toolkit::Visual::GRADIENT:
113     {
114       visualPtr = GradientVisual::New( *( mFactoryCache.Get() ), propertyMap );
115       break;
116     }
117
118     case Toolkit::Visual::IMAGE:
119     {
120       Property::Value* imageURLValue = propertyMap.Find( Toolkit::ImageVisual::Property::URL, IMAGE_URL_NAME );
121       std::string imageUrl;
122       if( imageURLValue && imageURLValue->Get( imageUrl ) )
123       {
124         VisualUrl visualUrl( imageUrl );
125
126         switch( visualUrl.GetType() )
127         {
128           case VisualUrl::N_PATCH:
129           {
130             visualPtr = NPatchVisual::New( *( mFactoryCache.Get() ), visualUrl, propertyMap );
131             break;
132           }
133           case VisualUrl::SVG:
134           {
135             visualPtr = SvgVisual::New( *( mFactoryCache.Get() ), visualUrl, propertyMap );
136             break;
137           }
138           case VisualUrl::GIF:
139           {
140             visualPtr = AnimatedImageVisual::New( *( mFactoryCache.Get() ), visualUrl, propertyMap );
141             break;
142           }
143           case VisualUrl::REGULAR_IMAGE:
144           {
145             visualPtr = ImageVisual::New( *( mFactoryCache.Get() ), visualUrl, propertyMap );
146             break;
147           }
148         }
149       }
150       break;
151     }
152
153     case Toolkit::Visual::MESH:
154     {
155       visualPtr = MeshVisual::New( *( mFactoryCache.Get() ), propertyMap );
156       break;
157     }
158
159     case Toolkit::Visual::PRIMITIVE:
160     {
161       visualPtr = PrimitiveVisual::New( *( mFactoryCache.Get() ), propertyMap );
162       break;
163     }
164
165     case Toolkit::Visual::WIREFRAME:
166     {
167       visualPtr = WireframeVisual::New( *( mFactoryCache.Get() ), propertyMap );
168       break;
169     }
170
171     case Toolkit::DevelVisual::TEXT:
172     {
173       visualPtr = TextVisual::New( *( mFactoryCache.Get() ), propertyMap );
174       break;
175     }
176
177     case Toolkit::DevelVisual::N_PATCH:
178     {
179       Property::Value* imageURLValue = propertyMap.Find( Toolkit::ImageVisual::Property::URL, IMAGE_URL_NAME );
180       std::string imageUrl;
181       if( imageURLValue && imageURLValue->Get( imageUrl ) )
182       {
183         visualPtr = NPatchVisual::New( *( mFactoryCache.Get() ), imageUrl, propertyMap );
184       }
185       break;
186     }
187
188     case Toolkit::DevelVisual::SVG:
189     {
190       Property::Value* imageURLValue = propertyMap.Find( Toolkit::ImageVisual::Property::URL, IMAGE_URL_NAME );
191       std::string imageUrl;
192       if( imageURLValue && imageURLValue->Get( imageUrl ) )
193       {
194         visualPtr = SvgVisual::New( *( mFactoryCache.Get() ), imageUrl, propertyMap );
195       }
196       break;
197     }
198
199     case Toolkit::DevelVisual::ANIMATED_IMAGE:
200     {
201       Property::Value* imageURLValue = propertyMap.Find( Toolkit::ImageVisual::Property::URL, IMAGE_URL_NAME );
202       std::string imageUrl;
203       if( imageURLValue && imageURLValue->Get( imageUrl ) )
204       {
205         visualPtr = AnimatedImageVisual::New( *( mFactoryCache.Get() ), imageUrl, propertyMap );
206       }
207       break;
208     }
209   }
210
211   if( !visualPtr )
212   {
213     DALI_LOG_ERROR( "Renderer type unknown\n" );
214   }
215
216   if( mDebugEnabled && visualType !=  Toolkit::DevelVisual::WIREFRAME )
217   {
218     //Create a WireframeVisual if we have debug enabled
219     visualPtr = WireframeVisual::New( *( mFactoryCache.Get() ), visualPtr, propertyMap );
220   }
221
222   return Toolkit::Visual::Base( visualPtr.Get() );
223 }
224
225 Toolkit::Visual::Base VisualFactory::CreateVisual( const Image& image )
226 {
227   if( !mFactoryCache )
228   {
229     mFactoryCache = new VisualFactoryCache();
230   }
231
232   Visual::BasePtr visualPtr;
233
234   NinePatchImage npatchImage = NinePatchImage::DownCast( image );
235   if( npatchImage )
236   {
237     visualPtr = NPatchVisual::New( *( mFactoryCache.Get() ), npatchImage );
238   }
239   else
240   {
241     visualPtr = ImageVisual::New( *( mFactoryCache.Get() ), image );
242   }
243
244   if( mDebugEnabled )
245   {
246     //Create a WireframeVisual if we have debug enabled
247     visualPtr = WireframeVisual::New( *( mFactoryCache.Get() ), visualPtr );
248   }
249
250   return Toolkit::Visual::Base( visualPtr.Get() );
251 }
252
253 Toolkit::Visual::Base VisualFactory::CreateVisual( const std::string& url, ImageDimensions size )
254 {
255   if( !mFactoryCache )
256   {
257     mFactoryCache = new VisualFactoryCache();
258   }
259
260   Visual::BasePtr visualPtr;
261
262   // first resolve url type to know which visual to create
263   VisualUrl visualUrl( url );
264   switch( visualUrl.GetType() )
265   {
266     case VisualUrl::N_PATCH:
267     {
268       visualPtr = NPatchVisual::New( *( mFactoryCache.Get() ), visualUrl );
269       break;
270     }
271     case VisualUrl::SVG:
272     {
273       visualPtr = SvgVisual::New( *( mFactoryCache.Get() ), visualUrl );
274       break;
275     }
276     case VisualUrl::GIF:
277     {
278       visualPtr = AnimatedImageVisual::New( *( mFactoryCache.Get() ), visualUrl );
279       break;
280     }
281     case VisualUrl::REGULAR_IMAGE:
282     {
283       visualPtr = ImageVisual::New( *( mFactoryCache.Get() ), visualUrl, size );
284       break;
285     }
286   }
287
288   if( mDebugEnabled )
289   {
290     //Create a WireframeVisual if we have debug enabled
291     visualPtr = WireframeVisual::New( *( mFactoryCache.Get() ), visualPtr );
292   }
293
294   return Toolkit::Visual::Base( visualPtr.Get() );
295 }
296
297 } // namespace Internal
298
299 } // namespace Toolkit
300
301 } // namespace Dali