X-Git-Url: http://review.tizen.org/git/?p=platform%2Fcore%2Fuifw%2Fdali-toolkit.git;a=blobdiff_plain;f=dali-toolkit%2Finternal%2Fvisuals%2Ftext%2Ftext-visual.h;h=7304f0f6fa00a117705484826d357c17fa6f1018;hp=6f47e45180e2330993a5c5a6b62240737b2c1ec2;hb=37cb9a8e7c94ea7153434d6b0b87a6f08bb9191f;hpb=072e6002280ed51a637ed54e0451bdbbe3c4ec79 diff --git a/dali-toolkit/internal/visuals/text/text-visual.h b/dali-toolkit/internal/visuals/text/text-visual.h index 6f47e45..7304f0f 100644 --- a/dali-toolkit/internal/visuals/text/text-visual.h +++ b/dali-toolkit/internal/visuals/text/text-visual.h @@ -2,7 +2,7 @@ #define DALI_TOOLKIT_INTERNAL_TEXT_VISUAL_H /* - * Copyright (c) 2019 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. @@ -19,25 +19,23 @@ */ // EXTERNAL INCLUDES +#include #include #include // INTERNAL INCLUDES -#include #include #include +#include namespace Dali { - namespace Toolkit { - namespace Internal { - class TextVisual; -typedef IntrusivePtr< TextVisual > TextVisualPtr; +typedef IntrusivePtr TextVisualPtr; /** * The visual which renders text @@ -69,7 +67,6 @@ typedef IntrusivePtr< TextVisual > TextVisualPtr; class TextVisual : public Visual::Base { public: - /** * @brief Create a new text visual. * @@ -77,22 +74,23 @@ public: * @param[in] properties A Property::Map containing settings for this visual * @return A smart-pointer to the newly allocated visual. */ - static TextVisualPtr New( VisualFactoryCache& factoryCache, const Property::Map& properties ); + static TextVisualPtr New(VisualFactoryCache& factoryCache, const Property::Map& properties); /** * @brief Converts all strings keys in property map to index keys. Property Map can then be merged correctly. - * @param[in,out] propertyMap containing string keys or a mix of strings and indexes. Will be changed to index keys. + * @param[in] propertyMap containing string keys or a mix of strings and indexes. + * @return Property::Map containing index keys. */ - static void ConvertStringKeysToIndexKeys( Property::Map& propertyMap ); + static Property::Map ConvertStringKeysToIndexKeys(const Property::Map& propertyMap); /** * @brief Retrieve the text's controller. * @param[in] visual The text visual. * @return The text controller */ - static Text::ControllerPtr GetController( Toolkit::Visual::Base visual ) + static Text::ControllerPtr GetController(Toolkit::Visual::Base visual) { - return GetVisualObject( visual ).mController; + return GetVisualObject(visual).mController; }; /** @@ -100,81 +98,84 @@ public: * @param[in] visual The text visual. * @param[in] animatablePropertyIndex The index of the animatable property */ - static void SetAnimatableTextColorProperty( Toolkit::Visual::Base visual, Property::Index animatablePropertyIndex ) + static void SetAnimatableTextColorProperty(Toolkit::Visual::Base visual, Property::Index animatablePropertyIndex) { - GetVisualObject( visual ).mAnimatableTextColorPropertyIndex = animatablePropertyIndex; + GetVisualObject(visual).mAnimatableTextColorPropertyIndex = animatablePropertyIndex; }; /** * @brief Set the flag to trigger the textures to be initialized and renderer to be added to the control. * @param[in] visual The text visual. */ - static void EnableRendererUpdate( Toolkit::Visual::Base visual ) + static void EnableRendererUpdate(Toolkit::Visual::Base visual) { - GetVisualObject( visual ).mRendererUpdateNeeded = true; + GetVisualObject(visual).mRendererUpdateNeeded = true; }; /** * @brief Instantly updates the renderer * @param[in] visual The text visual. */ - static void UpdateRenderer( Toolkit::Visual::Base visual ) + static void UpdateRenderer(Toolkit::Visual::Base visual) { - GetVisualObject( visual ).UpdateRenderer(); + GetVisualObject(visual).UpdateRenderer(); }; public: // from Visual::Base - /** * @copydoc Visual::Base::GetHeightForWidth() */ - float GetHeightForWidth( float width ) override; + float GetHeightForWidth(float width) override; /** * @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: - /** * @brief Constructor. * * @param[in] factoryCache The VisualFactoryCache object */ - TextVisual( VisualFactoryCache& factoryCache ); + TextVisual(VisualFactoryCache& factoryCache); /** * @brief A reference counted object may only be deleted by calling Unreference(). */ virtual ~TextVisual(); + /** + * @copydoc Visual::Base::OnInitialize + */ + void OnInitialize() override; + // from Visual::Base /** * @copydoc Visual::Base::DoSetProperties() */ - void DoSetProperties( const Property::Map& propertyMap ) override; + void DoSetProperties(const Property::Map& propertyMap) override; /** - * @copydoc Visual::Base::DoSetOnStage() + * @copydoc Visual::Base::DoSetOnScene() */ - void DoSetOnStage( Actor& actor ) override; + void DoSetOnScene(Actor& actor) override; /** - * @copydoc Visual::Base::DoSetOffStage() + * @copydoc Visual::Base::DoSetOffScene() */ - void DoSetOffStage( Actor& actor ) override; + void DoSetOffScene(Actor& actor) override; /** * @copydoc Visual::Base::OnSetTransform @@ -182,6 +183,46 @@ protected: void OnSetTransform() override; private: + struct TilingInfo + { + unsigned char* textBuffer; + unsigned char* styleBuffer; + unsigned char* maskBuffer; + int width; + int height; + Pixel::Format textPixelFormat; + int offsetPosition; + Vector2 offSet; + + TilingInfo(int width, int height, Pixel::Format textPixelFormat) + : textBuffer(NULL), + styleBuffer(NULL), + maskBuffer(NULL), + width(width), + height(height), + textPixelFormat(textPixelFormat), + offsetPosition(0), + offSet(0.f, 0.f) + { + } + + ~TilingInfo() + { + if(textBuffer) + { + free(textBuffer); + } + if(styleBuffer) + { + free(styleBuffer); + } + if(maskBuffer) + { + free(maskBuffer); + } + } + }; + /** * @brief Set the individual property to the given value. * @@ -189,7 +230,7 @@ private: * * @param[in] propertyValue The value to set. */ - void DoSetProperty( Dali::Property::Index index, const Dali::Property::Value& propertyValue ); + void DoSetProperty(Dali::Property::Index index, const Dali::Property::Value& propertyValue); /** * @brief Updates the text's renderer. @@ -197,9 +238,49 @@ private: void UpdateRenderer(); /** - * @brief Removes the texture set from the renderer. + * @brief Removes the text's renderer. + */ + void RemoveRenderer(Actor& actor); + + /** + * @brief Create a texture in textureSet and add it. + * @param[in] textureSet The textureSet to which the texture will be added. + * @param[in] data The PixelData to be uploaded to texture + * @param[in] sampler The sampler. + * @param[in] textureSetIndex The Index of TextureSet. + */ + void AddTexture(TextureSet& textureSet, PixelData& data, Sampler& sampler, unsigned int textureSetIndex); + + /** + * @brief Convert the buffer to pixelData. + * @param[in] buffer The Buffer to be converted to pixelData. + * @param[in] width The width of pixel data. + * @param[in] height The height of pixel data. + * @param[in] offsetPosition The The buffer's start position. + * @param[in] textPixelFormat The PixelForma of text. + */ + PixelData ConvertToPixelData(unsigned char* buffer, int width, int height, int offsetPosition, const Pixel::Format textPixelFormat); + + /** + * @brief Create the text's texture. + * @param[in] info This is the information you need to create a Tiling. + * @param[in] renderer The renderer to which the TextureSet will be added. + * @param[in] sampler The sampler. + * @param[in] hasMultipleTextColors Whether the text contains multiple colors. + * @param[in] containsColorGlyph Whether the text contains color glyph. + * @param[in] styleEnabled Whether the text contains any styles (e.g. shadow, underline, etc.). + */ + void CreateTextureSet(TilingInfo& info, Renderer& renderer, Sampler& sampler, bool hasMultipleTextColors, bool containsColorGlyph, bool styleEnabled); + + /** + * Create renderer of the text for rendering. + * @param[in] actor The actor. + * @param[in] size The texture size. + * @param[in] hasMultipleTextColors Whether the text contains multiple colors. + * @param[in] containsColorGlyph Whether the text contains color glyph. + * @param[in] styleEnabled Whether the text contains any styles (e.g. shadow, underline, etc.). */ - void RemoveTextureSet(); + void AddRenderer(Actor& actor, const Vector2& size, bool hasMultipleTextColors, bool containsColorGlyph, bool styleEnabled); /** * Get the texture of the text for rendering. @@ -208,7 +289,7 @@ private: * @param[in] containsColorGlyph Whether the text contains color glyph. * @param[in] styleEnabled Whether the text contains any styles (e.g. shadow, underline, etc.). */ - TextureSet GetTextTexture( const Vector2& size, bool hasMultipleTextColors, bool containsColorGlyph, bool styleEnabled ); + TextureSet GetTextTexture(const Vector2& size, bool hasMultipleTextColors, bool containsColorGlyph, bool styleEnabled); /** * Get the text rendering shader. @@ -217,19 +298,20 @@ private: * @param[in] containsColorGlyph Whether the text contains color glyph. * @param[in] styleEnabled Whether the text contains any styles (e.g. shadow, underline, etc.). */ - Shader GetTextShader( VisualFactoryCache& factoryCache, bool hasMultipleTextColors, bool containsColorGlyph, bool styleEnabled ); + Shader GetTextShader(VisualFactoryCache& factoryCache, bool hasMultipleTextColors, bool containsColorGlyph, bool styleEnabled); /** * @brief Retrieve the TextVisual object. * @param[in] visual A handle to the TextVisual * @return The TextVisual object */ - static TextVisual& GetVisualObject( Toolkit::Visual::Base visual ) + static TextVisual& GetVisualObject(Toolkit::Visual::Base visual) { - return static_cast< TextVisual& >( Toolkit::GetImplementation( visual ).GetVisualObject() ); + return static_cast(Toolkit::GetImplementation(visual).GetVisualObject()); }; private: + typedef std::vector RendererContainer; /** * Used as an alternative to boolean so that it is obvious whether the text contains single or multiple text colors, and emoji and styles. @@ -239,20 +321,23 @@ private: enum Type { SINGLE_COLOR_TEXT = 0, ///< The text contains single color only. - MULTI_COLOR_TEXT = 1, ///< The text contains multiple colors. - NO_EMOJI = 0, ///< The text contains no emoji. - HAS_EMOJI = 1, ///< The text contains emoji. - NO_STYLES = 0, ///< The text contains contains no styles. - HAS_SYLES = 1 ///< The text contains contains styles. + MULTI_COLOR_TEXT = 1, ///< The text contains multiple colors. + NO_EMOJI = 0, ///< The text contains no emoji. + HAS_EMOJI = 1, ///< The text contains emoji. + NO_STYLES = 0, ///< The text contains contains no styles. + HAS_SYLES = 1 ///< The text contains contains styles. }; }; private: - Text::ControllerPtr mController; ///< The text's controller. - Text::TypesetterPtr mTypesetter; ///< The text's typesetter. - WeakHandle mControl; ///< The control where the renderer is added. - Property::Index mAnimatableTextColorPropertyIndex; ///< The index of animatable text color property registered by the control. - bool mRendererUpdateNeeded:1; ///< The flag to indicate whether the renderer needs to be updated. + Text::ControllerPtr mController; ///< The text's controller. + Text::TypesetterPtr mTypesetter; ///< The text's typesetter. + WeakHandle mControl; ///< The control where the renderer is added. + Constraint mColorConstraint{}; ///< Color constraint + Constraint mOpacityConstraint{}; ///< Opacity constraint + Property::Index mAnimatableTextColorPropertyIndex; ///< The index of animatable text color property registered by the control. + bool mRendererUpdateNeeded : 1; ///< The flag to indicate whether the renderer needs to be updated. + RendererContainer mRendererList; }; } // namespace Internal