![]() |
Qt
Internal/Contributor docs for the Qt SDK. Note: These are NOT official API docs; those are found at https://doc.qt.io/
|
The QRawFont class provides access to a single physical instance of a font. More...
#include <qrawfont.h>
Public Types | |
enum | AntialiasingType { PixelAntialiasing , SubPixelAntialiasing } |
This enum represents the different ways a glyph can be rasterized in the function alphaMapForGlyph(). More... | |
enum | LayoutFlag { SeparateAdvances = 0 , KernedAdvances = 1 , UseDesignMetrics = 2 } |
Public Member Functions | |
QRawFont () | |
Constructs an invalid QRawFont. | |
QRawFont (const QString &fileName, qreal pixelSize, QFont::HintingPreference hintingPreference=QFont::PreferDefaultHinting) | |
Constructs a QRawFont representing the font contained in the file referenced by fileName for the size (in pixels) given by pixelSize, and using the hinting preference specified by hintingPreference. | |
QRawFont (const QByteArray &fontData, qreal pixelSize, QFont::HintingPreference hintingPreference=QFont::PreferDefaultHinting) | |
Constructs a QRawFont representing the font contained in the supplied fontData for the size (in pixels) given by pixelSize, and using the hinting preference specified by hintingPreference. | |
QRawFont (const QRawFont &other) | |
Creates a QRawFont which is a copy of other. | |
QRawFont & | operator= (const QRawFont &other) |
Assigns other to this QRawFont. | |
~QRawFont () | |
Destroys the QRawFont. | |
void | swap (QRawFont &other) noexcept |
bool | isValid () const |
Returns true if the QRawFont is valid and false otherwise. | |
bool | operator== (const QRawFont &other) const |
Returns true if this QRawFont is equal to other. | |
bool | operator!= (const QRawFont &other) const |
Returns true if this QRawFont is not equal to other. | |
int | glyphCount () const |
Returns the number of glyphs in this QRawFont. | |
QString | familyName () const |
Returns the family name of this QRawFont. | |
QString | styleName () const |
Returns the style name of this QRawFont. | |
QFont::Style | style () const |
Returns the style of this QRawFont. | |
int | weight () const |
Returns the weight of this QRawFont. | |
QList< quint32 > | glyphIndexesForString (const QString &text) const |
Converts the string of unicode points given by text to glyph indexes using the CMAP table in the underlying font, and returns a list containing the result. | |
QList< QPointF > | advancesForGlyphIndexes (const QList< quint32 > &glyphIndexes) const |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.Returns the QRawFont's advances for each of the glyphIndexes in pixel units. | |
QList< QPointF > | advancesForGlyphIndexes (const QList< quint32 > &glyphIndexes, LayoutFlags layoutFlags) const |
bool | glyphIndexesForChars (const QChar *chars, int numChars, quint32 *glyphIndexes, int *numGlyphs) const |
Converts a string of unicode points to glyph indexes using the CMAP table in the underlying font. | |
bool | advancesForGlyphIndexes (const quint32 *glyphIndexes, QPointF *advances, int numGlyphs) const |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.Returns the QRawFont's advances for each of the glyphIndexes in pixel units. | |
bool | advancesForGlyphIndexes (const quint32 *glyphIndexes, QPointF *advances, int numGlyphs, LayoutFlags layoutFlags) const |
QImage | alphaMapForGlyph (quint32 glyphIndex, AntialiasingType antialiasingType=SubPixelAntialiasing, const QTransform &transform=QTransform()) const |
This function returns a rasterized image of the glyph at the given glyphIndex in the underlying font, using the transform specified. | |
QPainterPath | pathForGlyph (quint32 glyphIndex) const |
This function returns the shape of the glyph at a given glyphIndex in the underlying font if the QRawFont is valid. | |
QRectF | boundingRect (quint32 glyphIndex) const |
Returns the smallest rectangle containing the glyph with the given glyphIndex. | |
void | setPixelSize (qreal pixelSize) |
Sets the pixel size with which this font should be rendered to pixelSize. | |
qreal | pixelSize () const |
Returns the pixel size set for this QRawFont. | |
QFont::HintingPreference | hintingPreference () const |
Returns the hinting preference used to construct this QRawFont. | |
qreal | ascent () const |
Returns the ascent of this QRawFont in pixel units. | |
qreal | capHeight () const |
Returns the cap height of this QRawFont in pixel units. | |
qreal | descent () const |
Returns the descent of this QRawFont in pixel units. | |
qreal | leading () const |
Returns the leading of this QRawFont in pixel units. | |
qreal | xHeight () const |
Returns the xHeight of this QRawFont in pixel units. | |
qreal | averageCharWidth () const |
Returns the average character width of this QRawFont in pixel units. | |
qreal | maxCharWidth () const |
Returns the width of the widest character in the font. | |
qreal | lineThickness () const |
Returns the thickness for drawing lines (underline, overline, etc.) along with text drawn in this font. | |
qreal | underlinePosition () const |
Returns the position from baseline for drawing underlines below the text rendered with this font. | |
qreal | unitsPerEm () const |
Returns the number of design units define the width and height of the em square for this QRawFont. | |
QString | glyphName (quint32 glyphIndex) const |
Returns the name of the given glyphIndex. | |
void | loadFromFile (const QString &fileName, qreal pixelSize, QFont::HintingPreference hintingPreference) |
Replaces the current QRawFont with the contents of the file referenced by fileName for the size (in pixels) given by pixelSize, and using the hinting preference specified by hintingPreference. | |
void | loadFromData (const QByteArray &fontData, qreal pixelSize, QFont::HintingPreference hintingPreference) |
Replaces the current QRawFont with the font contained in the supplied fontData for the size (in pixels) given by pixelSize, and using the hinting preference specified by hintingPreference. | |
bool | supportsCharacter (uint ucs4) const |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.Returns true if the font has a glyph that corresponds to the UCS-4 encoded character ucs4. | |
bool | supportsCharacter (QChar character) const |
Returns true if the font has a glyph that corresponds to the given character. | |
QList< QFontDatabase::WritingSystem > | supportedWritingSystems () const |
Returns a list of writing systems supported by the font according to designer supplied information in the font file. | |
QByteArray | fontTable (const char *tagName) const |
QByteArray | fontTable (QFont::Tag tag) const |
Static Public Member Functions | |
static QRawFont | fromFont (const QFont &font, QFontDatabase::WritingSystem writingSystem=QFontDatabase::Any) |
Fetches the physical representation based on a font query. |
Friends | |
class | QRawFontPrivate |
class | QTextLayout |
class | QTextEngine |
The QRawFont class provides access to a single physical instance of a font.
Most commonly, when presenting text in a user interface, the exact fonts used to render the characters is to some extent unknown. This can be the case for several reasons: For instance, the actual, physical fonts present on the target system could be unexpected to the developers, or the text could contain user selected styles, sizes or writing systems that are not supported by font chosen in the code.
Therefore, Qt's QFont class really represents a query for fonts. When text is interpreted, Qt will do its best to match the text to the query, but depending on the support, different fonts can be used behind the scenes.
For most use cases, this is both expected and necessary, as it minimizes the possibility of text in the user interface being undisplayable. In some cases, however, more direct control over the process might be useful. It is for these use cases the QRawFont class exists.
A QRawFont object represents a single, physical instance of a given font in a given pixel size. I.e. in the typical case it represents a set of TrueType or OpenType font tables and uses a user specified pixel size to convert metrics into logical pixel units. It can be used in combination with the QGlyphRun class to draw specific glyph indexes at specific positions, and also have accessors to some relevant data in the physical font.
QRawFont only provides support for the main font technologies: GDI and DirectWrite on Windows platforms, FreeType on Linux platforms and CoreText on \macos. For other font back-ends, the APIs will be disabled.
QRawFont can be constructed in a number of ways: \list
QRawFont is considered local to the thread in which it is constructed (either using a constructor, or by calling loadFromData() or loadFromFile()). The QRawFont cannot be moved to a different thread, but will have to be recreated in the thread in question.
Definition at line 23 of file qrawfont.h.
This enum represents the different ways a glyph can be rasterized in the function alphaMapForGlyph().
\value PixelAntialiasing Will rasterize by measuring the coverage of the shape on whole pixels. The returned image contains the alpha values of each pixel based on the coverage of the glyph shape. \value SubPixelAntialiasing Will rasterize by measuring the coverage of each subpixel, returning a separate alpha value for each of the red, green and blue components of each pixel.
Enumerator | |
---|---|
PixelAntialiasing | |
SubPixelAntialiasing |
Definition at line 26 of file qrawfont.h.
enum QRawFont::LayoutFlag |
This enum tells the function advancesForGlyphIndexes() how to calculate the advances.
\value SeparateAdvances Will calculate the advance for each glyph separately. \value KernedAdvances Will apply kerning between adjacent glyphs. Note that OpenType GPOS based kerning is currently not supported. \value UseDesignMetrics Use design metrics instead of hinted metrics adjusted to the resolution of the paint device. Can be OR-ed with any of the options above.
Enumerator | |
---|---|
SeparateAdvances | |
KernedAdvances | |
UseDesignMetrics |
Definition at line 31 of file qrawfont.h.
QRawFont::QRawFont | ( | ) |
Constructs an invalid QRawFont.
Definition at line 112 of file qrawfont.cpp.
QRawFont::QRawFont | ( | const QString & | fileName, |
qreal | pixelSize, | ||
QFont::HintingPreference | hintingPreference = QFont::PreferDefaultHinting ) |
Constructs a QRawFont representing the font contained in the file referenced by fileName for the size (in pixels) given by pixelSize, and using the hinting preference specified by hintingPreference.
Definition at line 124 of file qrawfont.cpp.
QRawFont::QRawFont | ( | const QByteArray & | fontData, |
qreal | pixelSize, | ||
QFont::HintingPreference | hintingPreference = QFont::PreferDefaultHinting ) |
Constructs a QRawFont representing the font contained in the supplied fontData for the size (in pixels) given by pixelSize, and using the hinting preference specified by hintingPreference.
Definition at line 139 of file qrawfont.cpp.
QRawFont::QRawFont | ( | const QRawFont & | other | ) |
Creates a QRawFont which is a copy of other.
Definition at line 150 of file qrawfont.cpp.
QRawFont::~QRawFont | ( | ) |
Destroys the QRawFont.
Definition at line 158 of file qrawfont.cpp.
|
inline |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.Returns the QRawFont's advances for each of the glyphIndexes in pixel units.
The advances give the distance from the position of a given glyph to where the next glyph should be drawn to make it appear as if the two glyphs are unspaced. The advance of each glyph is calculated separately.
Definition at line 140 of file qrawfont.h.
|
inline |
Returns the QRawFont's advances for each of the glyphIndexes in pixel units. The advances give the distance from the position of a given glyph to where the next glyph should be drawn to make it appear as if the two glyphs are unspaced. How the advances are calculated is controlled by layoutFlags.
KernedAdvances
is requested, this function will apply kerning rules from the TrueType table
{KERN}, if this is available in the font. In many modern fonts, kerning is handled through OpenType rules or AAT rules, which requires a full shaping step to be applied. To get the results of fully shaping the text, use \l{QTextLayout}.bool QRawFont::advancesForGlyphIndexes | ( | const quint32 * | glyphIndexes, |
QPointF * | advances, | ||
int | numGlyphs ) const |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.Returns the QRawFont's advances for each of the glyphIndexes in pixel units.
The advances give the distance from the position of a given glyph to where the next glyph should be drawn to make it appear as if the two glyphs are unspaced. The glyph indexes are given with the array glyphIndexes while the results are returned through advances, both of them must have numGlyphs elements. The advance of each glyph is calculated separately
Definition at line 638 of file qrawfont.cpp.
bool QRawFont::advancesForGlyphIndexes | ( | const quint32 * | glyphIndexes, |
QPointF * | advances, | ||
int | numGlyphs, | ||
LayoutFlags | layoutFlags ) const |
Returns the QRawFont's advances for each of the glyphIndexes in pixel units. The advances give the distance from the position of a given glyph to where the next glyph should be drawn to make it appear as if the two glyphs are unspaced. The glyph indexes are given with the array glyphIndexes while the results are returned through advances, both of them must have numGlyphs elements. How the advances are calculated is controlled by layoutFlags.
KernedAdvances
is requested, this function will apply kerning rules from the TrueType table
{KERN}, if this is available in the font. In many modern fonts, kerning is handled through OpenType rules or AAT rules, which requires a full shaping step to be applied. To get the results of fully shaping the text, use \l{QTextLayout}.Definition at line 602 of file qrawfont.cpp.
QImage QRawFont::alphaMapForGlyph | ( | quint32 | glyphIndex, |
AntialiasingType | antialiasingType = SubPixelAntialiasing, | ||
const QTransform & | transform = QTransform() ) const |
This function returns a rasterized image of the glyph at the given glyphIndex in the underlying font, using the transform specified.
If the QRawFont is not valid, this function will return an invalid QImage.
If the font is a color font, then the resulting image will contain the rendered glyph at the current pixel size. In this case, the antialiasingType will be ignored.
Otherwise, if antialiasingType is set to QRawFont::SubPixelAntialiasing, then the resulting image will be in QImage::Format_RGB32 and the RGB values of each pixel will represent the subpixel opacities of the pixel in the rasterization of the glyph. Otherwise, the image will be in the format of QImage::Format_Indexed8 and each pixel will contain the opacity of the pixel in the rasterization.
Definition at line 262 of file qrawfont.cpp.
qreal QRawFont::ascent | ( | ) | const |
Returns the ascent of this QRawFont in pixel units.
The ascent of a font is the distance from the baseline to the highest position characters extend to. In practice, some font designers break this rule, e.g. when they put more than one accent on top of a character, or to accommodate an unusual character in an exotic language, so it is possible (though rare) that this value will be too small.
Definition at line 333 of file qrawfont.cpp.
qreal QRawFont::averageCharWidth | ( | ) | const |
Returns the average character width of this QRawFont in pixel units.
Definition at line 399 of file qrawfont.cpp.
Returns the smallest rectangle containing the glyph with the given glyphIndex.
Definition at line 819 of file qrawfont.cpp.
qreal QRawFont::capHeight | ( | ) | const |
Returns the cap height of this QRawFont in pixel units.
The cap height of a font is the height of a capital letter above the baseline. It specifically is the height of capital letters that are flat - such as H or I - as opposed to round letters such as O, or pointed letters like A, both of which may display overshoot.
Definition at line 350 of file qrawfont.cpp.
qreal QRawFont::descent | ( | ) | const |
Returns the descent of this QRawFont in pixel units.
The descent is the distance from the base line to the lowest point characters extend to. In practice, some font designers break this rule, e.g. to accommodate an unusual character in an exotic language, so it is possible (though rare) that this value will be too small.
Definition at line 365 of file qrawfont.cpp.
QString QRawFont::familyName | ( | ) | const |
Returns the family name of this QRawFont.
Definition at line 460 of file qrawfont.cpp.
QByteArray QRawFont::fontTable | ( | const char * | tagName | ) | const |
Definition at line 668 of file qrawfont.cpp.
QByteArray QRawFont::fontTable | ( | QFont::Tag | tag | ) | const |
Retrieves the sfnt table specified by tag from the underlying physical font, or an empty byte array if no such table was found. The returned font table's byte order is Big Endian, like the sfnt format specifies.
Definition at line 675 of file qrawfont.cpp.
|
static |
Fetches the physical representation based on a font query.
The physical font returned is the font that will be preferred by Qt in order to display text in the selected writingSystem.
Definition at line 756 of file qrawfont.cpp.
int QRawFont::glyphCount | ( | ) | const |
Returns the number of glyphs in this QRawFont.
Definition at line 227 of file qrawfont.cpp.
bool QRawFont::glyphIndexesForChars | ( | const QChar * | chars, |
int | numChars, | ||
quint32 * | glyphIndexes, | ||
int * | numGlyphs ) const |
Converts a string of unicode points to glyph indexes using the CMAP table in the underlying font.
The function works like glyphIndexesForString() except it take an array (chars), the results will be returned though glyphIndexes array and number of glyphs will be set in numGlyphs. The size of glyphIndexes array must be at least numChars, if that's still not enough, this function will return false, then you can resize glyphIndexes from the size returned in numGlyphs.
Definition at line 537 of file qrawfont.cpp.
Converts the string of unicode points given by text to glyph indexes using the CMAP table in the underlying font, and returns a list containing the result.
Note that, in cases where there are other tables in the font that affect the shaping of the text, the returned glyph indexes will not correctly represent the rendering of the text. To get the correctly shaped text, you can use QTextLayout to lay out and shape the text, then call QTextLayout::glyphs() to get the set of glyph index list and QRawFont pairs.
Definition at line 508 of file qrawfont.cpp.
Returns the name of the given glyphIndex.
If the glyph does not have an explicit name in the font a name is synthesized based on its glyph index.
Definition at line 240 of file qrawfont.cpp.
QFont::HintingPreference QRawFont::hintingPreference | ( | ) | const |
Returns the hinting preference used to construct this QRawFont.
Definition at line 648 of file qrawfont.cpp.
bool QRawFont::isValid | ( | ) | const |
Returns true
if the QRawFont is valid and false otherwise.
Definition at line 180 of file qrawfont.cpp.
qreal QRawFont::leading | ( | ) | const |
Returns the leading of this QRawFont in pixel units.
This is the natural inter-line spacing.
Definition at line 389 of file qrawfont.cpp.
qreal QRawFont::lineThickness | ( | ) | const |
Returns the thickness for drawing lines (underline, overline, etc.) along with text drawn in this font.
Definition at line 443 of file qrawfont.cpp.
void QRawFont::loadFromData | ( | const QByteArray & | fontData, |
qreal | pixelSize, | ||
QFont::HintingPreference | hintingPreference ) |
Replaces the current QRawFont with the font contained in the supplied fontData for the size (in pixels) given by pixelSize, and using the hinting preference specified by hintingPreference.
The fontData must contain a TrueType or OpenType font.
Definition at line 212 of file qrawfont.cpp.
void QRawFont::loadFromFile | ( | const QString & | fileName, |
qreal | pixelSize, | ||
QFont::HintingPreference | hintingPreference ) |
Replaces the current QRawFont with the contents of the file referenced by fileName for the size (in pixels) given by pixelSize, and using the hinting preference specified by hintingPreference.
The file must reference a TrueType or OpenType font.
Definition at line 194 of file qrawfont.cpp.
qreal QRawFont::maxCharWidth | ( | ) | const |
Returns the width of the widest character in the font.
Definition at line 409 of file qrawfont.cpp.
|
inline |
Returns true
if this QRawFont is not equal to other.
Otherwise, returns false
.
Definition at line 55 of file qrawfont.h.
Assigns other to this QRawFont.
Definition at line 165 of file qrawfont.cpp.
bool QRawFont::operator== | ( | const QRawFont & | other | ) | const |
Returns true
if this QRawFont is equal to other.
Otherwise, returns false
.
Definition at line 299 of file qrawfont.cpp.
QPainterPath QRawFont::pathForGlyph | ( | quint32 | glyphIndex | ) | const |
This function returns the shape of the glyph at a given glyphIndex in the underlying font if the QRawFont is valid.
Otherwise, it returns an empty QPainterPath.
The returned glyph will always be unhinted.
Definition at line 285 of file qrawfont.cpp.
qreal QRawFont::pixelSize | ( | ) | const |
Returns the pixel size set for this QRawFont.
The pixel size affects how glyphs are rasterized, the size of glyphs returned by pathForGlyph(), and is used to convert internal metrics from design units to logical pixel units.
Definition at line 421 of file qrawfont.cpp.
Sets the pixel size with which this font should be rendered to pixelSize.
Definition at line 793 of file qrawfont.cpp.
QFont::Style QRawFont::style | ( | ) | const |
Returns the style of this QRawFont.
Definition at line 480 of file qrawfont.cpp.
QString QRawFont::styleName | ( | ) | const |
Returns the style name of this QRawFont.
Definition at line 470 of file qrawfont.cpp.
QList< QFontDatabase::WritingSystem > QRawFont::supportedWritingSystems | ( | ) | const |
Returns a list of writing systems supported by the font according to designer supplied information in the font file.
Please note that this does not guarantee support for a specific unicode point in the font. You can use the supportsCharacter() to check support for a single, specific character.
Definition at line 694 of file qrawfont.cpp.
bool QRawFont::supportsCharacter | ( | QChar | character | ) | const |
Returns true
if the font has a glyph that corresponds to the given character.
Definition at line 729 of file qrawfont.cpp.
bool QRawFont::supportsCharacter | ( | uint | ucs4 | ) | const |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.Returns true
if the font has a glyph that corresponds to the UCS-4 encoded character ucs4.
Definition at line 741 of file qrawfont.cpp.
Definition at line 50 of file qrawfont.h.
qreal QRawFont::underlinePosition | ( | ) | const |
Returns the position from baseline for drawing underlines below the text rendered with this font.
Definition at line 452 of file qrawfont.cpp.
qreal QRawFont::unitsPerEm | ( | ) | const |
Returns the number of design units define the width and height of the em square for this QRawFont.
This value is used together with the pixel size when converting design metrics to pixel units, as the internal metrics are specified in design units and the pixel size gives the size of 1 em in pixels.
Definition at line 434 of file qrawfont.cpp.
int QRawFont::weight | ( | ) | const |
Returns the weight of this QRawFont.
Definition at line 490 of file qrawfont.cpp.
qreal QRawFont::xHeight | ( | ) | const |
Returns the xHeight of this QRawFont in pixel units.
This is often but not always the same as the height of the character 'x'.
Definition at line 377 of file qrawfont.cpp.
|
friend |
Definition at line 118 of file qrawfont.h.
|
friend |
Definition at line 120 of file qrawfont.h.
|
friend |
Definition at line 119 of file qrawfont.h.