X-Git-Url: http://review.tizen.org/git/?p=platform%2Fcore%2Fuifw%2Fdali-toolkit.git;a=blobdiff_plain;f=dali-toolkit%2Finternal%2Fvisuals%2Fimage-atlas-manager.cpp;h=2e4dfb4ad86b7046207824707b2b965976b92a72;hp=66897e4940fabb0be93a74583823d5f2965ec977;hb=954a8e25f7e32579a4a9276db09f43d45a19d2a0;hpb=bd75dc4cad4ce62cc9206abf19280b40825b9726 diff --git a/dali-toolkit/internal/visuals/image-atlas-manager.cpp b/dali-toolkit/internal/visuals/image-atlas-manager.cpp index 66897e4..2e4dfb4 100644 --- a/dali-toolkit/internal/visuals/image-atlas-manager.cpp +++ b/dali-toolkit/internal/visuals/image-atlas-manager.cpp @@ -20,7 +20,7 @@ // EXTERNAL HEADER #include -#include +#include namespace Dali { @@ -49,15 +49,16 @@ ImageAtlasManager::~ImageAtlasManager() TextureSet ImageAtlasManager::Add( Vector4& textureRect, const std::string& url, - ImageDimensions size, + ImageDimensions& size, FittingMode::Type fittingMode, - bool orientationCorrection ) + bool orientationCorrection, + AtlasUploadObserver* atlasUploadObserver ) { ImageDimensions dimensions = size; ImageDimensions zero; if( size == zero ) { - dimensions = ResourceImage::GetImageSize( url ); + dimensions = Dali::GetClosestImageSize( url ); } // big image, atlasing is not applied @@ -67,11 +68,12 @@ TextureSet ImageAtlasManager::Add( Vector4& textureRect, { return TextureSet(); } + size = dimensions; unsigned int i = 0; for( AtlasContainer::iterator iter = mAtlasList.begin(); iter != mAtlasList.end(); ++iter) { - if( (*iter).Upload( textureRect, url, size, fittingMode, orientationCorrection ) ) + if( (*iter).Upload( textureRect, url, size, fittingMode, orientationCorrection, atlasUploadObserver ) ) { return mTextureSetList[i]; } @@ -79,12 +81,12 @@ TextureSet ImageAtlasManager::Add( Vector4& textureRect, } CreateNewAtlas(); - mAtlasList.back().Upload( textureRect, url, size, fittingMode, orientationCorrection ); + mAtlasList.back().Upload( textureRect, url, size, fittingMode, orientationCorrection, atlasUploadObserver ); return mTextureSetList.back(); } TextureSet ImageAtlasManager::Add( Vector4& textureRect, - PixelData pixelData ) + PixelData pixelData ) { // big buffer, atlasing is not applied