2 * Copyright (c) 2015 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 "renderer-factory-impl.h"
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/devel-api/object/type-registry-helper.h>
28 #include <dali-toolkit/internal/controls/renderers/border/border-renderer.h>
29 #include <dali-toolkit/internal/controls/renderers/color/color-renderer.h>
30 #include <dali-toolkit/internal/controls/renderers/gradient/gradient-renderer.h>
31 #include <dali-toolkit/internal/controls/renderers/npatch/npatch-renderer.h>
32 #include <dali-toolkit/internal/controls/renderers/image/image-renderer.h>
33 #include <dali-toolkit/internal/controls/renderers/renderer-factory-cache.h>
37 const char * const RENDERER_TYPE_NAME( "rendererType" );
39 const char * const COLOR_RENDERER("colorRenderer");
40 const char * const BORDER_RENDERER("borderRenderer");
41 const char * const GRADIENT_RENDERER("gradientRenderer");
42 const char * const IMAGE_RENDERER("imageRenderer");
43 const char * const N_PATCH_RENDERER("nPatchRenderer");
45 const char * const BROKEN_RENDERER_IMAGE_URL( DALI_IMAGE_DIR "broken.png");
62 BaseHandle handle = Toolkit::RendererFactory::Get();
67 DALI_TYPE_REGISTRATION_BEGIN_CREATE( Toolkit::RendererFactory, Dali::BaseHandle, Create, true )
68 DALI_TYPE_REGISTRATION_END()
72 RendererFactory::RendererFactory()
76 RendererFactory::~RendererFactory()
80 Toolkit::ControlRenderer RendererFactory::GetControlRenderer( const Property::Map& propertyMap )
82 ControlRenderer* rendererPtr = NULL;
84 Property::Value* type = propertyMap.Find( RENDERER_TYPE_NAME );
85 std::string typeValue ;
86 if( type && type->Get( typeValue ))
90 mFactoryCache = new RendererFactoryCache();
93 if( typeValue == COLOR_RENDERER )
95 rendererPtr = new ColorRenderer( *( mFactoryCache.Get() ) );
97 else if( typeValue == GRADIENT_RENDERER )
99 rendererPtr = new GradientRenderer( *( mFactoryCache.Get() ) );
101 else if( typeValue == IMAGE_RENDERER )
103 rendererPtr = new ImageRenderer( *( mFactoryCache.Get() ) );
105 else if( typeValue == N_PATCH_RENDERER )
107 rendererPtr = new NPatchRenderer( *( mFactoryCache.Get() ) );
109 else if( typeValue == BORDER_RENDERER )
111 rendererPtr = new BorderRenderer( *( mFactoryCache.Get() ) );
118 rendererPtr->Initialize( actor, propertyMap );
122 DALI_LOG_ERROR( "Renderer type unknown" );
125 return Toolkit::ControlRenderer( rendererPtr );
128 Toolkit::ControlRenderer RendererFactory::GetControlRenderer( const Vector4& color )
132 mFactoryCache = new RendererFactoryCache();
135 ColorRenderer* rendererPtr = new ColorRenderer( *( mFactoryCache.Get() ) );
136 rendererPtr->SetColor( color );
138 return Toolkit::ControlRenderer( rendererPtr );
141 void RendererFactory::ResetRenderer( Toolkit::ControlRenderer& renderer, Actor& actor, const Vector4& color )
145 ColorRenderer* rendererPtr = dynamic_cast< ColorRenderer* >( &GetImplementation( renderer ) );
148 rendererPtr->SetColor( color );
152 renderer.RemoveAndReset( actor );
155 renderer = GetControlRenderer( color );
156 if( actor && actor.OnStage() )
158 renderer.SetOnStage( actor );
162 Toolkit::ControlRenderer RendererFactory::GetControlRenderer( float borderSize, const Vector4& borderColor )
166 mFactoryCache = new RendererFactoryCache();
168 BorderRenderer* rendererPtr = new BorderRenderer( *mFactoryCache.Get() );
172 mFactoryCache = new RendererFactoryCache();
175 rendererPtr->SetBorderSize( borderSize );
176 rendererPtr->SetBorderColor( borderColor );
178 return Toolkit::ControlRenderer( rendererPtr );
181 Toolkit::ControlRenderer RendererFactory::GetControlRenderer( const Image& image )
185 mFactoryCache = new RendererFactoryCache();
188 NinePatchImage npatchImage = NinePatchImage::DownCast( image );
191 NPatchRenderer* rendererPtr = new NPatchRenderer( *( mFactoryCache.Get() ) );
192 rendererPtr->SetImage( npatchImage );
194 return Toolkit::ControlRenderer( rendererPtr );
198 ImageRenderer* rendererPtr = new ImageRenderer( *( mFactoryCache.Get() ) );
200 rendererPtr->SetImage( actor, image );
202 return Toolkit::ControlRenderer( rendererPtr );
206 void RendererFactory::ResetRenderer( Toolkit::ControlRenderer& renderer, Actor& actor, const Image& image )
210 NinePatchImage npatchImage = NinePatchImage::DownCast( image );
213 NPatchRenderer* rendererPtr = dynamic_cast< NPatchRenderer* >( &GetImplementation( renderer ) );
216 rendererPtr->SetImage( npatchImage );
222 ImageRenderer* rendererPtr = dynamic_cast< ImageRenderer* >( &GetImplementation( renderer ) );
225 rendererPtr->SetImage( actor, image );
230 renderer.RemoveAndReset( actor );
233 renderer = GetControlRenderer( image );
234 if( actor && actor.OnStage() )
236 renderer.SetOnStage( actor );
240 Toolkit::ControlRenderer RendererFactory::GetControlRenderer( const std::string& url )
244 mFactoryCache = new RendererFactoryCache();
247 if( NinePatchImage::IsNinePatchUrl( url ) )
249 NPatchRenderer* rendererPtr = new NPatchRenderer( *( mFactoryCache.Get() ) );
250 rendererPtr->SetImage( url );
252 return Toolkit::ControlRenderer( rendererPtr );
256 ImageRenderer* rendererPtr = new ImageRenderer( *( mFactoryCache.Get() ) );
258 rendererPtr->SetImage( actor, url );
260 return Toolkit::ControlRenderer( rendererPtr );
264 void RendererFactory::ResetRenderer( Toolkit::ControlRenderer& renderer, Actor& actor, const std::string& url )
268 if( NinePatchImage::IsNinePatchUrl( url ) )
270 NPatchRenderer* rendererPtr = dynamic_cast< NPatchRenderer* >( &GetImplementation( renderer ) );
273 rendererPtr->SetImage( url );
279 ImageRenderer* rendererPtr = dynamic_cast< ImageRenderer* >( &GetImplementation( renderer ) );
282 rendererPtr->SetImage( actor, url );
287 renderer.RemoveAndReset( actor );
290 renderer = GetControlRenderer( url );
291 if( actor && actor.OnStage() )
293 renderer.SetOnStage( actor );
297 void RendererFactory::ResetRenderer( Toolkit::ControlRenderer& renderer, Actor& actor, const Property::Map& propertyMap )
301 ControlRenderer& controlRenderer = GetImplementation( renderer );
303 Property::Value* type = propertyMap.Find( RENDERER_TYPE_NAME );
304 std::string typeValue ;
306 //If there's no renderer type specified or if there hasn't been a renderer type change then we can reuse the renderer
307 if( !type || !type->Get( typeValue ) ||
308 ( typeValue == IMAGE_RENDERER && typeid( controlRenderer ) == typeid( ImageRenderer ) ) ||
309 ( typeValue == N_PATCH_RENDERER && typeid( controlRenderer ) == typeid( NPatchRenderer ) ) ||
310 ( typeValue == COLOR_RENDERER && typeid( controlRenderer ) == typeid( ColorRenderer ) )||
311 ( typeValue == GRADIENT_RENDERER && typeid( controlRenderer ) == typeid( GradientRenderer ) ) ||
312 ( typeValue == BORDER_RENDERER && typeid( controlRenderer ) == typeid( BorderRenderer ) ) )
314 controlRenderer.Initialize( actor, propertyMap );
318 renderer.RemoveAndReset( actor );
321 renderer = GetControlRenderer( propertyMap );
322 if( actor && actor.OnStage() )
324 renderer.SetOnStage( actor );
328 Image RendererFactory::GetBrokenRendererImage()
330 return ResourceImage::New( BROKEN_RENDERER_IMAGE_URL );
333 } // namespace Internal
335 } // namespace Toolkit