/*
- * Copyright (c) 2017 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.
#include <dali/internal/text/text-abstraction/font-client-impl.h>
// EXTERNAL INCLUDES
-#ifndef DALI_PROFILE_UBUNTU
+#if !(defined(DALI_PROFILE_UBUNTU) || defined(ANDROID) || defined(WIN32) || defined(__APPLE__))
#include <vconf.h>
#endif
// INTERNAL INCLUDES
-#include <dali/devel-api/adaptor-framework/singleton-service.h>
+#include <dali/devel-api/common/singleton-service.h>
#include <dali/internal/text/text-abstraction/font-client-plugin-impl.h>
+#include <dali/devel-api/text-abstraction/glyph-info.h>
+
namespace Dali
{
-
namespace TextAbstraction
{
-
namespace Internal
{
+Dali::TextAbstraction::FontClient FontClient::gPreInitializedFontClient(NULL);
FontClient::FontClient()
-: mPlugin( nullptr ),
- mDpiHorizontal( 0 ),
- mDpiVertical( 0 )
+: mPlugin(nullptr),
+ mDpiHorizontal(0),
+ mDpiVertical(0)
{
}
{
Dali::TextAbstraction::FontClient fontClientHandle;
- Dali::SingletonService service( SingletonService::Get() );
- if ( service )
+ Dali::SingletonService service(SingletonService::Get());
+ if(service)
{
// Check whether the singleton is already created
- Dali::BaseHandle handle = service.GetSingleton( typeid( Dali::TextAbstraction::FontClient ) );
+ Dali::BaseHandle handle = service.GetSingleton(typeid(Dali::TextAbstraction::FontClient));
if(handle)
{
// If so, downcast the handle
- FontClient* impl = dynamic_cast< Dali::TextAbstraction::Internal::FontClient* >( handle.GetObjectPtr() );
- fontClientHandle = Dali::TextAbstraction::FontClient( impl );
+ FontClient* impl = dynamic_cast<Dali::TextAbstraction::Internal::FontClient*>(handle.GetObjectPtr());
+ fontClientHandle = Dali::TextAbstraction::FontClient(impl);
}
else // create and register the object
{
- fontClientHandle = Dali::TextAbstraction::FontClient( new FontClient );
- service.Register( typeid( fontClientHandle ), fontClientHandle );
+ if(gPreInitializedFontClient)
+ {
+ fontClientHandle = gPreInitializedFontClient;
+ gPreInitializedFontClient.Reset(); // No longer needed
+ }
+ else
+ {
+ fontClientHandle = Dali::TextAbstraction::FontClient(new FontClient);
+ }
+
+ service.Register(typeid(fontClientHandle), fontClientHandle);
}
}
return fontClientHandle;
}
-void FontClient::SetDpi( unsigned int horizontalDpi, unsigned int verticalDpi )
+Dali::TextAbstraction::FontClient FontClient::PreInitialize()
+{
+ gPreInitializedFontClient = Dali::TextAbstraction::FontClient(new FontClient);
+
+ // Make DefaultFontDescription cached
+ Dali::TextAbstraction::FontDescription defaultFontDescription;
+ gPreInitializedFontClient.GetDefaultPlatformFontDescription(defaultFontDescription);
+
+ return gPreInitializedFontClient;
+}
+
+void FontClient::ClearCache()
+{
+ if(mPlugin)
+ {
+ mPlugin->ClearCache();
+ }
+}
+
+void FontClient::SetDpi(unsigned int horizontalDpi, unsigned int verticalDpi)
{
mDpiHorizontal = horizontalDpi;
- mDpiVertical = verticalDpi;
+ mDpiVertical = verticalDpi;
// Allow DPI to be set without loading plugin
- if( mPlugin )
+ if(mPlugin)
{
- mPlugin->SetDpi( horizontalDpi, verticalDpi );
+ mPlugin->SetDpi(horizontalDpi, verticalDpi);
}
}
-void FontClient::GetDpi( unsigned int& horizontalDpi, unsigned int& verticalDpi )
+void FontClient::GetDpi(unsigned int& horizontalDpi, unsigned int& verticalDpi)
{
horizontalDpi = mDpiHorizontal;
- verticalDpi = mDpiVertical;
+ verticalDpi = mDpiVertical;
}
int FontClient::GetDefaultFontSize()
{
- int fontSize( -1 );
+ int fontSize(-1);
-#ifndef DALI_PROFILE_UBUNTU
- vconf_get_int( VCONFKEY_SETAPPL_ACCESSIBILITY_FONT_SIZE, &fontSize );
-#endif // DALI_PROFILE_UBUNTU
+#if !(defined(DALI_PROFILE_UBUNTU) || defined(ANDROID) || defined(WIN32) || defined(__APPLE__))
+ vconf_get_int(VCONFKEY_SETAPPL_ACCESSIBILITY_FONT_SIZE, &fontSize);
+#endif
return fontSize;
}
mPlugin->ResetSystemDefaults();
}
-void FontClient::GetDefaultFonts( FontList& defaultFonts )
+void FontClient::GetDefaultFonts(FontList& defaultFonts)
+{
+ CreatePlugin();
+
+ mPlugin->GetDefaultFonts(defaultFonts);
+}
+
+void FontClient::GetDefaultPlatformFontDescription(FontDescription& fontDescription)
{
CreatePlugin();
- mPlugin->GetDefaultFonts( defaultFonts );
+ mPlugin->GetDefaultPlatformFontDescription(fontDescription);
}
-void FontClient::GetDefaultPlatformFontDescription( FontDescription& fontDescription )
+void FontClient::GetDescription(FontId id, FontDescription& fontDescription)
{
CreatePlugin();
- mPlugin->GetDefaultPlatformFontDescription( fontDescription );
+ mPlugin->GetDescription(id, fontDescription);
}
-void FontClient::GetDescription( FontId id, FontDescription& fontDescription )
+PointSize26Dot6 FontClient::GetPointSize(FontId id)
{
CreatePlugin();
- mPlugin->GetDescription( id, fontDescription );
+ return mPlugin->GetPointSize(id);
}
-PointSize26Dot6 FontClient::GetPointSize( FontId id )
+bool FontClient::IsCharacterSupportedByFont(FontId fontId, Character character)
{
CreatePlugin();
- return mPlugin->GetPointSize( id );
+ return mPlugin->IsCharacterSupportedByFont(fontId, character);
}
-bool FontClient::IsCharacterSupportedByFont( FontId fontId, Character character )
+void FontClient::GetSystemFonts(FontList& systemFonts)
{
CreatePlugin();
- return mPlugin->IsCharacterSupportedByFont( fontId, character );
+ mPlugin->GetSystemFonts(systemFonts);
}
-void FontClient::GetSystemFonts( FontList& systemFonts )
+FontId FontClient::FindDefaultFont(Character charcode,
+ PointSize26Dot6 requestedPointSize,
+ bool preferColor)
{
CreatePlugin();
- mPlugin->GetSystemFonts( systemFonts );
+ return mPlugin->FindDefaultFont(charcode,
+ requestedPointSize,
+ preferColor);
}
-FontId FontClient::FindDefaultFont( Character charcode,
- PointSize26Dot6 requestedPointSize,
- bool preferColor )
+FontId FontClient::FindFallbackFont(Character charcode,
+ const FontDescription& preferredFontDescription,
+ PointSize26Dot6 requestedPointSize,
+ bool preferColor)
{
CreatePlugin();
- return mPlugin->FindDefaultFont( charcode,
+ return mPlugin->FindFallbackFont(charcode,
+ preferredFontDescription,
requestedPointSize,
- preferColor );
+ preferColor);
+}
+
+bool FontClient::IsScalable(const FontPath& path)
+{
+ CreatePlugin();
+
+ return mPlugin->IsScalable(path);
+}
+
+bool FontClient::IsScalable(const FontDescription& fontDescription)
+{
+ CreatePlugin();
+
+ return mPlugin->IsScalable(fontDescription);
+}
+
+void FontClient::GetFixedSizes(const FontPath& path, Dali::Vector<PointSize26Dot6>& sizes)
+{
+ CreatePlugin();
+
+ mPlugin->GetFixedSizes(path, sizes);
+}
+
+void FontClient::GetFixedSizes(const FontDescription& fontDescription,
+ Dali::Vector<PointSize26Dot6>& sizes)
+{
+ CreatePlugin();
+
+ mPlugin->GetFixedSizes(fontDescription, sizes);
+}
+
+bool FontClient::HasItalicStyle(FontId fontId) const
+{
+ if(!mPlugin)
+ {
+ return false;
+ }
+ return mPlugin->HasItalicStyle(fontId);
+}
+
+FontId FontClient::GetFontId(const FontPath& path, PointSize26Dot6 requestedPointSize, FaceIndex faceIndex)
+{
+ CreatePlugin();
+
+ return mPlugin->GetFontId(path,
+ requestedPointSize,
+ faceIndex,
+ true);
}
-FontId FontClient::FindFallbackFont( Character charcode,
- const FontDescription& preferredFontDescription,
- PointSize26Dot6 requestedPointSize,
- bool preferColor )
+FontId FontClient::GetFontId(const FontDescription& fontDescription,
+ PointSize26Dot6 requestedPointSize,
+ FaceIndex faceIndex)
{
CreatePlugin();
- return mPlugin->FindFallbackFont( charcode,
- preferredFontDescription,
- requestedPointSize,
- preferColor );
+ return mPlugin->GetFontId(fontDescription,
+ requestedPointSize,
+ faceIndex);
}
-bool FontClient::IsScalable( const FontPath& path )
+FontId FontClient::GetFontId(const BitmapFont& bitmapFont)
{
CreatePlugin();
- return mPlugin->IsScalable( path );
+ return mPlugin->GetFontId(bitmapFont);
}
-bool FontClient::IsScalable( const FontDescription& fontDescription )
+void FontClient::GetFontMetrics(FontId fontId, FontMetrics& metrics)
{
CreatePlugin();
- return mPlugin->IsScalable( fontDescription );
+ mPlugin->GetFontMetrics(fontId, metrics);
}
-void FontClient::GetFixedSizes( const FontPath& path, Dali::Vector< PointSize26Dot6>& sizes )
+GlyphIndex FontClient::GetGlyphIndex(FontId fontId, Character charcode)
{
CreatePlugin();
- mPlugin->GetFixedSizes( path, sizes );
+ return mPlugin->GetGlyphIndex(fontId, charcode);
}
-void FontClient::GetFixedSizes( const FontDescription& fontDescription,
- Dali::Vector< PointSize26Dot6 >& sizes )
+bool FontClient::GetGlyphMetrics(GlyphInfo* array, uint32_t size, GlyphType type, bool horizontal)
{
CreatePlugin();
- mPlugin->GetFixedSizes( fontDescription, sizes );
+ return mPlugin->GetGlyphMetrics(array, size, type, horizontal);
}
-FontId FontClient::GetFontId( const FontPath& path, PointSize26Dot6 requestedPointSize, FaceIndex faceIndex )
+void FontClient::CreateBitmap(FontId fontId, GlyphIndex glyphIndex, bool isItalicRequired, bool isBoldRequired, Dali::TextAbstraction::FontClient::GlyphBufferData& data, int outlineWidth)
{
CreatePlugin();
- return mPlugin->GetFontId( path,
- requestedPointSize,
- faceIndex,
- true );
+ mPlugin->CreateBitmap(fontId, glyphIndex, isItalicRequired, isBoldRequired, data, outlineWidth);
}
-FontId FontClient::GetFontId( const FontDescription& fontDescription,
- PointSize26Dot6 requestedPointSize,
- FaceIndex faceIndex )
+PixelData FontClient::CreateBitmap(FontId fontId, GlyphIndex glyphIndex, int outlineWidth)
{
CreatePlugin();
- return mPlugin->GetFontId( fontDescription,
- requestedPointSize,
- faceIndex );
+ return mPlugin->CreateBitmap(fontId, glyphIndex, outlineWidth);
}
-void FontClient::GetFontMetrics( FontId fontId, FontMetrics& metrics )
+void FontClient::CreateVectorBlob(FontId fontId, GlyphIndex glyphIndex, VectorBlob*& blob, unsigned int& blobLength, unsigned int& nominalWidth, unsigned int& nominalHeight)
{
CreatePlugin();
- return mPlugin->GetFontMetrics( fontId, metrics );
+ mPlugin->CreateVectorBlob(fontId, glyphIndex, blob, blobLength, nominalWidth, nominalHeight);
}
-GlyphIndex FontClient::GetGlyphIndex( FontId fontId, Character charcode )
+const GlyphInfo& FontClient::GetEllipsisGlyph(PointSize26Dot6 requestedPointSize)
{
CreatePlugin();
- return mPlugin->GetGlyphIndex( fontId, charcode );
+ return mPlugin->GetEllipsisGlyph(requestedPointSize);
}
-bool FontClient::GetGlyphMetrics( GlyphInfo* array, uint32_t size, GlyphType type, bool horizontal )
+bool FontClient::IsColorGlyph(FontId fontId, GlyphIndex glyphIndex)
{
CreatePlugin();
- return mPlugin->GetGlyphMetrics( array, size, type, horizontal );
+ return mPlugin->IsColorGlyph(fontId, glyphIndex);
}
-void FontClient::CreateBitmap( FontId fontId, GlyphIndex glyphIndex, bool softwareItalic, bool softwareBold, Dali::TextAbstraction::FontClient::GlyphBufferData& data, int outlineWidth )
+GlyphIndex FontClient::CreateEmbeddedItem(const TextAbstraction::FontClient::EmbeddedItemDescription& description, Pixel::Format& pixelFormat)
{
CreatePlugin();
- mPlugin->CreateBitmap( fontId, glyphIndex, softwareItalic, softwareBold, data, outlineWidth );
+ return mPlugin->CreateEmbeddedItem(description, pixelFormat);
}
-PixelData FontClient::CreateBitmap( FontId fontId, GlyphIndex glyphIndex, int outlineWidth )
+void FontClient::EnableAtlasLimitation(bool enabled)
{
CreatePlugin();
+ return mPlugin->EnableAtlasLimitation(enabled);
+}
+
+bool FontClient::IsAtlasLimitationEnabled() const
+{
+ if(mPlugin)
+ {
+ return mPlugin->IsAtlasLimitationEnabled();
+ }
+ return TextAbstraction::FontClient::DEFAULT_ATLAS_LIMITATION_ENABLED;
+}
+
+Size FontClient::GetMaximumTextAtlasSize() const
+{
+ if(mPlugin)
+ {
+ return mPlugin->GetMaximumTextAtlasSize();
+ }
+ return TextAbstraction::FontClient::MAX_TEXT_ATLAS_SIZE;
+}
+
+Size FontClient::GetDefaultTextAtlasSize() const
+{
+ if(mPlugin)
+ {
+ return mPlugin->GetDefaultTextAtlasSize();
+ }
+ return TextAbstraction::FontClient::DEFAULT_TEXT_ATLAS_SIZE;
+}
- return mPlugin->CreateBitmap( fontId, glyphIndex, outlineWidth );
+Size FontClient::GetCurrentMaximumBlockSizeFitInAtlas() const
+{
+ if(mPlugin)
+ {
+ return mPlugin->GetCurrentMaximumBlockSizeFitInAtlas();
+ }
+ return TextAbstraction::FontClient::DEFAULT_TEXT_ATLAS_SIZE;
}
-void FontClient::CreateVectorBlob( FontId fontId, GlyphIndex glyphIndex, VectorBlob*& blob, unsigned int& blobLength, unsigned int& nominalWidth, unsigned int& nominalHeight )
+bool FontClient::SetCurrentMaximumBlockSizeFitInAtlas(const Size& currentMaximumBlockSizeFitInAtlas)
{
CreatePlugin();
+ return mPlugin->SetCurrentMaximumBlockSizeFitInAtlas(currentMaximumBlockSizeFitInAtlas);
+}
- return mPlugin->CreateVectorBlob( fontId, glyphIndex, blob, blobLength, nominalWidth, nominalHeight );
+uint32_t FontClient::GetNumberOfPointsPerOneUnitOfPointSize() const
+{
+ if(mPlugin)
+ {
+ return mPlugin->GetNumberOfPointsPerOneUnitOfPointSize();
+ }
+ return TextAbstraction::FontClient::NUMBER_OF_POINTS_PER_ONE_UNIT_OF_POINT_SIZE;;
}
-const GlyphInfo& FontClient::GetEllipsisGlyph( PointSize26Dot6 requestedPointSize )
+FT_FaceRec_* FontClient::GetFreetypeFace(FontId fontId)
{
CreatePlugin();
- return mPlugin->GetEllipsisGlyph( requestedPointSize );
+ return mPlugin->GetFreetypeFace(fontId);
}
-bool FontClient::IsColorGlyph( FontId fontId, GlyphIndex glyphIndex )
+FontDescription::Type FontClient::GetFontType(FontId fontId)
{
CreatePlugin();
- return mPlugin->IsColorGlyph( fontId, glyphIndex );
+ return mPlugin->GetFontType(fontId);
}
-FT_FaceRec_* FontClient::GetFreetypeFace( FontId fontId )
+bool FontClient::AddCustomFontDirectory(const FontPath& path)
{
CreatePlugin();
- return mPlugin->GetFreetypeFace( fontId );
+ return mPlugin->AddCustomFontDirectory(path);
}
void FontClient::CreatePlugin()
{
- if( !mPlugin )
+ if(!mPlugin)
{
- mPlugin = new Plugin( mDpiHorizontal, mDpiVertical );
+ mPlugin = new Plugin(mDpiHorizontal, mDpiVertical);
}
}