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=c005691864e9bcd00e2291a8068414a25865c755;hp=814fc675d146208a217d3d4a42aac697d20e6456;hb=24e9ef34e2b4283a03e2d62f4782fccb5a72d67d;hpb=8fea8f2ae64923690519e0de039ce4af51271d9f diff --git a/dali-toolkit/internal/visuals/svg/svg-visual.h b/dali-toolkit/internal/visuals/svg/svg-visual.h index 814fc67..c005691 100644 --- a/dali-toolkit/internal/visuals/svg/svg-visual.h +++ b/dali-toolkit/internal/visuals/svg/svg-visual.h @@ -2,7 +2,7 @@ #define DALI_TOOLKIT_INTERNAL_SVG_VISUAL_H /* - * Copyright (c) 2020 Samsung Electronics Co., Ltd. + * Copyright (c) 2022 Samsung Electronics Co., Ltd. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -28,16 +28,13 @@ namespace Dali { - namespace Toolkit { - namespace Internal { - class ImageVisualShaderFactory; class SvgVisual; -typedef IntrusivePtr< SvgVisual > SvgVisualPtr; +typedef IntrusivePtr SvgVisualPtr; /** * The visual which renders a svg image @@ -49,10 +46,9 @@ typedef IntrusivePtr< SvgVisual > SvgVisualPtr; * | url | STRING | * */ -class SvgVisual: public Visual::Base +class SvgVisual : public Visual::Base { public: - /** * @brief Create the SVG Visual using the image URL. * @@ -65,7 +61,7 @@ public: * @param[in] properties A Property::Map containing settings for this visual * @return A smart-pointer to the newly allocated visual. */ - static SvgVisualPtr New( VisualFactoryCache& factoryCache, ImageVisualShaderFactory& shaderFactory, const VisualUrl& imageUrl, const Property::Map& properties ); + static SvgVisualPtr New(VisualFactoryCache& factoryCache, ImageVisualShaderFactory& shaderFactory, const VisualUrl& imageUrl, const Property::Map& properties); /** * @brief Create the SVG Visual using the image URL. @@ -78,27 +74,30 @@ public: * @param[in] imageUrl The URL to svg resource to use * @return A smart-pointer to the newly allocated visual. */ - static SvgVisualPtr New( VisualFactoryCache& factoryCache, ImageVisualShaderFactory& shaderFactory, const VisualUrl& imageUrl ); - -public: // from Visual + static SvgVisualPtr New(VisualFactoryCache& factoryCache, ImageVisualShaderFactory& shaderFactory, const VisualUrl& imageUrl); +public: // from Visual /** * @copydoc Visual::Base::GetNaturalSize */ - void GetNaturalSize( Vector2& naturalSize ) override; + void GetNaturalSize(Vector2& naturalSize) override; /** * @copydoc Visual::Base::CreatePropertyMap */ - void DoCreatePropertyMap( Property::Map& map ) const override; + void DoCreatePropertyMap(Property::Map& map) const override; /** * @copydoc Visual::Base::CreateInstancePropertyMap */ - void DoCreateInstancePropertyMap( Property::Map& map ) const override; + void DoCreateInstancePropertyMap(Property::Map& map) const override; -protected: + /** + * @copydoc Visual::Base::EnablePreMultipliedAlpha + */ + void EnablePreMultipliedAlpha(bool preMultiplied) override; +protected: /** * @brief Constructor. * @@ -106,7 +105,7 @@ protected: * @param[in] shaderFactory The ImageVisualShaderFactory object * @param[in] imageUrl The URL to svg resource to use */ - SvgVisual( VisualFactoryCache& factoryCache, ImageVisualShaderFactory& shaderFactory, const VisualUrl& imageUrl ); + SvgVisual(VisualFactoryCache& factoryCache, ImageVisualShaderFactory& shaderFactory, const VisualUrl& imageUrl); /** * @brief A reference counted object may only be deleted by calling Unreference(). @@ -114,19 +113,24 @@ protected: virtual ~SvgVisual(); /** + * @copydoc Visual::Base::OnInitialize + */ + void OnInitialize() override; + + /** * @copydoc Visual::Base::DoSetProperties */ - void DoSetProperties( const Property::Map& propertyMap ) override; + void DoSetProperties(const Property::Map& propertyMap) override; /** * @copydoc Visual::Base::DoSetOnScene */ - void DoSetOnScene( Actor& actor ) override; + void DoSetOnScene(Actor& actor) override; /** * @copydoc Visual::Base::DoSetOffScene */ - void DoSetOffScene( Actor& actor ) override; + void DoSetOffScene(Actor& actor) override; /** * @copydoc Visual::Base::OnSetTransform @@ -134,12 +138,16 @@ protected: void OnSetTransform() override; /** - * @copydoc Visual::Base::IsResourceReady + * @copydoc Visual::Base::UpdateShader */ - bool IsResourceReady() const override; + void UpdateShader() override; -public: + /** + * @copydoc Visual::Base::GenerateShader + */ + Shader GenerateShader() const override; +public: /** * @bried Apply the rasterized image to the visual. * @@ -147,7 +155,7 @@ public: * @param[in] rasterizedPixelData The pixel buffer with the rasterized pixels * @param[in] bool Whether the resource is loaded */ - void ApplyRasterizedImage( VectorImageRenderer vectorImage, PixelData rasterizedPixelData, bool isLoaded ); + void ApplyRasterizedImage(VectorImageRenderer vectorImage, PixelData rasterizedPixelData, bool isLoaded); private: /** @@ -160,20 +168,20 @@ private: * * @param[in] size The target size of the SVG rasterization. */ - void AddRasterizationTask( const Vector2& size ); + void AddRasterizationTask(const Vector2& size); /** * Helper method to set individual values by index key. * @param[in] index The index key of the value * @param[in] value The value */ - void DoSetProperty( Property::Index index, const Property::Value& value ); + void DoSetProperty(Property::Index index, const Property::Value& value); // Undefined - SvgVisual( const SvgVisual& svgRenderer ); + SvgVisual(const SvgVisual& svgRenderer); // Undefined - SvgVisual& operator=( const SvgVisual& svgRenderer ); + SvgVisual& operator=(const SvgVisual& svgRenderer); private: ImageVisualShaderFactory& mImageVisualShaderFactory; @@ -182,10 +190,10 @@ private: VectorImageRenderer mVectorRenderer; uint32_t mDefaultWidth; uint32_t mDefaultHeight; - bool mLoaded; WeakHandle mPlacementActor; Vector2 mVisualSize; - bool mAttemptAtlasing; ///< If true will attempt atlasing, otherwise create unique texture + bool mLoadFailed; + bool mAttemptAtlasing; ///< If true will attempt atlasing, otherwise create unique texture }; } // namespace Internal