X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=dali-toolkit%2Finternal%2Fvisuals%2Fsvg%2Fsvg-visual.h;h=43ac1f43e6f796a97c529032e0d29b8fd96dd006;hb=refs%2Fchanges%2F32%2F98732%2F1;hp=d6dfef5ca3f8a967bdbcc6cbb7eb7df525f986ee;hpb=cc0aefb3259c6fe818d9949ebf768843cc01e6fd;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 d6dfef5..43ac1f4 100644 --- a/dali-toolkit/internal/visuals/svg/svg-visual.h +++ b/dali-toolkit/internal/visuals/svg/svg-visual.h @@ -18,9 +18,12 @@ * */ +// EXTERNAL INCLUDES +#include +#include + // INTERNAL INCLUDES -#include -#include +#include struct NSVGimage; @@ -33,6 +36,9 @@ namespace Toolkit namespace Internal { +class SvgVisual; +typedef IntrusivePtr< SvgVisual > SvgVisualPtr; + /** * The visual which renders a svg image * @@ -43,74 +49,78 @@ namespace Internal * | url | STRING | * */ -class SvgVisual: public Visual +class SvgVisual: public Visual::Base { public: /** - * @brief Constructor. + * @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 */ - SvgVisual( VisualFactoryCache& factoryCache, ImageAtlasManager& atlasManager ); + static SvgVisualPtr New( VisualFactoryCache& factoryCache, const std::string& imageUrl ); + +public: // from Visual /** - * @brief A reference counted object may only be deleted by calling Unreference(). + * @copydoc Visual::Base::GetNaturalSize */ - ~SvgVisual(); - -public: // from Visual + virtual void GetNaturalSize( Vector2& naturalSize ); /** - * @copydoc Visual::GetNaturalSize + * @copydoc Visual::Base::CreatePropertyMap */ - virtual void GetNaturalSize( Vector2& naturalSize ) const; + virtual void DoCreatePropertyMap( Property::Map& map ) const; /** - * @copydoc Visual::SetSize + * @copydoc Visual::Base::DoSetProperty */ - virtual void SetSize( const Vector2& size ); + virtual void DoSetProperty( Dali::Property::Index index, const Dali::Property::Value& propertyValue ); /** - * @copydoc Visual::CreatePropertyMap + * @copydoc Visual::Base::DoGetProperty */ - virtual void DoCreatePropertyMap( Property::Map& map ) const; + virtual Dali::Property::Value DoGetProperty( Dali::Property::Index index ); protected: /** - * @copydoc Visual::DoInitialize + * @brief Constructor. + * + * @param[in] factoryCache A pointer pointing to the VisualFactoryCache object */ - virtual void DoInitialize( Actor& actor, const Property::Map& propertyMap ); + SvgVisual( VisualFactoryCache& factoryCache ); /** - * @copydoc Visual::DoSetOnStage + * @brief A reference counted object may only be deleted by calling Unreference(). */ - virtual void DoSetOnStage( Actor& actor ); + virtual ~SvgVisual(); /** - * @copydoc Visual::DoSetOffStage + * @copydoc Visual::Base::DoSetProperties */ - virtual void DoSetOffStage( Actor& actor ); + virtual void DoSetProperties( const Property::Map& propertyMap ); -public: + /** + * @copydoc Visual::Base::DoSetOnStage + */ + virtual void DoSetOnStage( Actor& actor ); /** - * @brief Helper method to determine whether the url indicate that it is a svg image. - * - * @param [in] url The URL of the image file. - * @return true if it is a svg image + * @copydoc Visual::Base::DoSetOffStage */ - static bool IsSvgUrl( const std::string& url ); + virtual void DoSetOffStage( Actor& actor ); /** - * @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 + * @copydoc Visual::Base::OnSetTransform */ - void SetImage( const std::string& imageUrl, ImageDimensions size = ImageDimensions() ); + virtual void OnSetTransform(); + +public: /** * @bried Apply the rasterized image to the visual. @@ -120,6 +130,14 @@ 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. + */ + void ParseFromUrl( const std::string& imageUrl ); + /** * @bried Rasterize the svg with the given size, and add it to the visual. * @@ -136,10 +154,10 @@ private: private: Vector4 mAtlasRect; - ImageAtlasManager& mAtlasManager; std::string mImageUrl; NSVGimage* mParsedImage; - + WeakHandle mPlacementActor; + Vector2 mVisualSize; }; } // namespace Internal