X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=dali-toolkit%2Finternal%2Ftext%2Frendering%2Fatlas%2Fatlas-glyph-manager.h;h=592017bcf7c7aeec9ce4ea103ac6ff280b7a2fba;hb=e25442b0c940c46d7ae4ae2e7fb48688665d69e8;hp=1870bd514dece91f058d715198634c8324dab632;hpb=aae67693a392087235a203195366691f2dc9f91f;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 1870bd5..592017b 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) 2019 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. @@ -55,6 +55,19 @@ public: 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. + }; + /** * @brief Create a AtlasGlyphManager handle. * @@ -80,11 +93,13 @@ public: * @brief Ask Atlas Manager to add a glyph * * @param[in] glyph glyph to add to an atlas + * @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 BufferImage& bitmap, + const GlyphStyle& style, + const PixelData& bitmap, AtlasManager::AtlasSlot& slot ); /** @@ -103,12 +118,14 @@ public: * * @param[in] fontId The font that this glyph comes from * @param[in] index The GlyphIndex 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, + const GlyphStyle& style, AtlasManager::AtlasSlot& slot ); /** @@ -140,13 +157,13 @@ public: Pixel::Format GetPixelFormat( uint32_t atlasId ); /** - * @brief Get the material used by an atlas + * @brief Get the texture set used by an atlas * * @param[in] atlasId Id of an atlas * - * @return The material used by the atlas + * @return The texture set used by the atlas */ - Material GetMaterial( uint32_t atlasId ) const; + TextureSet GetTextures( uint32_t atlasId ) const; /** * @brief Get Glyph Manager metrics @@ -160,9 +177,10 @@ public: * * @param[in] fontId The font this image came from * @param[in] index The index 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, int32_t delta ); + void AdjustReferenceCount( Text::FontId fontId, Text::GlyphIndex index, const GlyphStyle& style, int32_t delta ); private: @@ -174,4 +192,4 @@ private: } // namespace Dali -#endif // __DALI_TOOLKIT_ATLAS_GLYPH_MANAGER_H__ +#endif // DALI_TOOLKIT_ATLAS_GLYPH_MANAGER_H