Qt
Internal/Contributor docs for the Qt SDK. <b>Note:</b> These are NOT official API docs; those are found <a href='https://doc.qt.io/'>here</a>.
Loading...
Searching...
No Matches
QWindowsFontDatabaseFT Class Reference

#include <qwindowsfontdatabase_ft_p.h>

+ Inheritance diagram for QWindowsFontDatabaseFT:
+ Collaboration diagram for QWindowsFontDatabaseFT:

Public Member Functions

void populateFontDatabase () override
 This function is called once at startup by Qt's internal font database.
 
bool populateFamilyAliases (const QString &familyName) override
 
void populateFamily (const QString &familyName) override
 This function is called whenever a lazily populated family, populated through registerFontFamily(), needs full population.
 
QFontEnginefontEngine (const QFontDef &fontDef, void *handle) override
 Returns the font engine that can be used to render the font described by the font definition, fontDef, in the specified script.
 
QFontEnginefontEngine (const QByteArray &fontData, qreal pixelSize, QFont::HintingPreference hintingPreference) override
 Returns the font engine that will be used to back a QRawFont, based on the given \fontData, pixelSize, and hintingPreference.
 
QStringList fallbacksForFamily (const QString &family, QFont::Style style, QFont::StyleHint styleHint, QChar::Script script) const override
 Returns a list of alternative fonts for the specified family and style and script using the styleHint given.
 
QString fontDir () const override
 Returns the directory containing the fonts used by the database.
 
QFont defaultFont () const override
 Returns the default system font.
 
- Public Member Functions inherited from QFreeTypeFontDatabase
QStringList addApplicationFont (const QByteArray &fontData, const QString &fileName, QFontDatabasePrivate::ApplicationFont *applicationFont=nullptr) override
 Adds an application font described by the font contained supplied fontData or using the font contained in the file referenced by fileName.
 
void releaseHandle (void *handle) override
 Releases the specified font handle.
 
bool supportsVariableApplicationFonts () const override
 Returns true if this font database supports loading named instances from variable application fonts.
 
- Public Member Functions inherited from QPlatformFontDatabase
virtual ~QPlatformFontDatabase ()
 
virtual void invalidate ()
 This function is called whenever the font database is invalidated.
 
virtual QFontEngineMultifontEngineMulti (QFontEngine *fontEngine, QChar::Script script)
 Returns a multi font engine in the specified script to encapsulate fontEngine with the option to fall back to the fonts given by fallbacks if fontEngine does not support a certain character.
 
virtual bool isPrivateFontFamily (const QString &family) const
 Returns true if the font family is private.
 
virtual QString resolveFontFamilyAlias (const QString &family) const
 Resolve alias to actual font family names.
 
virtual bool fontsAlwaysScalable () const
 Return true if all fonts are considered scalable when using this font database.
 
virtual QList< int > standardSizes () const
 Return list of standard font sizes when using this font database.
 

Public Attributes

bool m_hasPopulatedAliases = false
 

Additional Inherited Members

- Static Public Member Functions inherited from QFreeTypeFontDatabase
static void addNamedInstancesForFace (void *face, int faceIndex, const QString &family, const QString &styleName, QFont::Weight weight, QFont::Stretch stretch, QFont::Style style, bool fixedPitch, const QSupportedWritingSystems &writingSystems, const QByteArray &fileName, const QByteArray &fontData)
 
static QStringList addTTFile (const QByteArray &fontData, const QByteArray &file, QFontDatabasePrivate::ApplicationFont *applicationFont=nullptr)
 
- Static Public Member Functions inherited from QPlatformFontDatabase
static QSupportedWritingSystems writingSystemsFromTrueTypeBits (quint32 unicodeRange[4], quint32 codePageRange[2])
 Helper function that determines the writing systems support by a given unicodeRange and codePageRange.
 
static QSupportedWritingSystems writingSystemsFromOS2Table (const char *os2Table, size_t length)
 Helper function that determines the writing system support based on the contents of the OS/2 table in the font.
 
static void registerFont (const QString &familyname, const QString &stylename, const QString &foundryname, QFont::Weight weight, QFont::Style style, QFont::Stretch stretch, bool antialiased, bool scalable, int pixelSize, bool fixedPitch, const QSupportedWritingSystems &writingSystems, void *handle)
 Registers a font with the given set of attributes describing the font's foundry, family name, style and stretch information, pixel size, and supported writing systems.
 
static void registerFontFamily (const QString &familyName)
 Registers a font family with the font database.
 
static void registerAliasToFontFamily (const QString &familyName, const QString &alias)
 Helper function that register the alias for the familyName.
 
static void repopulateFontDatabase ()
 Requests that the platform font database should be repopulated.
 
static bool isFamilyPopulated (const QString &familyName)
 Helper function that returns true if the font family has already been registered and populated.
 

Detailed Description

Definition at line 24 of file qwindowsfontdatabase_ft_p.h.

Member Function Documentation

◆ defaultFont()

QFont QWindowsFontDatabaseFT::defaultFont ( ) const
overridevirtual

Returns the default system font.

See also
QGuiApplication::font()
Since
5.0

Reimplemented from QPlatformFontDatabase.

Definition at line 419 of file qwindowsfontdatabase_ft.cpp.

References QWindowsFontDatabaseBase::systemDefaultFont().

+ Here is the call graph for this function:

◆ fallbacksForFamily()

QStringList QWindowsFontDatabaseFT::fallbacksForFamily ( const QString & family,
QFont::Style style,
QFont::StyleHint styleHint,
QChar::Script script ) const
overridevirtual

Returns a list of alternative fonts for the specified family and style and script using the styleHint given.

Default implementation returns a list of fonts for which style and script support has been reported during the font database population.

Reimplemented from QPlatformFontDatabase.

Definition at line 400 of file qwindowsfontdatabase_ft.cpp.

References QWindowsFontDatabaseBase::extraTryFontsForFamily(), QPlatformFontDatabase::fallbacksForFamily(), QWindowsFontDatabaseBase::familyForStyleHint(), and qCDebug.

+ Here is the call graph for this function:

◆ fontDir()

QString QWindowsFontDatabaseFT::fontDir ( ) const
overridevirtual

Returns the directory containing the fonts used by the database.

Reimplemented from QPlatformFontDatabase.

Definition at line 412 of file qwindowsfontdatabase_ft.cpp.

References qCDebug, and qgetenv().

+ Here is the call graph for this function:

◆ fontEngine() [1/2]

QFontEngine * QWindowsFontDatabaseFT::fontEngine ( const QByteArray & fontData,
qreal pixelSize,
QFont::HintingPreference hintingPreference )
overridevirtual

Returns the font engine that will be used to back a QRawFont, based on the given \fontData, pixelSize, and hintingPreference.

This function is called by QRawFont, and does not play a part in the normal operations of QFontDatabase.

Reimplemented from QFreeTypeFontDatabase.

Definition at line 393 of file qwindowsfontdatabase_ft.cpp.

References QFreeTypeFontDatabase::fontEngine(), and qCDebug.

+ Here is the call graph for this function:

◆ fontEngine() [2/2]

QFontEngine * QWindowsFontDatabaseFT::fontEngine ( const QFontDef & fontDef,
void * handle )
overridevirtual

Returns the font engine that can be used to render the font described by the font definition, fontDef, in the specified script.

This function is called by QFontDatabase both for system fonts provided by the platform font database, as well as for application fonts added by the application developer.

The handle is the QPlatformFontDatabase specific handle passed when registering the font family via QPlatformFontDatabase::registerFont.

The function is called for both fonts added via a filename as well as fonts added from QByteArray data. Subclasses will need to handle both cases via its platform specific handle.

Reimplemented from QFreeTypeFontDatabase.

Definition at line 386 of file qwindowsfontdatabase_ft.cpp.

References QFontDef::families, QFreeTypeFontDatabase::fontEngine(), and qCDebug.

+ Here is the call graph for this function:

◆ populateFamily()

void QWindowsFontDatabaseFT::populateFamily ( const QString & familyName)
overridevirtual

This function is called whenever a lazily populated family, populated through registerFontFamily(), needs full population.

You are expected to fully populate the family by calling registerFont() for each font that matches the family name.

Reimplemented from QPlatformFontDatabase.

Definition at line 321 of file qwindowsfontdatabase_ft.cpp.

References qCDebug, qCWarning, QString::size(), storeFont(), and QString::toWCharArray().

Referenced by populateFamilyAliases().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ populateFamilyAliases()

bool QWindowsFontDatabaseFT::populateFamilyAliases ( const QString & familyName)
overridevirtual

Reimplemented from QPlatformFontDatabase.

Definition at line 298 of file qwindowsfontdatabase_ft.cpp.

References QFontDatabase::families(), m_hasPopulatedAliases, populateFamily(), and Q_UNUSED.

+ Here is the call graph for this function:

◆ populateFontDatabase()

void QWindowsFontDatabaseFT::populateFontDatabase ( )
overridevirtual

This function is called once at startup by Qt's internal font database.

Reimplement this function in a subclass for a convenient place to initialize the internal font database.

You may lazily populate the database by calling registerFontFamily() instead of registerFont(), in which case you'll get a callback to populateFamily() when the required family needs population. You then call registerFont() to finish population of the family.

The default implementation does nothing.

Reimplemented from QFreeTypeFontDatabase.

Definition at line 371 of file qwindowsfontdatabase_ft.cpp.

References populateFontFamilies(), QPlatformFontDatabase::registerFontFamily(), QPlatformFontDatabase::resolveFontFamilyAlias(), and QWindowsFontDatabaseBase::systemDefaultFont().

+ Here is the call graph for this function:

Member Data Documentation

◆ m_hasPopulatedAliases

bool QWindowsFontDatabaseFT::m_hasPopulatedAliases = false

Definition at line 41 of file qwindowsfontdatabase_ft_p.h.

Referenced by populateFamilyAliases().


The documentation for this class was generated from the following files: