#include <Font.h>
Public Types | |
enum | StandardType1Font { e_times_roman = 0, e_times_bold, e_times_italic, e_times_bold_italic, e_helvetica, e_helvetica_bold, e_helvetica_oblique, e_helvetica_bold_oblique, e_courier, e_courier_bold, e_courier_oblique, e_courier_bold_oblique, e_symbol, e_zapf_dingbats, e_null } |
enum | Encoding { e_IdentityH =0, e_Indices } |
enum | Type { e_Type1, e_TrueType, e_MMType1, e_Type3, e_Type0, e_CIDType0, e_CIDType2 } |
Public Member Functions | |
Font (SDF::Obj font_dict=0) | |
Font (const Font &c) | |
Font & | operator= (const Font &c) |
Type | GetType () |
bool | IsSimple () |
SDF::Obj | GetSDFObj () |
SDF::Obj | GetDescriptor () |
const char * | GetName () |
const char * | GetFamilyName () |
bool | IsFixedWidth () |
bool | IsSerif () |
bool | IsSymbolic () |
bool | IsItalic () |
bool | IsAllCap () |
bool | IsForceBold () |
bool | IsHorizontalMode () |
double | GetWidth (UInt32 char_code) const |
double | GetMaxWidth () |
double | GetMissingWidth () |
Common::Iterator< UInt32 > | GetCharCodeIterator () |
PathData | GetGlyphPath (UInt32 char_code, bool conics2cubics, Common::Matrix2D *transform=0) |
ShapedText | GetShapedText (const UString &text_to_shape) |
UString | MapToUnicode (UInt32 char_code) |
bool | MapToUnicode (UInt32 char_code, Unicode *out_uni_arr, const int in_uni_sz, int &out_chars) |
const char ** | GetEncoding () |
bool | IsEmbedded () |
const char * | GetEmbeddedFontName () |
SDF::Obj | GetEmbeddedFont () |
int | GetEmbeddedFontBufSize () |
UInt16 | GetUnitsPerEm () |
Rect | GetBBox () |
double | GetAscent () |
double | GetDescent () |
int | GetStandardType1FontType () |
bool | IsCFF () |
Common::Matrix2D | GetType3FontMatrix () |
SDF::Obj | GetType3GlyphStream (UInt32 char_code) |
double | GetVerticalAdvance (UInt32 char_code, double &out_pos_vect_x, double &out_pos_vect_y) |
std::vector< double > | GetVerticalAdvance (UInt32 char_code) |
Font | GetDescendant () |
UInt32 | MapToCID (UInt32 char_code) const |
int | MapToCID (const UChar *char_data, int char_data_avail, UInt32 &out_charcode, UInt32 &out_cid) const |
void | Destroy () |
Static Public Member Functions | |
static Font | Create (SDF::SDFDoc &doc, StandardType1Font type, bool embed=false) |
static Font | CreateTrueTypeFont (SDF::SDFDoc &doc, const UString &font_path, bool embed=true, bool subset=true) |
static Font | CreateTrueTypeFont2 (SDF::SDFDoc &doc, const void *logfont, bool embed=true, bool subset=true) |
static Font | CreateCIDTrueTypeFont (SDF::SDFDoc &doc, const UString &font_path, bool embed=true, bool subset=true, Encoding encoding=e_IdentityH, UInt32 ttc_font_index=0) |
static Font | CreateCIDTrueTypeFont2 (SDF::SDFDoc &doc, const void *logfonta, bool embed=true, bool subset=true, Encoding encoding=e_IdentityH) |
static Font | CreateCIDTrueTypeFont2Unicode (SDF::SDFDoc &doc, const void *logfontw, bool embed=true, bool subset=true, Encoding encoding=e_IdentityH) |
static Font | Create (SDF::SDFDoc &doc, Font &from, const UString &char_set) |
static Font | Create (SDF::SDFDoc &doc, const char *name, const UString &char_set) |
static Font | CreateType1Font (SDF::SDFDoc &doc, const UString &font_path, bool embed=true) |
static Type | GetType (SDF::Obj font_dict) |
A font that is used to draw text on a page. It corresponds to a Font Resource in a PDF file. More than one page may reference the same Font object. A Font has a number of attributes, including an array of widths, the character encoding, and the font's resource name.
PDF document can contain several different types of fonts and Font class represents a single, flat interface around all PDF font types.
There are two main classes of fonts in PDF: simple and composite fonts.
Simple fonts are Type1, TrueType, and Type3 fonts. All simple fonts have the following properties:
A composite font is one whose glyphs are obtained from a font like object called a CIDFont (e.g. CIDType0Font and CIDType0Font). A composite font is represented by a font dictionary whose Subtype value is Type0. The Type 0 font is known as the root font, while its associated CIDFont is called its descendant. CID-keyed fonts provide a convenient and efficient method for defining multiple-byte character encodings and fonts with a large number of glyphs. These capabilities provide great flexibility for representing text in writing systems for languages with large character sets, such as Chinese, Japanese, and Korean (CJK).
pdftron::PDF::Font::Font | ( | SDF::Obj | font_dict = 0 | ) |
pdftron::PDF::Font::Font | ( | const Font & | c | ) |
|
static |
Create a PDF::Font object for the given standard (also known as base 14 font)
|
static |
Create a new Unicode font based on the description of an existing PDF font.
doc | document in which the external font should be embedded. |
from | A Font object that provides the name for choosing a font. If the font with that name can be located and it covers a sufficient character set characters from that font will be used. Otherwise the font object created will be from a another font that covers the character set. |
char_set | An initial character set. This provides an approach to specify any characters that are required to be included in the final font as part of a string. Note that additional characters will be added to the character set as needed, so it is not required to specify them here. (empty string is a perfectly valid and common value for this argument) |
|
static |
Create a new Unicode font based on the description of an existing PDF font.
doc | document in which the external font should be embedded. |
name | A font name that provides a hint when choosing a font. If the font with that name can be located and it covers a sufficient character set characters from that font will be used. Otherwise the font object created will be from a another font that covers the character set. |
char_set | An initial character set. This provides an approach to specify any characters that are required to be included in the final font as part of a string. Note that additional characters will be added to the character set as needed, so it is not required to specify them here. (empty string is a perfectly valid and common value for this argument) |
|
static |
Embed an external TrueType font in the document as a CID font. By default the function selects "Identity-H" encoding that maps 2-byte character codes ranging from 0 to 65,535 to the same Unicode value. Other predefined encodings are listed in Table 5.15 'Predefined CMap names' in PDF Reference Manual.
doc | - document in which the external font should be embedded. |
font_path | - path to the external font file. |
embed | - a boolean indicating whether the font should be embedded or not. For accurate font reproduction set the embed flag to 'true'. |
subset | - a boolean indicating whether the embedded font should be subsetted |
encoding | - the encoding type either e_IdentityH (default) or e_Indices (to write glyph indices rather than unicode) |
ttc_font_index | - if a TrueTypeCollection (TTC) font is loaded this parameter controls which font is actually picked |
|
static |
Create a CID TrueType PDF font with the characteristics specified in the LOGFONTA structure.
doc | - document in which the external font should be embedded. |
logfonta | A pointer to a Windows LOGFONTA structure that defines the characteristics of the logical font. |
embed | - a boolean indicating whether the font should be embedded or not. For accurate font reproduction set the embed flag to 'true'. |
subset | - a boolean indicating whether the embedded font should be subsetted |
encoding | - the encoding type either e_IdentityH (default) or e_Indices (to write glyph indices rather than unicode) |
|
static |
Create a CID TrueType PDF font with the characteristics specified in the LOGFONTA structure.
doc | - document in which the external font should be embedded. |
logfontw | A pointer to a Windows LOGFONTW structure that defines the characteristics of the logical font. |
embed | - a boolean indicating whether the font should be embedded or not. For accurate font reproduction set the embed flag to 'true'. |
subset | - a boolean indicating whether the embedded font should be subsetted |
encoding | - the encoding type either e_IdentityH (default) or e_Indices (to write glyph indices rather than unicode) |
|
static |
Embed an external TrueType font in the document as a Simple font.
doc | Document in which the external font should be embedded. |
font_path | Path to the external font file. |
embed | A boolean indicating whether the font should be embedded or not. For accurate font reproduction set the embed flag to 'true'. |
subset | A boolean indicating whether the embedded font should be subsetted. |
|
static |
Create a TrueType PDF font with the characteristics specified in the LOGFONTA structure.
doc | Document in which the external font should be embedded. |
logfont | A pointer to a Windows LOGFONTA structure that defines the characteristics of the logical font. |
embed | A boolean indicating whether the font should be embedded or not. For accurate font reproduction set the embed flag to 'true'. |
subset | A boolean indicating whether the embedded font should be subsetted. |
|
static |
Embed an external Type1 font in the document.
doc | - document in which the external font should be embedded. |
font_path | - path to the external font file. |
embed | - a boolean indicating whether the font should be embedded or not. For accurate font reproduction set the embed flag to 'true'. |
void pdftron::PDF::Font::Destroy | ( | ) |
Frees the native memory of the object.
double pdftron::PDF::Font::GetAscent | ( | ) |
The face's ascender is the vertical distance from the baseline to the topmost point of any glyph in the face. This field's value is a positive number, expressed in the glyph coordinate system. For all font types except Type 3, the units of glyph space are one-thousandth of a unit of text space. Some font designs use a value different from 'bbox.yMax'.
Rect pdftron::PDF::Font::GetBBox | ( | ) |
Common::Iterator<UInt32> pdftron::PDF::Font::GetCharCodeIterator | ( | ) |
GetCharCodeIterator represents an iterator interface used to traverse a list of char codes for which there is a glyph outline in the embedded font.
Font pdftron::PDF::Font::GetDescendant | ( | ) |
double pdftron::PDF::Font::GetDescent | ( | ) |
The face's descender is the vertical distance from the baseline to the bottommost point of any glyph in the face. This field's value is a negative number expressed in the glyph coordinate system. For all font types except Type 3, the units of glyph space are one-thousandth of a unit of text space. Some font designs use a value different from 'bbox.yMin'.
SDF::Obj pdftron::PDF::Font::GetDescriptor | ( | ) |
SDF::Obj pdftron::PDF::Font::GetEmbeddedFont | ( | ) |
int pdftron::PDF::Font::GetEmbeddedFontBufSize | ( | ) |
const char* pdftron::PDF::Font::GetEmbeddedFontName | ( | ) |
const char** pdftron::PDF::Font::GetEncoding | ( | ) |
For a Type 3 font, all glyph names will be present in the encoding array, and NULL entries correspond to un-encoded code points.
const char* pdftron::PDF::Font::GetFamilyName | ( | ) |
PathData pdftron::PDF::Font::GetGlyphPath | ( | UInt32 | char_code, |
bool | conics2cubics, | ||
Common::Matrix2D * | transform = 0 |
||
) |
The function retrieves the glyph outline for a given character code.
char_code | character to query |
conics2cubics | if set to true converts all quadratic Bezier curves to cubic Beziers, otherwise no conversion is performed. |
transform | An optional matrix used to transform glyph data coordinates. If null/unspecified, glyph data points will not be transformed. |
double pdftron::PDF::Font::GetMaxWidth | ( | ) |
double pdftron::PDF::Font::GetMissingWidth | ( | ) |
const char* pdftron::PDF::Font::GetName | ( | ) |
ShapedText pdftron::PDF::Font::GetShapedText | ( | const UString & | text_to_shape | ) |
Creates a set of positioned glyphs corresponding to the visual representation of the provided text string.
The shaped text will take into account any advanced positioning and substitution features provided by an underylying embedded font file. For example, these features could include kerning, ligatures, and diacritic positioning. Typically the resulting shaped text would be fed into ElementBuilder.CreateShapedTextRun()
text_to_shape | the string to be shaped. |
int pdftron::PDF::Font::GetStandardType1FontType | ( | ) |
Common::Matrix2D pdftron::PDF::Font::GetType3FontMatrix | ( | ) |
UInt16 pdftron::PDF::Font::GetUnitsPerEm | ( | ) |
double pdftron::PDF::Font::GetVerticalAdvance | ( | UInt32 | char_code, |
double & | out_pos_vect_x, | ||
double & | out_pos_vect_y | ||
) |
char_code | character to query for vertical advance |
out_pos_vect_x | - initialized by the method. horizontal component of the position vector defining the position of the vertical writing mode origin relative to horizontal writing mode origin. |
out_pos_vect_y | - initialized by the method. vertical component of the position vector defining the position of the vertical writing mode origin relative to horizontal writing mode origin. |
std::vector<double> pdftron::PDF::Font::GetVerticalAdvance | ( | UInt32 | char_code | ) |
double pdftron::PDF::Font::GetWidth | ( | UInt32 | char_code | ) | const |
The function gets the advance width of the font glyph. The advance width is the amount by which the current point advances when the glyph is drawn. The advance width may not correspond to the visible width of the glyph and for this reason, the advance width cannot be used to determine the glyphs' bounding boxes.
bool pdftron::PDF::Font::IsAllCap | ( | ) |
bool pdftron::PDF::Font::IsCFF | ( | ) |
bool pdftron::PDF::Font::IsEmbedded | ( | ) |
Tests whether or not the specified font is stored as a font file in a stream embedded in the PDF file.
bool pdftron::PDF::Font::IsFixedWidth | ( | ) |
bool pdftron::PDF::Font::IsForceBold | ( | ) |
bool pdftron::PDF::Font::IsHorizontalMode | ( | ) |
bool pdftron::PDF::Font::IsItalic | ( | ) |
bool pdftron::PDF::Font::IsSerif | ( | ) |
bool pdftron::PDF::Font::IsSimple | ( | ) |
All simple fonts have the following properties:
bool pdftron::PDF::Font::IsSymbolic | ( | ) |
int pdftron::PDF::Font::MapToCID | ( | const UChar * | char_data, |
int | char_data_avail, | ||
UInt32 & | out_charcode, | ||
UInt32 & | out_cid | ||
) | const |
The function maps charcode (out_charcode) from char_data buffer to a CID (out_cid) and return the number of bytes representing the CID in the buffer.
char_data | the input data buffer containing one or more bytes of input charcode |
char_data_avail | the number of bytes in the char_data buffer |
out_charcode | the first charcode in char_data buffer. |
out_cid | CID corresponding to the out_charcode parsed from char_data buffer. |
Maps the encoding specific 'charcode' to Unicode. Conversion of 'charcode' to Unicode can result in up to four Unicode characters.
char_code | encoding specific 'charcode' that needs to be converted to Unicode. |
out_uni_arr | A pointer to an array of Unicode characters where the conversion result will be stored. |
in_uni_sz | The number of characters that can be written to out_uni_arr. You can assume that the function will never map to more than 10 characters. |
out_char_num | The function will modify this value to return the number of Unicode characters written in 'out_uni_arr' array. |
A char_code is mapped to Unicode private area when the information required for proper mapping is missing in PDF document (e.g. a predefined encoding or ToUnicode CMap).
bool pdftron::PDF::Font::MapToUnicode | ( | UInt32 | char_code, |
Unicode * | out_uni_arr, | ||
const int | in_uni_sz, | ||
int & | out_chars | ||
) |