// EXTERNAL INCLUDES
#include <dali/public-api/images/resource-image.h>
#include <dali/public-api/object/type-registry.h>
-#include <dali/devel-api/object/type-registry-helper.h>
+#include <dali/public-api/object/type-registry-helper.h>
#include <dali/devel-api/scripting/scripting.h>
// INTERNAL INCLUDES
#include <dali-toolkit/public-api/controls/image-view/image-view.h>
#include <dali-toolkit/devel-api/controls/renderer-factory/renderer-factory.h>
-#include <dali-toolkit/internal/controls/renderers/image/image-renderer.h>
namespace Dali
{
using namespace Dali;
ImageView::ImageView()
-: Control( ControlBehaviour( ACTOR_BEHAVIOUR_NONE ) ),
- mPremultipledAlphaEnabled( false )
+: Control( ControlBehaviour( ACTOR_BEHAVIOUR_NONE ) )
{
}
mUrl = url;
- if( size.GetWidth() == 0u && size.GetHeight() == 0u )
- {
- mImageSize = ResourceImage::GetImageSize( mUrl );
- }
- else
+ if( size.GetWidth() != 0u && size.GetHeight() != 0u )
{
mImageSize = size;
}
Actor self = Self();
- Toolkit::RendererFactory::Get().ResetRenderer( mRenderer, self, mUrl, mImageSize );
+ Toolkit::RendererFactory::Get().ResetRenderer( mRenderer, self, mUrl, size );
RelayoutRequest();
}
}
-void ImageView::EnablePreMultipliedAlpha( bool preMultipled )
+Image ImageView::GetImage() const
{
- mPremultipledAlphaEnabled = preMultipled;
+ return mImage;
+}
+void ImageView::EnablePreMultipliedAlpha( bool preMultipled )
+{
if( mRenderer )
{
- ControlRenderer& rendererImpl = GetImplementation( mRenderer );
- if (&typeid( rendererImpl ) == &typeid(ImageRenderer) )
- {
- ImageRenderer* imageRenderer = static_cast<ImageRenderer*>( &rendererImpl );
- imageRenderer->EnablePreMultipliedAlpha( preMultipled );
- }
+ GetImplementation( mRenderer ).EnablePreMultipliedAlpha( preMultipled );
}
}
bool ImageView::IsPreMultipliedAlphaEnabled() const
{
- return mPremultipledAlphaEnabled;
+ if( mRenderer )
+ {
+ return GetImplementation( mRenderer ).IsPreMultipliedAlphaEnabled();
+ }
+ return false;
}
void ImageView::SetDepthIndex( int depthIndex )
Vector3 ImageView::GetNaturalSize()
{
- Vector3 size;
+ if( mRenderer )
+ {
+ Vector2 rendererNaturalSize;
+ mRenderer.GetNaturalSize( rendererNaturalSize );
+ return Vector3( rendererNaturalSize );
+ }
+ Vector3 size;
size.x = mImageSize.GetWidth();
size.y = mImageSize.GetHeight();
Control::OnStageDisconnection();
}
+void ImageView::OnSizeSet( const Vector3& targetSize )
+{
+ Control::OnSizeSet( targetSize );
+
+ if( mRenderer )
+ {
+ Vector2 size( targetSize );
+ mRenderer.SetSize( size );
+ }
+}
+
///////////////////////////////////////////////////////////
//
// Properties
case Toolkit::ImageView::Property::PRE_MULTIPLIED_ALPHA:
{
- bool IsPre;
- if( value.Get( IsPre ) )
+ bool isPre;
+ if( value.Get( isPre ) )
{
- GetImpl(imageView).EnablePreMultipliedAlpha( IsPre );
+ GetImpl(imageView).EnablePreMultipliedAlpha( isPre );
}
break;
}