X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=dali-toolkit%2Finternal%2Fvisuals%2Fcolor%2Fcolor-visual.h;h=11e43d326662bf00a0e0e28a1e6cf683f5aad17d;hb=2ca1c3856ce848a94f54444f1014a820e91ee207;hp=cf2b0578c329332f7f8269106bcf8529bcbd6dd8;hpb=b15279dd1e820bebf41aeb78453f997fe50051ae;p=platform%2Fcore%2Fuifw%2Fdali-toolkit.git diff --git a/dali-toolkit/internal/visuals/color/color-visual.h b/dali-toolkit/internal/visuals/color/color-visual.h index cf2b057..11e43d3 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) 2016 Samsung Electronics Co., Ltd. + * Copyright (c) 2021 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. @@ -53,31 +53,22 @@ public: * @brief Create a new color visual. * * @param[in] factoryCache A pointer pointing to the VisualFactoryCache object + * @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 ); + static ColorVisualPtr New( VisualFactoryCache& factoryCache, const Property::Map& properties ); public: // from Visual /** - * @copydoc Visual::Base::SetSize - */ - virtual void SetSize( const Vector2& size ); - - /** * @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 ); + void DoCreatePropertyMap( Property::Map& map ) const override; /** - * @copydoc Visual::Base::DoGetProperty + * @copydoc Visual::Base::CreateInstancePropertyMap */ - virtual Dali::Property::Value DoGetProperty( Dali::Property::Index index ); + void DoCreateInstancePropertyMap( Property::Map& map ) const override; protected: @@ -94,28 +85,52 @@ protected: virtual ~ColorVisual(); /** + * @copydoc Visual::Base::OnInitialize + */ + void OnInitialize() override; + + /** * @copydoc Visual::Base::DoSetProperties */ - virtual void DoSetProperties( const Property::Map& propertyMap ); + void DoSetProperties( const Property::Map& propertyMap ) override; /** - * @copydoc Visual::Base::DoSetOnStage + * @copydoc Visual::Base::DoSetOnScene */ - virtual void DoSetOnStage( Actor& actor ); + void DoSetOnScene( Actor& actor ) override; -public: + /** + * @copydoc Visual::Base::DoSetOffScene + */ + void DoSetOffScene(Actor& actor) override; /** - * Set the color for rendering. - * @param[in] color The color to be rendered. + * @copydoc Visual::Base::OnSetTransform */ - void SetColor( const Vector4& color ); + void OnSetTransform() override; + + /** + * @copydoc Visual::Base::OnDoAction + */ + void OnDoAction( const Property::Index actionId, const Property::Value& attributes ) override; + + /** + * @copydoc Visual::Base::UpdateShader + */ + void UpdateShader() override; + + /** + * @copydoc Visual::Base::OnGetPropertyObject + */ + Dali::Property OnGetPropertyObject(Dali::Property::Key key) 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. + * @brief Get a shader for the current properties. + * @return The shader for the current properties. */ - void InitializeRenderer(); + Shader GetShader(); private: @@ -126,10 +141,10 @@ private: ColorVisual& operator=( const ColorVisual& colorRenderer ); private: - - Vector4 mMixColor; - Property::Index mMixColorIndex; - + float mBlurRadius; ///< The blur radius + Property::Index mBlurRadiusIndex; ///< The blur radius property index + bool mRenderIfTransparent; ///< Whether we should render even if the mix-color is transparent. + bool mNeedBlurRadius; ///< Whether we need the blur radius in shader. }; } // namespace Internal