X-Git-Url: http://review.tizen.org/git/?p=platform%2Fcore%2Fuifw%2Fdali-toolkit.git;a=blobdiff_plain;f=dali-toolkit%2Finternal%2Fvisuals%2Fsvg%2Fsvg-visual.h;h=5dbd24e645f3a3606f02e971c0fe813d653bf52c;hp=81672e50645f1b4754848729a0f0e1b2a0a37bc5;hb=f4c1e7f52d49c3ce033b9ee4c3c7414b06a22d45;hpb=c3f9162ab11786380e2ec9c55f217c2daf7722e8 diff --git a/dali-toolkit/internal/visuals/svg/svg-visual.h b/dali-toolkit/internal/visuals/svg/svg-visual.h index 81672e5..5dbd24e 100644 --- a/dali-toolkit/internal/visuals/svg/svg-visual.h +++ b/dali-toolkit/internal/visuals/svg/svg-visual.h @@ -18,7 +18,8 @@ * */ -//EXTERNAL INCLUDES +// EXTERNAL INCLUDES +#include #include // INTERNAL INCLUDES @@ -35,6 +36,9 @@ namespace Toolkit namespace Internal { +class SvgVisual; +typedef IntrusivePtr< SvgVisual > SvgVisualPtr; + /** * The visual which renders a svg image * @@ -50,16 +54,24 @@ class SvgVisual: public Visual::Base public: /** - * @brief Constructor. + * @brief Create a new SVG visual. * * @param[in] factoryCache A pointer pointing to the VisualFactoryCache object + * @return A smart-pointer to the newly allocated visual. */ - SvgVisual( VisualFactoryCache& factoryCache ); + static SvgVisualPtr New( VisualFactoryCache& factoryCache ); /** - * @brief A reference counted object may only be deleted by calling Unreference(). + * @brief Create 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 + * @param[in] size The required size for the SVG */ - ~SvgVisual(); + static SvgVisualPtr New( VisualFactoryCache& factoryCache, const std::string& imageUrl, ImageDimensions size = ImageDimensions() ); public: // from Visual @@ -78,9 +90,31 @@ public: // from Visual */ 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: /** + * @brief Constructor. + * + * @param[in] factoryCache A pointer pointing to the VisualFactoryCache object + */ + SvgVisual( VisualFactoryCache& factoryCache ); + + /** + * @brief A reference counted object may only be deleted by calling Unreference(). + */ + virtual ~SvgVisual(); + + /** * @copydoc Visual::Base::DoInitialize */ virtual void DoInitialize( Actor& actor, const Property::Map& propertyMap ); @@ -98,15 +132,6 @@ protected: public: /** - * @brief Sets the svg image of this visual to the resource at imageUrl - * 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] imageUrl The URL to svg resource to use - */ - void SetImage( const std::string& imageUrl, ImageDimensions size = ImageDimensions() ); - - /** * @bried Apply the rasterized image to the visual. * * @param[in] rasterizedPixelData The pixel buffer with the rasterized pixels @@ -114,6 +139,15 @@ public: void ApplyRasterizedImage( PixelData rasterizedPixelData ); private: + + /** + * @brief Parses the SVG Image from the set URL. + * + * @param[in] imageUrl The URL of the image to parse the SVG from. + * @param[in] size The required size of the SVG + */ + void ParseFromUrl( const std::string& imageUrl, ImageDimensions size = ImageDimensions() ); + /** * @bried Rasterize the svg with the given size, and add it to the visual. *