X-Git-Url: http://review.tizen.org/git/?p=platform%2Fcore%2Fuifw%2Fdali-toolkit.git;a=blobdiff_plain;f=dali-toolkit%2Finternal%2Fcontrols%2Fimage-view%2Fimage-view-impl.cpp;h=59a3b336234c4e73a302e32d2fef3c103677d9ff;hp=2cb24bb21812620ee37cf4fb466276a00e037db3;hb=4c6d34154c81cf86b4c3662b81e1223f3326ceb5;hpb=ada974666c47551b8bfdb9302acc95f91ffda901 diff --git a/dali-toolkit/internal/controls/image-view/image-view-impl.cpp b/dali-toolkit/internal/controls/image-view/image-view-impl.cpp index 2cb24bb..59a3b33 100644 --- a/dali-toolkit/internal/controls/image-view/image-view-impl.cpp +++ b/dali-toolkit/internal/controls/image-view/image-view-impl.cpp @@ -73,24 +73,8 @@ void ImageView::SetImage( Image image ) mImage = image; - bool newRendererCreated = false; - if( mRenderer ) - { - newRendererCreated = Toolkit::RendererFactory::Get().ResetRenderer( mRenderer, image ); - } - else - { - mRenderer = Toolkit::RendererFactory::Get().GetControlRenderer( image ); - newRendererCreated = true; - } - - //we need to inform any newly created renderers if it is on stage - if( newRendererCreated && Self().OnStage() ) - { - CustomActor self = Self(); - mRenderer.SetOnStage( self ); - } - + Actor self = Self(); + Toolkit::RendererFactory::Get().ResetRenderer( mRenderer, self, image ); mImageSize = image ? ImageDimensions( image.GetWidth(), image.GetHeight() ) : ImageDimensions( 0, 0 ); } } @@ -99,23 +83,8 @@ void ImageView::SetImage( Property::Map map ) { mPropertyMap = map; - bool newRendererCreated = false; - if( mRenderer ) - { - newRendererCreated = Toolkit::RendererFactory::Get().ResetRenderer( mRenderer, mPropertyMap ); - } - else - { - mRenderer = Toolkit::RendererFactory::Get().GetControlRenderer( mPropertyMap ); - newRendererCreated = true; - } - - //we need to inform any newly created renderers if it is on stage - CustomActor self = Self(); - if( newRendererCreated && self.OnStage() ) - { - mRenderer.SetOnStage( self ); - } + Actor self = Self(); + Toolkit::RendererFactory::Get().ResetRenderer( mRenderer, self, mPropertyMap ); int width = 0; Property::Value* widthValue = mPropertyMap.Find( "width" ); @@ -134,7 +103,7 @@ void ImageView::SetImage( Property::Map map ) mImageSize = ImageDimensions( width, height ); } -void ImageView::SetImage( const std::string& url ) +void ImageView::SetImage( const std::string& url, ImageDimensions size ) { if( mUrl != url ) { @@ -143,25 +112,17 @@ void ImageView::SetImage( const std::string& url ) mUrl = url; - bool newRendererCreated = false; - if( mRenderer ) + if( size.GetWidth() == 0u && size.GetHeight() == 0u ) { - newRendererCreated = Toolkit::RendererFactory::Get().ResetRenderer( mRenderer, mUrl ); + mImageSize = ResourceImage::GetImageSize( mUrl ); } else { - mRenderer = Toolkit::RendererFactory::Get().GetControlRenderer( mUrl ); - newRendererCreated = true; - } - - //we need to inform any newly created renderers if it is on stage - if( newRendererCreated && Self().OnStage() ) - { - CustomActor self = Self(); - mRenderer.SetOnStage( self ); + mImageSize = size; } - mImageSize = ResourceImage::GetImageSize( mUrl ); + Actor self = Self(); + Toolkit::RendererFactory::Get().ResetRenderer( mRenderer, self, mUrl, mImageSize ); } } @@ -255,7 +216,7 @@ void ImageView::SetProperty( BaseObject* object, Property::Index index, const Pr if( value.Get( imageUrl ) ) { ImageView& impl = GetImpl( imageView ); - impl.SetImage( imageUrl ); + impl.SetImage( imageUrl, ImageDimensions() ); } // if its not a string then get a Property::Map from the property if possible.