X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;ds=sidebyside;f=dali-toolkit%2Finternal%2Ftext%2Frendering%2Fatlas%2Fatlas-glyph-manager-impl.h;h=5008106a5d2cda40aeaaeca12eed65d3edbebe91;hb=526a64a21247c78086bbee7a2bcc7ca13142f3ed;hp=c4da1ba9413402d8ed732fca82442063e0d97153;hpb=3b1fb566901d21b8303d9be3308e3920f5182e6d;p=platform%2Fcore%2Fuifw%2Fdali-toolkit.git diff --git a/dali-toolkit/internal/text/rendering/atlas/atlas-glyph-manager-impl.h b/dali-toolkit/internal/text/rendering/atlas/atlas-glyph-manager-impl.h index c4da1ba..5008106 100644 --- a/dali-toolkit/internal/text/rendering/atlas/atlas-glyph-manager-impl.h +++ b/dali-toolkit/internal/text/rendering/atlas/atlas-glyph-manager-impl.h @@ -49,11 +49,17 @@ class AtlasGlyphManager : public Dali::BaseObject { public: - struct GlyphRecord + struct GlyphRecordEntry { - Text::FontId mFontId; Text::GlyphIndex mIndex; uint32_t mImageId; + int32_t mCount; + }; + + struct FontGlyphRecord + { + Text::FontId mFontId; + Vector< GlyphRecordEntry > mGlyphRecords; }; AtlasGlyphManager(); @@ -68,7 +74,8 @@ public: /** * @copydoc Toolkit::AtlasGlyphManager::Add */ - void Add( const Text::GlyphInfo& glyph, + void Add( Text::FontId fontId, + const Text::GlyphInfo& glyph, const BufferImage& bitmap, Dali::Toolkit::AtlasManager::AtlasSlot& slot ); @@ -88,31 +95,41 @@ public: /** * @copydoc Toolkit::AtlasGlyphManager::Cached */ - void Cached( Text::FontId fontId, + bool Cached( Text::FontId fontId, Text::GlyphIndex index, Dali::Toolkit::AtlasManager::AtlasSlot& slot ); /** - * @copydoc Toolkit::AtlasGlyphManager::SetAtlasSize + * @copydoc Toolkit::AtlasGlyphManager::GetAtlasSize */ - void SetAtlasSize( const Vector2& size, - const Vector2& blockSize ); + Vector2 GetAtlasSize( uint32_t atlasId ); /** - * @copydoc Toolkit::AtlasGlyphManager::Remove + * @copydoc Toolkit::AtlasGlyphManager::SetNewAtlasSize */ - void Remove( uint32_t imageId ); + void SetNewAtlasSize( uint32_t width, uint32_t height, uint32_t blockWidth, uint32_t blockHeight ); /** * @copydoc toolkit::AtlasGlyphManager::GetPixelFormat */ Pixel::Format GetPixelFormat( uint32_t atlasId ); + /** + * @copydoc toolkit::AtlasGlyphManager::GetMetrics + */ + const Toolkit::AtlasGlyphManager::Metrics& GetMetrics(); + + /** + * @copydoc toolkit::AtlasGlyphManager::AdjustReferenceCount + */ + void AdjustReferenceCount( Text::FontId fontId, uint32_t imageId, int32_t delta ); + private: Dali::Toolkit::AtlasManager mAtlasManager; - Vector< GlyphRecord > mGlyphRecords; + std::vector< FontGlyphRecord > mFontGlyphRecords; uint32_t mCount; + Toolkit::AtlasGlyphManager::Metrics mMetrics; }; } // namespace Internal