X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=dali-toolkit%2Finternal%2Ftext%2Frendering%2Fatlas%2Fatlas-glyph-manager.h;h=cc6f92fbc2f14256483d154b30d5d075a19003aa;hb=b5fd9045b672b657db6f6647ed57d0380d29a6aa;hp=c41415e1ce24f4819bca0819868704d9929f20a2;hpb=5fa82acc87ca7de63ce715bb3cb63a12ac36fbcf;p=platform%2Fcore%2Fuifw%2Fdali-toolkit.git diff --git a/dali-toolkit/internal/text/rendering/atlas/atlas-glyph-manager.h b/dali-toolkit/internal/text/rendering/atlas/atlas-glyph-manager.h index c41415e..cc6f92f 100644 --- a/dali-toolkit/internal/text/rendering/atlas/atlas-glyph-manager.h +++ b/dali-toolkit/internal/text/rendering/atlas/atlas-glyph-manager.h @@ -1,8 +1,8 @@ -#ifndef __DALI_TOOLKIT_ATLAS_GLYPH_MANAGER_H__ -#define __DALI_TOOLKIT_ATLAS_GLYPH_MANAGER_H__ +#ifndef DALI_TOOLKIT_ATLAS_GLYPH_MANAGER_H +#define DALI_TOOLKIT_ATLAS_GLYPH_MANAGER_H /* - * Copyright (c) 2015 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. @@ -24,35 +24,47 @@ namespace Dali { - namespace Toolkit { - namespace Internal DALI_INTERNAL { class AtlasGlyphManager; } - class AtlasGlyphManager : public BaseHandle { public: - /** * Description of GlyphManager state */ struct Metrics { Metrics() - : mGlyphCount( 0u ) - {} + : mGlyphCount(0u) + { + } ~Metrics() - {} + { + } + + uint32_t mGlyphCount; ///< number of glyphs being managed + std::string mVerboseGlyphCounts; ///< a verbose list of the glyphs + ref counts + AtlasManager::Metrics mAtlasMetrics; ///< metrics from the Atlas Manager + }; - uint32_t mGlyphCount; ///< number of glyphs being managed - std::string mVerboseGlyphCounts; ///< a verbose list of the glyphs + ref counts - AtlasManager::Metrics mAtlasMetrics; ///< metrics from the Atlas Manager + struct GlyphStyle + { + GlyphStyle() + : outline{0u}, + isItalic{false}, + isBold{false} + { + } + + uint16_t outline; ///< The outline width of this glyph + bool isItalic : 1; ///< Whether the glyph is italic. + bool isBold : 1; ///< Whether the glyph is bold. }; /** @@ -80,14 +92,14 @@ public: * @brief Ask Atlas Manager to add a glyph * * @param[in] glyph glyph to add to an atlas - * @param[in] outlineWidth the outline width of the glyph + * @param[in] style The style of this glyph * @param[in] bitmap bitmap to use for glyph addition * @param[out] slot information returned by atlas manager for addition */ - void Add( const Text::GlyphInfo& glyph, - const uint32_t outlineWidth, - const PixelData& bitmap, - AtlasManager::AtlasSlot& slot ); + void Add(const Text::GlyphInfo& glyph, + const GlyphStyle& style, + const PixelData& bitmap, + AtlasManager::AtlasSlot& slot); /** * @brief Generate mesh data for an image contained in an atlas @@ -96,24 +108,24 @@ public: * @param[in] position top left of image * @param[out] meshData generated MeshData */ - void GenerateMeshData( uint32_t imageId, - const Vector2& position, - Toolkit::AtlasManager::Mesh2D& mesh ); + void GenerateMeshData(uint32_t imageId, + const Vector2& position, + Toolkit::AtlasManager::Mesh2D& mesh); /** * @brief Check to see if a glyph is being cached * * @param[in] fontId The font that this glyph comes from * @param[in] index The GlyphIndex of this glyph - * @param[in] outlineWidth The outline width of this glyph + * @param[in] style The style of this glyph * @param[out] slot container holding information about the glyph( mImage = 0 indicates not being cached ) * * @return Whether glyph is cached or not ? */ - bool IsCached( Text::FontId fontId, - Text::GlyphIndex index, - uint32_t outlineWidth, - AtlasManager::AtlasSlot& slot ); + bool IsCached(Text::FontId fontId, + Text::GlyphIndex index, + const GlyphStyle& style, + AtlasManager::AtlasSlot& slot); /** * @brief Retrieve the size of an atlas @@ -122,9 +134,9 @@ public: * * @return The pixel size of the atlas */ - Vector2 GetAtlasSize( uint32_t atlasId ); + Vector2 GetAtlasSize(uint32_t atlasId); - /** + /** * @brief Set the atlas size and block size for subsequent Atlas generation * * @param[in] width width of atlas in pixels @@ -132,7 +144,7 @@ public: * @param[in] blockWidth width of a block in pixels * @param[in] blockHeight height of a block in pixels */ - void SetNewAtlasSize( uint32_t width, uint32_t height, uint32_t blockWidth, uint32_t blockHeight ); + void SetNewAtlasSize(uint32_t width, uint32_t height, uint32_t blockWidth, uint32_t blockHeight); /** * @brief Get the Pixel Format used by an atlas @@ -141,7 +153,7 @@ public: * * @return The pixel format of the atlas */ - Pixel::Format GetPixelFormat( uint32_t atlasId ); + Pixel::Format GetPixelFormat(uint32_t atlasId); /** * @brief Get the texture set used by an atlas @@ -150,7 +162,7 @@ public: * * @return The texture set used by the atlas */ - TextureSet GetTextures( uint32_t atlasId ) const; + TextureSet GetTextures(uint32_t atlasId) const; /** * @brief Get Glyph Manager metrics @@ -164,19 +176,17 @@ public: * * @param[in] fontId The font this image came from * @param[in] index The index of the glyph - * @param[in] outlineWidth The outline width of the glyph + * @param[in] style The style of this glyph * @param[in] delta The adjustment to make to the reference count */ - void AdjustReferenceCount( Text::FontId fontId, Text::GlyphIndex index, uint32_t outlineWidth, int32_t delta ); + void AdjustReferenceCount(Text::FontId fontId, Text::GlyphIndex index, const GlyphStyle& style, int32_t delta); private: - - explicit DALI_INTERNAL AtlasGlyphManager(Internal::AtlasGlyphManager *impl); - + explicit DALI_INTERNAL AtlasGlyphManager(Internal::AtlasGlyphManager* impl); }; } // namespace Toolkit } // namespace Dali -#endif // __DALI_TOOLKIT_ATLAS_GLYPH_MANAGER_H__ +#endif // DALI_TOOLKIT_ATLAS_GLYPH_MANAGER_H