X-Git-Url: http://review.tizen.org/git/?p=platform%2Fcore%2Fuifw%2Fdali-toolkit.git;a=blobdiff_plain;f=dali-toolkit%2Finternal%2Fvisuals%2Fnpatch-loader.cpp;h=2e216f339c6d5e357d8558179f872cbf7cb18d85;hp=d4a1f0e4ae33f9ff47e47c2481ea42407f833db7;hb=8bb92d7d1170f2ddf59da60bd3588be601ef8cd2;hpb=da6b7205afe6a54fb1caf7a765008948a57f45eb diff --git a/dali-toolkit/internal/visuals/npatch-loader.cpp b/dali-toolkit/internal/visuals/npatch-loader.cpp index d4a1f0e..2e216f3 100644 --- a/dali-toolkit/internal/visuals/npatch-loader.cpp +++ b/dali-toolkit/internal/visuals/npatch-loader.cpp @@ -18,7 +18,10 @@ // CLASS HEADER #include -// EXTERNAL INCLUDES +// INTERNAL HEADERS +#include + +// EXTERNAL HEADERS #include #include @@ -52,6 +55,9 @@ void SetLoadedNPatchData( NPatchLoader::Data* data, Devel::PixelBuffer& pixelBuf data->croppedWidth = pixelBuffer.GetWidth(); data->croppedHeight = pixelBuffer.GetHeight(); + // Create opacity map + data->renderingMap = RenderingAddOn::Get().IsValid() ? RenderingAddOn::Get().BuildNPatch(pixelBuffer, data ) : nullptr; + PixelData pixels = Devel::PixelBuffer::Convert( pixelBuffer ); // takes ownership of buffer Texture texture = Texture::New( TextureType::TEXTURE_2D, pixels.GetPixelFormat(), pixels.GetWidth(), pixels.GetHeight() ); @@ -65,6 +71,15 @@ void SetLoadedNPatchData( NPatchLoader::Data* data, Devel::PixelBuffer& pixelBuf } // namespace NPatchBuffer +NPatchLoader::Data::~Data() +{ + // If there is an opacity map, it has to be destroyed using addon call + if( renderingMap ) + { + RenderingAddOn::Get().DestroyNPatch( renderingMap ); + } +} + NPatchLoader::NPatchLoader() { }