X-Git-Url: http://review.tizen.org/git/?p=platform%2Fcore%2Fuifw%2Fdali-toolkit.git;a=blobdiff_plain;f=dali-toolkit%2Finternal%2Fvisuals%2Fcolor%2Fcolor-visual.h;h=0a8a8b2d0280237895015b8352b5af31bab96224;hp=05c8ba9558e6e42a0dda464321fa6194e932176e;hb=5a936aac073676657d48db5c42e5d2ad3f5cac9f;hpb=954a8e25f7e32579a4a9276db09f43d45a19d2a0 diff --git a/dali-toolkit/internal/visuals/color/color-visual.h b/dali-toolkit/internal/visuals/color/color-visual.h index 05c8ba9..0a8a8b2 100644 --- a/dali-toolkit/internal/visuals/color/color-visual.h +++ b/dali-toolkit/internal/visuals/color/color-visual.h @@ -2,7 +2,7 @@ #define DALI_TOOLKIT_INTERNAL_COLOR_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. @@ -26,15 +26,12 @@ namespace Dali { - namespace Toolkit { - namespace Internal { - class ColorVisual; -typedef IntrusivePtr< ColorVisual > ColorVisualPtr; +typedef IntrusivePtr ColorVisualPtr; /** * The visual which renders a solid color to the control's quad @@ -45,10 +42,9 @@ typedef IntrusivePtr< ColorVisual > ColorVisualPtr; * |-----------------|-------------| * | mixColor | VECTOR4 | */ -class ColorVisual: public Visual::Base +class ColorVisual : public Visual::Base { public: - /** * @brief Create a new color visual. * @@ -56,28 +52,31 @@ public: * @param[in] properties A Property::Map containing settings for this visual * @return A smart-pointer to the newly allocated visual. */ - static ColorVisualPtr New( VisualFactoryCache& factoryCache, const Property::Map& properties ); - -public: // from Visual + static ColorVisualPtr New(VisualFactoryCache& factoryCache, const Property::Map& properties); +public: // from Visual /** * @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. * * @param[in] factoryCache A pointer pointing to the VisualFactoryCache object */ - ColorVisual( VisualFactoryCache& factoryCache ); + ColorVisual(VisualFactoryCache& factoryCache); /** * @brief A reference counted object may only be deleted by calling Unreference(). @@ -85,38 +84,63 @@ protected: virtual ~ColorVisual(); /** + * @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; /** - * @copydoc Visual::Base::DoSetOnStage + * @copydoc Visual::Base::DoSetOffScene */ - void DoSetOnStage( Actor& actor ) override; + void DoSetOffScene(Actor& actor) override; /** * @copydoc Visual::Base::OnSetTransform */ void OnSetTransform() override; -private: /** - * @brief Initialize the renderer with the geometry and shader from the cache, if not available, create and save to the cache for sharing. + * @copydoc Visual::Base::UpdateShader */ - void InitializeRenderer(); + void UpdateShader() override; -private: + /** + * @copydoc Visual::Base::GenerateShader + */ + Shader GenerateShader() const override; + + /** + * @copydoc Visual::Base::OnGetPropertyObject + */ + Dali::Property OnGetPropertyObject(Dali::Property::Key key) override; +protected: + /** + * @brief Query whether the visual requires to be blur. + * + * @return Returns true if the blur is required, false otherwise. + */ + bool IsBlurRequired() const; + +private: // Undefined - ColorVisual( const ColorVisual& colorRenderer ); + ColorVisual(const ColorVisual& colorRenderer); // Undefined - ColorVisual& operator=( const ColorVisual& colorRenderer ); + ColorVisual& operator=(const ColorVisual& colorRenderer); private: - - float mBlurRadius; ///< The blur radius - bool mRenderIfTransparent; ///< Whether we should render even if the mix-color is transparent. + float mBlurRadius; ///< The blur radius + bool mAlwaysUsingBlurRadius : 1; ///< Whether we need the blur radius in shader always. }; } // namespace Internal