/**************************************************************************** * * ftadvanc.h * * Quick computation of advance widths (specification only). * * Copyright 2008-2018 by * David Turner, Robert Wilhelm, and Werner Lemberg. * * This file is part of the FreeType project, and may only be used, * modified, and distributed under the terms of the FreeType project * license, LICENSE.TXT. By continuing to use, modify, or distribute * this file you indicate that you have read the license and * understand and accept it fully. * */ #ifndef FTADVANC_H_ #define FTADVANC_H_ #include #include FT_FREETYPE_H #ifdef FREETYPE_H #error "freetype.h of FreeType 1 has been loaded!" #error "Please fix the directory search order for header files" #error "so that freetype.h of FreeType 2 is found first." #endif FT_BEGIN_HEADER /************************************************************************** * * @section: * quick_advance * * @title: * Quick retrieval of advance values * * @abstract: * Retrieve horizontal and vertical advance values without processing * glyph outlines, if possible. * * @description: * This section contains functions to quickly extract advance values * without handling glyph outlines, if possible. * * @order: * FT_Get_Advance * FT_Get_Advances * */ /************************************************************************** * * @enum: * FT_ADVANCE_FLAG_FAST_ONLY * * @description: * A bit-flag to be OR-ed with the 'flags' parameter of the * @FT_Get_Advance and @FT_Get_Advances functions. * * If set, it indicates that you want these functions to fail if the * corresponding hinting mode or font driver doesn't allow for very * quick advance computation. * * Typically, glyphs that are either unscaled, unhinted, bitmapped, * or light-hinted can have their advance width computed very * quickly. * * Normal and bytecode hinted modes that require loading, scaling, * and hinting of the glyph outline, are extremely slow by * comparison. */ #define FT_ADVANCE_FLAG_FAST_ONLY 0x20000000L /************************************************************************** * * @function: * FT_Get_Advance * * @description: * Retrieve the advance value of a given glyph outline in an * @FT_Face. * * @input: * face :: * The source @FT_Face handle. * * gindex :: * The glyph index. * * load_flags :: * A set of bit flags similar to those used when * calling @FT_Load_Glyph, used to determine what kind * of advances you need. * @output: * padvance :: * The advance value. If scaling is performed (based on * the value of `load_flags`), the advance value is in * 16.16 format. Otherwise, it is in font units. * * If @FT_LOAD_VERTICAL_LAYOUT is set, this is the * vertical advance corresponding to a vertical layout. * Otherwise, it is the horizontal advance in a * horizontal layout. * * @return: * FreeType error code. 0 means success. * * @note: * This function may fail if you use @FT_ADVANCE_FLAG_FAST_ONLY and * if the corresponding font backend doesn't have a quick way to * retrieve the advances. * * A scaled advance is returned in 16.16 format but isn't transformed * by the affine transformation specified by @FT_Set_Transform. */ FT_EXPORT( FT_Error ) FT_Get_Advance( FT_Face face, FT_UInt gindex, FT_Int32 load_flags, FT_Fixed *padvance ); /************************************************************************** * * @function: * FT_Get_Advances * * @description: * Retrieve the advance values of several glyph outlines in an * @FT_Face. * * @input: * face :: * The source @FT_Face handle. * * start :: * The first glyph index. * * count :: * The number of advance values you want to retrieve. * * load_flags :: * A set of bit flags similar to those used when * calling @FT_Load_Glyph. * * @output: * padvance :: * The advance values. This array, to be provided by the * caller, must contain at least 'count' elements. * * If scaling is performed (based on the value of * `load_flags`), the advance values are in 16.16 format. * Otherwise, they are in font units. * * If @FT_LOAD_VERTICAL_LAYOUT is set, these are the * vertical advances corresponding to a vertical layout. * Otherwise, they are the horizontal advances in a * horizontal layout. * * @return: * FreeType error code. 0 means success. * * @note: * This function may fail if you use @FT_ADVANCE_FLAG_FAST_ONLY and * if the corresponding font backend doesn't have a quick way to * retrieve the advances. * * Scaled advances are returned in 16.16 format but aren't * transformed by the affine transformation specified by * @FT_Set_Transform. */ FT_EXPORT( FT_Error ) FT_Get_Advances( FT_Face face, FT_UInt start, FT_UInt count, FT_Int32 load_flags, FT_Fixed *padvances ); /* */ FT_END_HEADER #endif /* FTADVANC_H_ */ /* END */