mupdf
Loading...
Searching...
No Matches
font.h File Reference
Include dependency graph for font.h:
This graph shows which files directly or indirectly include this file:

Go to the source code of this file.

Classes

struct  fz_text_decoder
struct  fz_font_flags_t
struct  fz_shaper_data_t
struct  fz_font

Macros

#define FZ_MAX_TRUSTWORTHY_ASCENT   8
#define FZ_MAX_TRUSTWORTHY_DESCENT   -3

Typedefs

typedef struct fz_text_decoder fz_text_decoder
typedef struct fz_font fz_font
typedef fz_fontfz_load_system_font_fn(fz_context *ctx, const char *name, int bold, int italic, int needs_exact_metrics)
typedef fz_fontfz_load_system_cjk_font_fn(fz_context *ctx, const char *name, int ordering, int serif)
typedef fz_fontfz_load_system_fallback_font_fn(fz_context *ctx, int script, int language, int serif, int bold, int italic)
typedef void fz_cmap_callback(fz_context *ctx, void *opaque, unsigned long ucs, unsigned int gid)

Enumerations

enum  { FZ_ADOBE_CNS , FZ_ADOBE_GB , FZ_ADOBE_JAPAN , FZ_ADOBE_KOREA }
enum  fz_ascdesc_source { FZ_ASCDESC_FROM_FONT , FZ_ASCDESC_DEFAULT , FZ_ASCDESC_FROM_BOUNDS }

Functions

int fz_iso8859_1_from_unicode (int u)
int fz_iso8859_7_from_unicode (int u)
int fz_koi8u_from_unicode (int u)
int fz_windows_1250_from_unicode (int u)
int fz_windows_1251_from_unicode (int u)
int fz_windows_1252_from_unicode (int u)
int fz_unicode_from_glyph_name (const char *name)
int fz_unicode_from_glyph_name_strict (const char *name)
const char ** fz_duplicate_glyph_names_from_unicode (int unicode)
const char * fz_glyph_name_from_unicode_sc (int unicode)
void fz_init_text_decoder (fz_context *ctx, fz_text_decoder *dec, const char *encoding)
void * fz_font_ft_face (fz_context *ctx, fz_font *font)
fz_buffer ** fz_font_t3_procs (fz_context *ctx, fz_font *font)
fz_font_flags_tfz_font_flags (fz_font *font)
fz_shaper_data_tfz_font_shaper_data (fz_context *ctx, fz_font *font)
const char * fz_font_name (fz_context *ctx, fz_font *font)
int fz_font_is_bold (fz_context *ctx, fz_font *font)
int fz_font_is_italic (fz_context *ctx, fz_font *font)
int fz_font_is_serif (fz_context *ctx, fz_font *font)
int fz_font_is_monospaced (fz_context *ctx, fz_font *font)
fz_rect fz_font_bbox (fz_context *ctx, fz_font *font)
void fz_install_load_system_font_funcs (fz_context *ctx, fz_load_system_font_fn *f, fz_load_system_cjk_font_fn *f_cjk, fz_load_system_fallback_font_fn *f_fallback)
fz_fontfz_load_system_font (fz_context *ctx, const char *name, int bold, int italic, int needs_exact_metrics)
fz_fontfz_load_system_cjk_font (fz_context *ctx, const char *name, int ordering, int serif)
const unsigned char * fz_lookup_builtin_font (fz_context *ctx, const char *name, int bold, int italic, int *len)
const unsigned char * fz_lookup_base14_font (fz_context *ctx, const char *name, int *len)
const unsigned char * fz_lookup_cjk_font (fz_context *ctx, int ordering, int *len, int *index)
const unsigned char * fz_lookup_cjk_font_by_language (fz_context *ctx, const char *lang, int *len, int *subfont)
int fz_lookup_cjk_ordering_by_language (const char *name)
const unsigned char * fz_lookup_noto_font (fz_context *ctx, int script, int lang, int *len, int *subfont)
const unsigned char * fz_lookup_noto_math_font (fz_context *ctx, int *len)
const unsigned char * fz_lookup_noto_music_font (fz_context *ctx, int *len)
const unsigned char * fz_lookup_noto_symbol1_font (fz_context *ctx, int *len)
const unsigned char * fz_lookup_noto_symbol2_font (fz_context *ctx, int *len)
const unsigned char * fz_lookup_noto_emoji_font (fz_context *ctx, int *len)
const unsigned char * fz_lookup_noto_boxes_font (fz_context *ctx, int *len)
const char * fz_lookup_noto_stem_from_script (fz_context *ctx, int script, int language)
const char * fz_lookup_script_name (fz_context *ctx, int script, int language)
fz_fontfz_load_fallback_font (fz_context *ctx, int script, int language, int serif, int bold, int italic)
fz_fontfz_new_type3_font (fz_context *ctx, const char *name, fz_matrix matrix)
fz_fontfz_new_font_from_memory (fz_context *ctx, const char *name, const unsigned char *data, int len, int index, int use_glyph_bbox)
fz_fontfz_new_font_from_buffer (fz_context *ctx, const char *name, fz_buffer *buffer, int index, int use_glyph_bbox)
fz_fontfz_new_font_from_file (fz_context *ctx, const char *name, const char *path, int index, int use_glyph_bbox)
fz_fontfz_new_base14_font (fz_context *ctx, const char *name)
fz_fontfz_new_cjk_font (fz_context *ctx, int ordering)
fz_fontfz_new_builtin_font (fz_context *ctx, const char *name, int is_bold, int is_italic)
void fz_set_font_embedding (fz_context *ctx, fz_font *font, int embed)
fz_fontfz_keep_font (fz_context *ctx, fz_font *font)
void fz_drop_font (fz_context *ctx, fz_font *font)
void fz_set_font_bbox (fz_context *ctx, fz_font *font, float xmin, float ymin, float xmax, float ymax)
fz_rect fz_bound_glyph (fz_context *ctx, fz_font *font, int gid, fz_matrix trm)
int fz_glyph_cacheable (fz_context *ctx, fz_font *font, int gid)
void fz_run_t3_glyph (fz_context *ctx, fz_font *font, int gid, fz_matrix trm, struct fz_device *dev)
float fz_advance_glyph (fz_context *ctx, fz_font *font, int glyph, int wmode)
int fz_encode_character (fz_context *ctx, fz_font *font, int unicode)
int fz_encode_character_sc (fz_context *ctx, fz_font *font, int unicode)
int fz_encode_character_by_glyph_name (fz_context *ctx, fz_font *font, const char *glyphname)
int fz_encode_character_with_fallback (fz_context *ctx, fz_font *font, int unicode, int script, int language, fz_font **out_font)
void fz_get_glyph_name (fz_context *ctx, fz_font *font, int glyph, char *buf, int size)
float fz_font_ascender (fz_context *ctx, fz_font *font)
float fz_font_descender (fz_context *ctx, fz_font *font)
void fz_font_digest (fz_context *ctx, fz_font *font, unsigned char digest[16])
void fz_decouple_type3_font (fz_context *ctx, fz_font *font, void *t3doc)
const char * ft_error_string (int err)
int ft_char_index (void *face, int cid)
int ft_name_index (void *face, const char *name)
void fz_hb_lock (fz_context *ctx)
void fz_hb_unlock (fz_context *ctx)
void fz_enumerate_font_cmap (fz_context *ctx, fz_font *font, fz_cmap_callback *cb, void *opaque)
void fz_calculate_font_ascender_descender (fz_context *ctx, fz_font *font)
void fz_ft_lock (fz_context *ctx)
void fz_ft_unlock (fz_context *ctx)
int fz_ft_lock_held (fz_context *ctx)
fz_bufferfz_extract_ttf_from_ttc (fz_context *ctx, fz_font *font)
fz_bufferfz_subset_ttf_for_gids (fz_context *ctx, fz_buffer *orig, int *gids, int num_gids, int symbolic, int cidfont)
fz_bufferfz_subset_cff_for_gids (fz_context *ctx, fz_buffer *orig, int *gids, int num_gids, int symbolic, int cidfont)

Variables

FZ_DATA const char * fz_glyph_name_from_adobe_standard [256]
FZ_DATA const char * fz_glyph_name_from_iso8859_7 [256]
FZ_DATA const char * fz_glyph_name_from_koi8u [256]
FZ_DATA const char * fz_glyph_name_from_mac_expert [256]
FZ_DATA const char * fz_glyph_name_from_mac_roman [256]
FZ_DATA const char * fz_glyph_name_from_win_ansi [256]
FZ_DATA const char * fz_glyph_name_from_windows_1252 [256]
FZ_DATA const unsigned short fz_unicode_from_iso8859_1 [256]
FZ_DATA const unsigned short fz_unicode_from_iso8859_7 [256]
FZ_DATA const unsigned short fz_unicode_from_koi8u [256]
FZ_DATA const unsigned short fz_unicode_from_pdf_doc_encoding [256]
FZ_DATA const unsigned short fz_unicode_from_windows_1250 [256]
FZ_DATA const unsigned short fz_unicode_from_windows_1251 [256]
FZ_DATA const unsigned short fz_unicode_from_windows_1252 [256]

Macro Definition Documentation

◆ FZ_MAX_TRUSTWORTHY_ASCENT

#define FZ_MAX_TRUSTWORTHY_ASCENT   8

◆ FZ_MAX_TRUSTWORTHY_DESCENT

#define FZ_MAX_TRUSTWORTHY_DESCENT   -3

Typedef Documentation

◆ fz_cmap_callback

typedef void fz_cmap_callback(fz_context *ctx, void *opaque, unsigned long ucs, unsigned int gid)

Callback for use in font cmap enumeration.

◆ fz_font

typedef struct fz_font fz_font

An abstract font handle.

◆ fz_load_system_cjk_font_fn

typedef fz_font * fz_load_system_cjk_font_fn(fz_context *ctx, const char *name, int ordering, int serif)

Type for user supplied cjk font loading hook.

name: The name of the font to load.

ordering: The ordering for which to load the font (e.g. FZ_ADOBE_KOREA)

serif: 1 if a serif font is desired, 0 otherwise.

Returns a new font handle, or NULL if no font found (or on error).

◆ fz_load_system_fallback_font_fn

typedef fz_font * fz_load_system_fallback_font_fn(fz_context *ctx, int script, int language, int serif, int bold, int italic)

Type for user supplied fallback font loading hook.

name: The name of the font to load.

script: UCDN script enum.

language: FZ_LANG enum.

serif, bold, italic: boolean style flags.

Returns a new font handle, or NULL if no font found (or on error).

◆ fz_load_system_font_fn

typedef fz_font * fz_load_system_font_fn(fz_context *ctx, const char *name, int bold, int italic, int needs_exact_metrics)

Type for user supplied system font loading hook.

name: The name of the font to load.

bold: 1 if a bold font desired, 0 otherwise.

italic: 1 if an italic font desired, 0 otherwise. needs_exact_metrics: 1 if an exact metric match is required for the font requested.

Returns a new font handle, or NULL if no font found (or on error).

◆ fz_text_decoder

typedef struct fz_text_decoder fz_text_decoder

A text decoder (to read arbitrary encodings and convert to unicode).

Enumeration Type Documentation

◆ anonymous enum

anonymous enum
Enumerator
FZ_ADOBE_CNS 
FZ_ADOBE_GB 
FZ_ADOBE_JAPAN 
FZ_ADOBE_KOREA 

◆ fz_ascdesc_source

Enumerator
FZ_ASCDESC_FROM_FONT 
FZ_ASCDESC_DEFAULT 
FZ_ASCDESC_FROM_BOUNDS 

Function Documentation

◆ ft_char_index()

int ft_char_index ( void * face,
int cid )

◆ ft_error_string()

const char * ft_error_string ( int err)

map an FT error number to a static string.

err: The error number to lookup.

Returns a pointer to a static textual representation of a freetype error.

◆ ft_name_index()

int ft_name_index ( void * face,
const char * name )

◆ fz_advance_glyph()

float fz_advance_glyph ( fz_context * ctx,
fz_font * font,
int glyph,
int wmode )

Return the advance for a given glyph.

font: The font to look for the glyph in.

glyph: The glyph to find the advance for.

wmode: 1 for vertical mode, 0 for horizontal.

Returns the advance for the glyph.

◆ fz_bound_glyph()

fz_rect fz_bound_glyph ( fz_context * ctx,
fz_font * font,
int gid,
fz_matrix trm )

Return a bbox for a given glyph in a font.

font: The font to look for the glyph in.

gid: The glyph to bound.

trm: The matrix to apply to the glyph before bounding.

Returns rectangle by value containing the bounds of the given glyph.

◆ fz_calculate_font_ascender_descender()

void fz_calculate_font_ascender_descender ( fz_context * ctx,
fz_font * font )

Ensure that a font has its ascender/descender values calculated from the actual bbox of the glyphs.

Note, that we combine the declared values from the font (or the default values if those are not present) with the actual bbox to get the final result. So this can only cause ascender/descender to move further apart!

◆ fz_decouple_type3_font()

void fz_decouple_type3_font ( fz_context * ctx,
fz_font * font,
void * t3doc )

◆ fz_drop_font()

void fz_drop_font ( fz_context * ctx,
fz_font * font )

Drop a reference to a fz_font, destroying the font when the last reference is dropped.

font: The font to drop a reference to.

◆ fz_duplicate_glyph_names_from_unicode()

const char ** fz_duplicate_glyph_names_from_unicode ( int unicode)

◆ fz_encode_character()

int fz_encode_character ( fz_context * ctx,
fz_font * font,
int unicode )

Find the glyph id for a given unicode character within a font.

font: The font to look for the unicode character in.

unicode: The unicode character to encode.

Returns the glyph id for the given unicode value, or 0 if unknown.

◆ fz_encode_character_by_glyph_name()

int fz_encode_character_by_glyph_name ( fz_context * ctx,
fz_font * font,
const char * glyphname )

Encode character.

Either by direct lookup of glyphname within a font, or, failing that, by mapping glyphname to unicode and thence to the glyph index within the given font.

Returns zero for type3 fonts.

◆ fz_encode_character_sc()

int fz_encode_character_sc ( fz_context * ctx,
fz_font * font,
int unicode )

Encode character, preferring small-caps variant if available.

font: The font to look for the unicode character in.

unicode: The unicode character to encode.

Returns the glyph id for the given unicode value, or 0 if unknown.

◆ fz_encode_character_with_fallback()

int fz_encode_character_with_fallback ( fz_context * ctx,
fz_font * font,
int unicode,
int script,
int language,
fz_font ** out_font )

Find the glyph id for a given unicode character within a font, falling back to an alternative if not found.

font: The font to look for the unicode character in.

unicode: The unicode character to encode.

script: The script in use.

language: The language in use.

out_font: The font handle in which the given glyph represents the requested unicode character. The caller does not own the reference it is passed, so should call fz_keep_font if it is not simply to be used immediately.

Returns the glyph id for the given unicode value in the supplied font (and sets *out_font to font) if it is present. Otherwise an alternative fallback font (based on script/language) is searched for. If the glyph is found therein, *out_font is set to this reference, and the glyph reference is returned. If it cannot be found anywhere, the function returns 0.

◆ fz_enumerate_font_cmap()

void fz_enumerate_font_cmap ( fz_context * ctx,
fz_font * font,
fz_cmap_callback * cb,
void * opaque )

Enumerate a cmap using a callback.

◆ fz_extract_ttf_from_ttc()

fz_buffer * fz_extract_ttf_from_ttc ( fz_context * ctx,
fz_font * font )

◆ fz_font_ascender()

float fz_font_ascender ( fz_context * ctx,
fz_font * font )

Retrieve font ascender in ems.

◆ fz_font_bbox()

fz_rect fz_font_bbox ( fz_context * ctx,
fz_font * font )

Retrieve the font bbox.

font: The font to query.

Returns the font bbox by value; it is valid only if fz_font_flags(font)->invalid_bbox is zero.

◆ fz_font_descender()

float fz_font_descender ( fz_context * ctx,
fz_font * font )

Retrieve font descender in ems.

◆ fz_font_digest()

void fz_font_digest ( fz_context * ctx,
fz_font * font,
unsigned char digest[16] )

Retrieve the MD5 digest for the font's data.

◆ fz_font_flags()

fz_font_flags_t * fz_font_flags ( fz_font * font)

Retrieve a pointer to the font flags for a given font. These can then be updated as required.

font: The font to query

Returns a pointer to the flags structure (or NULL, if the font is NULL).

◆ fz_font_ft_face()

void * fz_font_ft_face ( fz_context * ctx,
fz_font * font )

Fonts come in two variants: Regular fonts are handled by FreeType. Type 3 fonts have callbacks to the interpreter. Retrieve the FT_Face handle for the font.

font: The font to query

Returns the FT_Face handle for the font, or NULL if not a freetype handled font. (Cast to void * to avoid nasty header exposure).

◆ fz_font_is_bold()

int fz_font_is_bold ( fz_context * ctx,
fz_font * font )

Query whether the font flags say that this font is bold.

◆ fz_font_is_italic()

int fz_font_is_italic ( fz_context * ctx,
fz_font * font )

Query whether the font flags say that this font is italic.

◆ fz_font_is_monospaced()

int fz_font_is_monospaced ( fz_context * ctx,
fz_font * font )

Query whether the font flags say that this font is monospaced.

◆ fz_font_is_serif()

int fz_font_is_serif ( fz_context * ctx,
fz_font * font )

Query whether the font flags say that this font is serif.

◆ fz_font_name()

const char * fz_font_name ( fz_context * ctx,
fz_font * font )

Retrieve a pointer to the name of the font.

font: The font to query.

Returns a pointer to an internal copy of the font name. Will never be NULL, but may be the empty string.

◆ fz_font_shaper_data()

fz_shaper_data_t * fz_font_shaper_data ( fz_context * ctx,
fz_font * font )

Retrieve a pointer to the shaper data structure for the given font.

font: The font to query.

Returns a pointer to the shaper data structure (or NULL if font is NULL).

◆ fz_font_t3_procs()

fz_buffer ** fz_font_t3_procs ( fz_context * ctx,
fz_font * font )

Retrieve the Type3 procs for a font.

font: The font to query

Returns the t3_procs pointer. Will be NULL for a non type-3 font.

◆ fz_ft_lock()

void fz_ft_lock ( fz_context * ctx)

◆ fz_ft_lock_held()

int fz_ft_lock_held ( fz_context * ctx)

◆ fz_ft_unlock()

void fz_ft_unlock ( fz_context * ctx)

◆ fz_get_glyph_name()

void fz_get_glyph_name ( fz_context * ctx,
fz_font * font,
int glyph,
char * buf,
int size )

Find the name of a glyph

font: The font to look for the glyph in.

glyph: The glyph id to look for.

buf: Pointer to a buffer for the name to be inserted into.

size: The size of the buffer.

If a font contains a name table, then the name of the glyph will be returned in the supplied buffer. Otherwise a name is synthesised. The name will be truncated to fit in the buffer.

◆ fz_glyph_cacheable()

int fz_glyph_cacheable ( fz_context * ctx,
fz_font * font,
int gid )

Determine if a given glyph in a font is cacheable. Certain glyphs in a type 3 font cannot safely be cached, as their appearance depends on the enclosing graphic state.

font: The font to look for the glyph in.

gif: The glyph to query.

Returns non-zero if cacheable, 0 if not.

◆ fz_glyph_name_from_unicode_sc()

const char * fz_glyph_name_from_unicode_sc ( int unicode)

◆ fz_hb_lock()

void fz_hb_lock ( fz_context * ctx)

Internal functions for our Harfbuzz integration to work around the lack of thread safety. Lock against Harfbuzz being called simultaneously in several threads. This reuses FZ_LOCK_FREETYPE.

◆ fz_hb_unlock()

void fz_hb_unlock ( fz_context * ctx)

Unlock after a Harfbuzz call. This reuses FZ_LOCK_FREETYPE.

◆ fz_init_text_decoder()

void fz_init_text_decoder ( fz_context * ctx,
fz_text_decoder * dec,
const char * encoding )

◆ fz_install_load_system_font_funcs()

void fz_install_load_system_font_funcs ( fz_context * ctx,
fz_load_system_font_fn * f,
fz_load_system_cjk_font_fn * f_cjk,
fz_load_system_fallback_font_fn * f_fallback )

Install functions to allow MuPDF to request fonts from the system.

Only one set of hooks can be in use at a time.

◆ fz_iso8859_1_from_unicode()

int fz_iso8859_1_from_unicode ( int u)

◆ fz_iso8859_7_from_unicode()

int fz_iso8859_7_from_unicode ( int u)

◆ fz_keep_font()

fz_font * fz_keep_font ( fz_context * ctx,
fz_font * font )

Add a reference to an existing fz_font.

font: The font to add a reference to.

Returns the same font.

◆ fz_koi8u_from_unicode()

int fz_koi8u_from_unicode ( int u)

◆ fz_load_fallback_font()

fz_font * fz_load_fallback_font ( fz_context * ctx,
int script,
int language,
int serif,
int bold,
int italic )

Try to load a fallback font for the given combination of font attributes. Whether a font is present or not will depend on the configuration in which MuPDF is built.

script: The script desired (e.g. UCDN_SCRIPT_KATAKANA).

language: The language desired (e.g. FZ_LANG_ja).

serif: 1 if serif desired, 0 otherwise.

bold: 1 if bold desired, 0 otherwise.

italic: 1 if italic desired, 0 otherwise.

Returns a new font handle, or NULL if not available.

◆ fz_load_system_cjk_font()

fz_font * fz_load_system_cjk_font ( fz_context * ctx,
const char * name,
int ordering,
int serif )

Attempt to load a given font from the system.

name: The name of the desired font.

ordering: The ordering to load the font from (e.g. FZ_ADOBE_KOREA)

serif: 1 if serif desired, 0 otherwise.

Returns a new font handle, or NULL if no matching font was found (or on error).

◆ fz_load_system_font()

fz_font * fz_load_system_font ( fz_context * ctx,
const char * name,
int bold,
int italic,
int needs_exact_metrics )

Attempt to load a given font from the system.

name: The name of the desired font.

bold: 1 if bold desired, 0 otherwise.

italic: 1 if italic desired, 0 otherwise.

needs_exact_metrics: 1 if an exact metrical match is required, 0 otherwise.

Returns a new font handle, or NULL if no matching font was found (or on error).

◆ fz_lookup_base14_font()

const unsigned char * fz_lookup_base14_font ( fz_context * ctx,
const char * name,
int * len )

Search the builtin base14 fonts for a match. Whether a given font is present or not will depend on the configuration in which MuPDF is built.

name: The name of the font desired.

len: Pointer to a place to receive the length of the discovered font buffer.

Returns a pointer to the font file data, or NULL if not present.

◆ fz_lookup_builtin_font()

const unsigned char * fz_lookup_builtin_font ( fz_context * ctx,
const char * name,
int bold,
int italic,
int * len )

Search the builtin fonts for a match. Whether a given font is present or not will depend on the configuration in which MuPDF is built.

name: The name of the font desired.

bold: 1 if bold desired, 0 otherwise.

italic: 1 if italic desired, 0 otherwise.

len: Pointer to a place to receive the length of the discovered font buffer.

Returns a pointer to the font file data, or NULL if not present.

◆ fz_lookup_cjk_font()

const unsigned char * fz_lookup_cjk_font ( fz_context * ctx,
int ordering,
int * len,
int * index )

Search the builtin cjk fonts for a match. Whether a font is present or not will depend on the configuration in which MuPDF is built.

ordering: The desired ordering of the font (e.g. FZ_ADOBE_KOREA).

len: Pointer to a place to receive the length of the discovered font buffer.

Returns a pointer to the font file data, or NULL if not present.

◆ fz_lookup_cjk_font_by_language()

const unsigned char * fz_lookup_cjk_font_by_language ( fz_context * ctx,
const char * lang,
int * len,
int * subfont )

Search the builtin cjk fonts for a match for a given language. Whether a font is present or not will depend on the configuration in which MuPDF is built.

lang: Pointer to a (case sensitive) language string (e.g. "ja", "ko", "zh-Hant" etc).

len: Pointer to a place to receive the length of the discovered font buffer.

subfont: Pointer to a place to store the subfont index of the discovered font.

Returns a pointer to the font file data, or NULL if not present.

◆ fz_lookup_cjk_ordering_by_language()

int fz_lookup_cjk_ordering_by_language ( const char * name)

Return the matching FZ_ADOBE_* ordering for the given language tag, such as "zh-Hant", "zh-Hans", "ja", or "ko".

◆ fz_lookup_noto_boxes_font()

const unsigned char * fz_lookup_noto_boxes_font ( fz_context * ctx,
int * len )

◆ fz_lookup_noto_emoji_font()

const unsigned char * fz_lookup_noto_emoji_font ( fz_context * ctx,
int * len )

◆ fz_lookup_noto_font()

const unsigned char * fz_lookup_noto_font ( fz_context * ctx,
int script,
int lang,
int * len,
int * subfont )

Search the builtin noto fonts for a match. Whether a font is present or not will depend on the configuration in which MuPDF is built.

script: The script desired (e.g. UCDN_SCRIPT_KATAKANA).

lang: The language desired (e.g. FZ_LANG_ja).

len: Pointer to a place to receive the length of the discovered font buffer.

Returns a pointer to the font file data, or NULL if not present.

◆ fz_lookup_noto_math_font()

const unsigned char * fz_lookup_noto_math_font ( fz_context * ctx,
int * len )

Search the builtin noto fonts specific symbol fonts. Whether a font is present or not will depend on the configuration in which MuPDF is built.

◆ fz_lookup_noto_music_font()

const unsigned char * fz_lookup_noto_music_font ( fz_context * ctx,
int * len )

◆ fz_lookup_noto_stem_from_script()

const char * fz_lookup_noto_stem_from_script ( fz_context * ctx,
int script,
int language )

Look up the Noto font file name for a given script. From the returned font stem, you can look for Noto fonts on the system in the form: Noto(Sans|Serif)${STEM}-Regular.(otf|ttf)

◆ fz_lookup_noto_symbol1_font()

const unsigned char * fz_lookup_noto_symbol1_font ( fz_context * ctx,
int * len )

◆ fz_lookup_noto_symbol2_font()

const unsigned char * fz_lookup_noto_symbol2_font ( fz_context * ctx,
int * len )

◆ fz_lookup_script_name()

const char * fz_lookup_script_name ( fz_context * ctx,
int script,
int language )

◆ fz_new_base14_font()

fz_font * fz_new_base14_font ( fz_context * ctx,
const char * name )

Create a new font from one of the built-in fonts.

◆ fz_new_builtin_font()

fz_font * fz_new_builtin_font ( fz_context * ctx,
const char * name,
int is_bold,
int is_italic )

◆ fz_new_cjk_font()

fz_font * fz_new_cjk_font ( fz_context * ctx,
int ordering )

◆ fz_new_font_from_buffer()

fz_font * fz_new_font_from_buffer ( fz_context * ctx,
const char * name,
fz_buffer * buffer,
int index,
int use_glyph_bbox )

Create a new font from a font file in a fz_buffer.

Fonts created in this way, will be eligible for embedding by default.

name: Name of font (leave NULL to use name from font).

buffer: Buffer to load from.

index: Which font from the file to load (0 for default).

use_glyph_box: 1 if we should use the glyph bbox, 0 otherwise.

Returns new font handle, or throws exception on error.

◆ fz_new_font_from_file()

fz_font * fz_new_font_from_file ( fz_context * ctx,
const char * name,
const char * path,
int index,
int use_glyph_bbox )

Create a new font from a font file.

Fonts created in this way, will be eligible for embedding by default.

name: Name of font (leave NULL to use name from font).

path: File path to load from.

index: Which font from the file to load (0 for default).

use_glyph_box: 1 if we should use the glyph bbox, 0 otherwise.

Returns new font handle, or throws exception on error.

◆ fz_new_font_from_memory()

fz_font * fz_new_font_from_memory ( fz_context * ctx,
const char * name,
const unsigned char * data,
int len,
int index,
int use_glyph_bbox )

Create a new font from a font file in memory.

Fonts created in this way, will be eligible for embedding by default.

name: Name of font (leave NULL to use name from font).

data: Pointer to the font file data.

len: Length of the font file data.

index: Which font from the file to load (0 for default).

use_glyph_box: 1 if we should use the glyph bbox, 0 otherwise.

Returns new font handle, or throws exception on error.

◆ fz_new_type3_font()

fz_font * fz_new_type3_font ( fz_context * ctx,
const char * name,
fz_matrix matrix )

Create a new (empty) type3 font.

name: Name of font (or NULL).

matrix: Font matrix.

Returns a new font handle, or throws exception on allocation failure.

◆ fz_run_t3_glyph()

void fz_run_t3_glyph ( fz_context * ctx,
fz_font * font,
int gid,
fz_matrix trm,
struct fz_device * dev )

Run a glyph from a Type3 font to a given device.

font: The font to find the glyph in.

gid: The glyph to run.

trm: The transform to apply.

dev: The device to render onto.

◆ fz_set_font_bbox()

void fz_set_font_bbox ( fz_context * ctx,
fz_font * font,
float xmin,
float ymin,
float xmax,
float ymax )

Set the font bbox.

font: The font to set the bbox for.

xmin, ymin, xmax, ymax: The bounding box.

◆ fz_set_font_embedding()

void fz_set_font_embedding ( fz_context * ctx,
fz_font * font,
int embed )

Control whether a given font should be embedded or not when writing.

◆ fz_subset_cff_for_gids()

fz_buffer * fz_subset_cff_for_gids ( fz_context * ctx,
fz_buffer * orig,
int * gids,
int num_gids,
int symbolic,
int cidfont )

◆ fz_subset_ttf_for_gids()

fz_buffer * fz_subset_ttf_for_gids ( fz_context * ctx,
fz_buffer * orig,
int * gids,
int num_gids,
int symbolic,
int cidfont )

◆ fz_unicode_from_glyph_name()

int fz_unicode_from_glyph_name ( const char * name)

◆ fz_unicode_from_glyph_name_strict()

int fz_unicode_from_glyph_name_strict ( const char * name)

◆ fz_windows_1250_from_unicode()

int fz_windows_1250_from_unicode ( int u)

◆ fz_windows_1251_from_unicode()

int fz_windows_1251_from_unicode ( int u)

◆ fz_windows_1252_from_unicode()

int fz_windows_1252_from_unicode ( int u)

Variable Documentation

◆ fz_glyph_name_from_adobe_standard

FZ_DATA const char* fz_glyph_name_from_adobe_standard[256]
extern

◆ fz_glyph_name_from_iso8859_7

FZ_DATA const char* fz_glyph_name_from_iso8859_7[256]
extern

◆ fz_glyph_name_from_koi8u

FZ_DATA const char* fz_glyph_name_from_koi8u[256]
extern

◆ fz_glyph_name_from_mac_expert

FZ_DATA const char* fz_glyph_name_from_mac_expert[256]
extern

◆ fz_glyph_name_from_mac_roman

FZ_DATA const char* fz_glyph_name_from_mac_roman[256]
extern

◆ fz_glyph_name_from_win_ansi

FZ_DATA const char* fz_glyph_name_from_win_ansi[256]
extern

◆ fz_glyph_name_from_windows_1252

FZ_DATA const char* fz_glyph_name_from_windows_1252[256]
extern

◆ fz_unicode_from_iso8859_1

FZ_DATA const unsigned short fz_unicode_from_iso8859_1[256]
extern

◆ fz_unicode_from_iso8859_7

FZ_DATA const unsigned short fz_unicode_from_iso8859_7[256]
extern

◆ fz_unicode_from_koi8u

FZ_DATA const unsigned short fz_unicode_from_koi8u[256]
extern

◆ fz_unicode_from_pdf_doc_encoding

FZ_DATA const unsigned short fz_unicode_from_pdf_doc_encoding[256]
extern

◆ fz_unicode_from_windows_1250

FZ_DATA const unsigned short fz_unicode_from_windows_1250[256]
extern

◆ fz_unicode_from_windows_1251

FZ_DATA const unsigned short fz_unicode_from_windows_1251[256]
extern

◆ fz_unicode_from_windows_1252

FZ_DATA const unsigned short fz_unicode_from_windows_1252[256]
extern