X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=dali-toolkit%2Finternal%2Fvisuals%2Fsvg%2Fsvg-visual.h;h=8fd91653cd1a2f9c784d261b11137a76907c3e2f;hb=e35b08ebd60473aef7500601706f665ac8cf7d39;hp=d674d2f1bc7fff4ff135b2ea83130f6a2ec3419b;hpb=1972f043026a3e1bdcaad71c17859a8f324d1e6d;p=platform%2Fcore%2Fuifw%2Fdali-toolkit.git diff --git a/dali-toolkit/internal/visuals/svg/svg-visual.h b/dali-toolkit/internal/visuals/svg/svg-visual.h index d674d2f..8fd9165 100644 --- a/dali-toolkit/internal/visuals/svg/svg-visual.h +++ b/dali-toolkit/internal/visuals/svg/svg-visual.h @@ -18,9 +18,11 @@ * */ +//EXTERNAL INCLUDES +#include + // INTERNAL INCLUDES -#include -#include +#include struct NSVGimage; @@ -34,7 +36,7 @@ namespace Internal { /** - * The renderer which renders a svg image + * The visual which renders a svg image * * The following property is essential * @@ -43,7 +45,7 @@ namespace Internal * | url | STRING | * */ -class SvgVisual: public Visual +class SvgVisual: public Visual::Base { public: @@ -52,7 +54,18 @@ public: * * @param[in] factoryCache A pointer pointing to the VisualFactoryCache object */ - SvgVisual( VisualFactoryCache& factoryCache, ImageAtlasManager& atlasManager ); + SvgVisual( VisualFactoryCache& factoryCache ); + + /** + * @brief Constructor which creates the SVG Visual using the image URL. + * + * The visual will parse the SVG image once it is set. + * And rasterize it into BufferImage synchronously when the associated actor is put on stage, and destroy the BufferImage when it is off stage + * + * @param[in] factoryCache A pointer pointing to the VisualFactoryCache object + * @param[in] imageUrl The URL to svg resource to use + */ + SvgVisual( VisualFactoryCache& factoryCache, const std::string& imageUrl, ImageDimensions size = ImageDimensions() ); /** * @brief A reference counted object may only be deleted by calling Unreference(). @@ -62,66 +75,68 @@ public: public: // from Visual /** - * @copydoc Visual::GetNaturalSize + * @copydoc Visual::Base::GetNaturalSize */ virtual void GetNaturalSize( Vector2& naturalSize ) const; /** - * @copydoc Visual::SetSize + * @copydoc Visual::Base::SetSize */ virtual void SetSize( const Vector2& size ); /** - * @copydoc Visual::CreatePropertyMap + * @copydoc Visual::Base::CreatePropertyMap */ virtual void DoCreatePropertyMap( Property::Map& map ) const; + /** + * @copydoc Visual::Base::DoSetProperty + */ + virtual void DoSetProperty( Dali::Property::Index index, const Dali::Property::Value& propertyValue ); + + /** + * @copydoc Visual::Base::DoGetProperty + */ + virtual Dali::Property::Value DoGetProperty( Dali::Property::Index index ); + protected: /** - * @copydoc Visual::DoInitialize + * @copydoc Visual::Base::DoInitialize */ virtual void DoInitialize( Actor& actor, const Property::Map& propertyMap ); /** - * @copydoc Visual::DoSetOnStage + * @copydoc Visual::Base::DoSetOnStage */ virtual void DoSetOnStage( Actor& actor ); /** - * @copydoc Visual::DoSetOffStage + * @copydoc Visual::Base::DoSetOffStage */ virtual void DoSetOffStage( Actor& actor ); public: /** - * @brief Helper method to determine whether the url indicate that it is a svg image. + * @bried Apply the rasterized image to the visual. * - * @param [in] url The URL of the image file. - * @return true if it is a svg image + * @param[in] rasterizedPixelData The pixel buffer with the rasterized pixels */ - static bool IsSvgUrl( const std::string& url ); + void ApplyRasterizedImage( PixelData rasterizedPixelData ); - /** - * @brief Sets the svg image of this renderer to the resource at imageUrl - * The renderer will parse the svg image once it is set. - * And rasterize it into BufferImage synchronously when the associated actor is put on stage, and destroy the BufferImage when it is off stage - * - * @param[in] imageUrl The URL to svg resource to use - */ - void SetImage( const std::string& imageUrl, ImageDimensions size = ImageDimensions() ); +private: /** - * @bried Apply the rasterized image to the renderer. + * @brief Parses the SVG Image from the set URL. * - * @param[in] rasterizedPixelData The pixel buffer with the rasterized pixels + * @param[in] imageUrl The URL of the image to parse the SVG from. + * @param[in] size The required size of the SVG */ - void ApplyRasterizedImage( PixelData rasterizedPixelData ); + void ParseFromUrl( const std::string& imageUrl, ImageDimensions size = ImageDimensions() ); -private: /** - * @bried Rasterize the svg with the given size, and add it to the renderer. + * @bried Rasterize the svg with the given size, and add it to the visual. * * @param[in] size The target size of the SVG rasterization. */ @@ -136,9 +151,9 @@ private: private: Vector4 mAtlasRect; - ImageAtlasManager& mAtlasManager; std::string mImageUrl; NSVGimage* mParsedImage; + WeakHandle mPlacementActor; };