X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=dali-toolkit%2Finternal%2Fimage-loader%2Fasync-image-loader-impl.cpp;h=966da79bcae345ba8bca1015b72d04371bf998a8;hb=339af74b081016140d2d5e25dc8609913aabaa31;hp=1fbef381ad5f9d01f1bda02dd62571348c95cf84;hpb=89ae5b785c2eb8276d5fb350004414bc3fab8a2d;p=platform%2Fcore%2Fuifw%2Fdali-toolkit.git diff --git a/dali-toolkit/internal/image-loader/async-image-loader-impl.cpp b/dali-toolkit/internal/image-loader/async-image-loader-impl.cpp index 1fbef38..966da79 100644 --- a/dali-toolkit/internal/image-loader/async-image-loader-impl.cpp +++ b/dali-toolkit/internal/image-loader/async-image-loader-impl.cpp @@ -49,7 +49,7 @@ IntrusivePtr AsyncImageLoader::New() return internal; } -uint32_t AsyncImageLoader::Load( const std::string& url, +uint32_t AsyncImageLoader::Load( const VisualUrl& url, ImageDimensions dimensions, FittingMode::Type fittingMode, SamplingMode::Type samplingMode, @@ -71,6 +71,11 @@ Toolkit::AsyncImageLoader::ImageLoadedSignalType& AsyncImageLoader::ImageLoadedS return mLoadedSignal; } +Toolkit::DevelAsyncImageLoader::PixelBufferLoadedSignalType& AsyncImageLoader::PixelBufferLoadedSignal() +{ + return mPixelBufferLoadedSignal; +} + bool AsyncImageLoader::Cancel( uint32_t loadingTaskId ) { return mLoadThread.CancelTask( loadingTaskId ); @@ -83,9 +88,22 @@ void AsyncImageLoader::CancelAll() void AsyncImageLoader::ProcessLoadedImage() { - while( LoadingTask *next = mLoadThread.NextCompletedTask() ) + while( LoadingTask *next = mLoadThread.NextCompletedTask() ) { - mLoadedSignal.Emit( next->id, next->pixelData ); + if( mPixelBufferLoadedSignal.GetConnectionCount() > 0 ) + { + mPixelBufferLoadedSignal.Emit( next->id, next->pixelBuffer ); + } + else if( mLoadedSignal.GetConnectionCount() > 0 ) + { + PixelData pixelData; + if( next->pixelBuffer ) + { + pixelData = Devel::PixelBuffer::Convert( next->pixelBuffer ); + } + mLoadedSignal.Emit( next->id, pixelData ); + } + delete next; } }