nuclear@0: /***************************************************************************/ nuclear@0: /* */ nuclear@0: /* ftmm.h */ nuclear@0: /* */ nuclear@0: /* FreeType Multiple Master font interface (specification). */ nuclear@0: /* */ nuclear@0: /* Copyright 1996-2001, 2003, 2004, 2006, 2009 by */ nuclear@0: /* David Turner, Robert Wilhelm, and Werner Lemberg. */ nuclear@0: /* */ nuclear@0: /* This file is part of the FreeType project, and may only be used, */ nuclear@0: /* modified, and distributed under the terms of the FreeType project */ nuclear@0: /* license, LICENSE.TXT. By continuing to use, modify, or distribute */ nuclear@0: /* this file you indicate that you have read the license and */ nuclear@0: /* understand and accept it fully. */ nuclear@0: /* */ nuclear@0: /***************************************************************************/ nuclear@0: nuclear@0: nuclear@0: #ifndef __FTMM_H__ nuclear@0: #define __FTMM_H__ nuclear@0: nuclear@0: nuclear@0: #include nuclear@0: #include FT_TYPE1_TABLES_H nuclear@0: nuclear@0: nuclear@0: FT_BEGIN_HEADER nuclear@0: nuclear@0: nuclear@0: /*************************************************************************/ nuclear@0: /* */ nuclear@0: /*
*/ nuclear@0: /* multiple_masters */ nuclear@0: /* */ nuclear@0: /* */ nuclear@0: /* Multiple Masters */ nuclear@0: /* */ nuclear@0: /* <Abstract> */ nuclear@0: /* How to manage Multiple Masters fonts. */ nuclear@0: /* */ nuclear@0: /* <Description> */ nuclear@0: /* The following types and functions are used to manage Multiple */ nuclear@0: /* Master fonts, i.e., the selection of specific design instances by */ nuclear@0: /* setting design axis coordinates. */ nuclear@0: /* */ nuclear@0: /* George Williams has extended this interface to make it work with */ nuclear@0: /* both Type~1 Multiple Masters fonts and GX distortable (var) */ nuclear@0: /* fonts. Some of these routines only work with MM fonts, others */ nuclear@0: /* will work with both types. They are similar enough that a */ nuclear@0: /* consistent interface makes sense. */ nuclear@0: /* */ nuclear@0: /*************************************************************************/ nuclear@0: nuclear@0: nuclear@0: /*************************************************************************/ nuclear@0: /* */ nuclear@0: /* <Struct> */ nuclear@0: /* FT_MM_Axis */ nuclear@0: /* */ nuclear@0: /* <Description> */ nuclear@0: /* A simple structure used to model a given axis in design space for */ nuclear@0: /* Multiple Masters fonts. */ nuclear@0: /* */ nuclear@0: /* This structure can't be used for GX var fonts. */ nuclear@0: /* */ nuclear@0: /* <Fields> */ nuclear@0: /* name :: The axis's name. */ nuclear@0: /* */ nuclear@0: /* minimum :: The axis's minimum design coordinate. */ nuclear@0: /* */ nuclear@0: /* maximum :: The axis's maximum design coordinate. */ nuclear@0: /* */ nuclear@0: typedef struct FT_MM_Axis_ nuclear@0: { nuclear@0: FT_String* name; nuclear@0: FT_Long minimum; nuclear@0: FT_Long maximum; nuclear@0: nuclear@0: } FT_MM_Axis; nuclear@0: nuclear@0: nuclear@0: /*************************************************************************/ nuclear@0: /* */ nuclear@0: /* <Struct> */ nuclear@0: /* FT_Multi_Master */ nuclear@0: /* */ nuclear@0: /* <Description> */ nuclear@0: /* A structure used to model the axes and space of a Multiple Masters */ nuclear@0: /* font. */ nuclear@0: /* */ nuclear@0: /* This structure can't be used for GX var fonts. */ nuclear@0: /* */ nuclear@0: /* <Fields> */ nuclear@0: /* num_axis :: Number of axes. Cannot exceed~4. */ nuclear@0: /* */ nuclear@0: /* num_designs :: Number of designs; should be normally 2^num_axis */ nuclear@0: /* even though the Type~1 specification strangely */ nuclear@0: /* allows for intermediate designs to be present. This */ nuclear@0: /* number cannot exceed~16. */ nuclear@0: /* */ nuclear@0: /* axis :: A table of axis descriptors. */ nuclear@0: /* */ nuclear@0: typedef struct FT_Multi_Master_ nuclear@0: { nuclear@0: FT_UInt num_axis; nuclear@0: FT_UInt num_designs; nuclear@0: FT_MM_Axis axis[T1_MAX_MM_AXIS]; nuclear@0: nuclear@0: } FT_Multi_Master; nuclear@0: nuclear@0: nuclear@0: /*************************************************************************/ nuclear@0: /* */ nuclear@0: /* <Struct> */ nuclear@0: /* FT_Var_Axis */ nuclear@0: /* */ nuclear@0: /* <Description> */ nuclear@0: /* A simple structure used to model a given axis in design space for */ nuclear@0: /* Multiple Masters and GX var fonts. */ nuclear@0: /* */ nuclear@0: /* <Fields> */ nuclear@0: /* name :: The axis's name. */ nuclear@0: /* Not always meaningful for GX. */ nuclear@0: /* */ nuclear@0: /* minimum :: The axis's minimum design coordinate. */ nuclear@0: /* */ nuclear@0: /* def :: The axis's default design coordinate. */ nuclear@0: /* FreeType computes meaningful default values for MM; it */ nuclear@0: /* is then an integer value, not in 16.16 format. */ nuclear@0: /* */ nuclear@0: /* maximum :: The axis's maximum design coordinate. */ nuclear@0: /* */ nuclear@0: /* tag :: The axis's tag (the GX equivalent to `name'). */ nuclear@0: /* FreeType provides default values for MM if possible. */ nuclear@0: /* */ nuclear@0: /* strid :: The entry in `name' table (another GX version of */ nuclear@0: /* `name'). */ nuclear@0: /* Not meaningful for MM. */ nuclear@0: /* */ nuclear@0: typedef struct FT_Var_Axis_ nuclear@0: { nuclear@0: FT_String* name; nuclear@0: nuclear@0: FT_Fixed minimum; nuclear@0: FT_Fixed def; nuclear@0: FT_Fixed maximum; nuclear@0: nuclear@0: FT_ULong tag; nuclear@0: FT_UInt strid; nuclear@0: nuclear@0: } FT_Var_Axis; nuclear@0: nuclear@0: nuclear@0: /*************************************************************************/ nuclear@0: /* */ nuclear@0: /* <Struct> */ nuclear@0: /* FT_Var_Named_Style */ nuclear@0: /* */ nuclear@0: /* <Description> */ nuclear@0: /* A simple structure used to model a named style in a GX var font. */ nuclear@0: /* */ nuclear@0: /* This structure can't be used for MM fonts. */ nuclear@0: /* */ nuclear@0: /* <Fields> */ nuclear@0: /* coords :: The design coordinates for this style. */ nuclear@0: /* This is an array with one entry for each axis. */ nuclear@0: /* */ nuclear@0: /* strid :: The entry in `name' table identifying this style. */ nuclear@0: /* */ nuclear@0: typedef struct FT_Var_Named_Style_ nuclear@0: { nuclear@0: FT_Fixed* coords; nuclear@0: FT_UInt strid; nuclear@0: nuclear@0: } FT_Var_Named_Style; nuclear@0: nuclear@0: nuclear@0: /*************************************************************************/ nuclear@0: /* */ nuclear@0: /* <Struct> */ nuclear@0: /* FT_MM_Var */ nuclear@0: /* */ nuclear@0: /* <Description> */ nuclear@0: /* A structure used to model the axes and space of a Multiple Masters */ nuclear@0: /* or GX var distortable font. */ nuclear@0: /* */ nuclear@0: /* Some fields are specific to one format and not to the other. */ nuclear@0: /* */ nuclear@0: /* <Fields> */ nuclear@0: /* num_axis :: The number of axes. The maximum value is~4 for */ nuclear@0: /* MM; no limit in GX. */ nuclear@0: /* */ nuclear@0: /* num_designs :: The number of designs; should be normally */ nuclear@0: /* 2^num_axis for MM fonts. Not meaningful for GX */ nuclear@0: /* (where every glyph could have a different */ nuclear@0: /* number of designs). */ nuclear@0: /* */ nuclear@0: /* num_namedstyles :: The number of named styles; only meaningful for */ nuclear@0: /* GX which allows certain design coordinates to */ nuclear@0: /* have a string ID (in the `name' table) */ nuclear@0: /* associated with them. The font can tell the */ nuclear@0: /* user that, for example, Weight=1.5 is `Bold'. */ nuclear@0: /* */ nuclear@0: /* axis :: A table of axis descriptors. */ nuclear@0: /* GX fonts contain slightly more data than MM. */ nuclear@0: /* */ nuclear@0: /* namedstyles :: A table of named styles. */ nuclear@0: /* Only meaningful with GX. */ nuclear@0: /* */ nuclear@0: typedef struct FT_MM_Var_ nuclear@0: { nuclear@0: FT_UInt num_axis; nuclear@0: FT_UInt num_designs; nuclear@0: FT_UInt num_namedstyles; nuclear@0: FT_Var_Axis* axis; nuclear@0: FT_Var_Named_Style* namedstyle; nuclear@0: nuclear@0: } FT_MM_Var; nuclear@0: nuclear@0: nuclear@0: /* */ nuclear@0: nuclear@0: nuclear@0: /*************************************************************************/ nuclear@0: /* */ nuclear@0: /* <Function> */ nuclear@0: /* FT_Get_Multi_Master */ nuclear@0: /* */ nuclear@0: /* <Description> */ nuclear@0: /* Retrieve the Multiple Master descriptor of a given font. */ nuclear@0: /* */ nuclear@0: /* This function can't be used with GX fonts. */ nuclear@0: /* */ nuclear@0: /* <Input> */ nuclear@0: /* face :: A handle to the source face. */ nuclear@0: /* */ nuclear@0: /* <Output> */ nuclear@0: /* amaster :: The Multiple Masters descriptor. */ nuclear@0: /* */ nuclear@0: /* <Return> */ nuclear@0: /* FreeType error code. 0~means success. */ nuclear@0: /* */ nuclear@0: FT_EXPORT( FT_Error ) nuclear@0: FT_Get_Multi_Master( FT_Face face, nuclear@0: FT_Multi_Master *amaster ); nuclear@0: nuclear@0: nuclear@0: /*************************************************************************/ nuclear@0: /* */ nuclear@0: /* <Function> */ nuclear@0: /* FT_Get_MM_Var */ nuclear@0: /* */ nuclear@0: /* <Description> */ nuclear@0: /* Retrieve the Multiple Master/GX var descriptor of a given font. */ nuclear@0: /* */ nuclear@0: /* <Input> */ nuclear@0: /* face :: A handle to the source face. */ nuclear@0: /* */ nuclear@0: /* <Output> */ nuclear@0: /* amaster :: The Multiple Masters/GX var descriptor. */ nuclear@0: /* Allocates a data structure, which the user must free */ nuclear@0: /* (a single call to FT_FREE will do it). */ nuclear@0: /* */ nuclear@0: /* <Return> */ nuclear@0: /* FreeType error code. 0~means success. */ nuclear@0: /* */ nuclear@0: FT_EXPORT( FT_Error ) nuclear@0: FT_Get_MM_Var( FT_Face face, nuclear@0: FT_MM_Var* *amaster ); nuclear@0: nuclear@0: nuclear@0: /*************************************************************************/ nuclear@0: /* */ nuclear@0: /* <Function> */ nuclear@0: /* FT_Set_MM_Design_Coordinates */ nuclear@0: /* */ nuclear@0: /* <Description> */ nuclear@0: /* For Multiple Masters fonts, choose an interpolated font design */ nuclear@0: /* through design coordinates. */ nuclear@0: /* */ nuclear@0: /* This function can't be used with GX fonts. */ nuclear@0: /* */ nuclear@0: /* <InOut> */ nuclear@0: /* face :: A handle to the source face. */ nuclear@0: /* */ nuclear@0: /* <Input> */ nuclear@0: /* num_coords :: The number of design coordinates (must be equal to */ nuclear@0: /* the number of axes in the font). */ nuclear@0: /* */ nuclear@0: /* coords :: An array of design coordinates. */ nuclear@0: /* */ nuclear@0: /* <Return> */ nuclear@0: /* FreeType error code. 0~means success. */ nuclear@0: /* */ nuclear@0: FT_EXPORT( FT_Error ) nuclear@0: FT_Set_MM_Design_Coordinates( FT_Face face, nuclear@0: FT_UInt num_coords, nuclear@0: FT_Long* coords ); nuclear@0: nuclear@0: nuclear@0: /*************************************************************************/ nuclear@0: /* */ nuclear@0: /* <Function> */ nuclear@0: /* FT_Set_Var_Design_Coordinates */ nuclear@0: /* */ nuclear@0: /* <Description> */ nuclear@0: /* For Multiple Master or GX Var fonts, choose an interpolated font */ nuclear@0: /* design through design coordinates. */ nuclear@0: /* */ nuclear@0: /* <InOut> */ nuclear@0: /* face :: A handle to the source face. */ nuclear@0: /* */ nuclear@0: /* <Input> */ nuclear@0: /* num_coords :: The number of design coordinates (must be equal to */ nuclear@0: /* the number of axes in the font). */ nuclear@0: /* */ nuclear@0: /* coords :: An array of design coordinates. */ nuclear@0: /* */ nuclear@0: /* <Return> */ nuclear@0: /* FreeType error code. 0~means success. */ nuclear@0: /* */ nuclear@0: FT_EXPORT( FT_Error ) nuclear@0: FT_Set_Var_Design_Coordinates( FT_Face face, nuclear@0: FT_UInt num_coords, nuclear@0: FT_Fixed* coords ); nuclear@0: nuclear@0: nuclear@0: /*************************************************************************/ nuclear@0: /* */ nuclear@0: /* <Function> */ nuclear@0: /* FT_Set_MM_Blend_Coordinates */ nuclear@0: /* */ nuclear@0: /* <Description> */ nuclear@0: /* For Multiple Masters and GX var fonts, choose an interpolated font */ nuclear@0: /* design through normalized blend coordinates. */ nuclear@0: /* */ nuclear@0: /* <InOut> */ nuclear@0: /* face :: A handle to the source face. */ nuclear@0: /* */ nuclear@0: /* <Input> */ nuclear@0: /* num_coords :: The number of design coordinates (must be equal to */ nuclear@0: /* the number of axes in the font). */ nuclear@0: /* */ nuclear@0: /* coords :: The design coordinates array (each element must be */ nuclear@0: /* between 0 and 1.0). */ nuclear@0: /* */ nuclear@0: /* <Return> */ nuclear@0: /* FreeType error code. 0~means success. */ nuclear@0: /* */ nuclear@0: FT_EXPORT( FT_Error ) nuclear@0: FT_Set_MM_Blend_Coordinates( FT_Face face, nuclear@0: FT_UInt num_coords, nuclear@0: FT_Fixed* coords ); nuclear@0: nuclear@0: nuclear@0: /*************************************************************************/ nuclear@0: /* */ nuclear@0: /* <Function> */ nuclear@0: /* FT_Set_Var_Blend_Coordinates */ nuclear@0: /* */ nuclear@0: /* <Description> */ nuclear@0: /* This is another name of @FT_Set_MM_Blend_Coordinates. */ nuclear@0: /* */ nuclear@0: FT_EXPORT( FT_Error ) nuclear@0: FT_Set_Var_Blend_Coordinates( FT_Face face, nuclear@0: FT_UInt num_coords, nuclear@0: FT_Fixed* coords ); nuclear@0: nuclear@0: nuclear@0: /* */ nuclear@0: nuclear@0: nuclear@0: FT_END_HEADER nuclear@0: nuclear@0: #endif /* __FTMM_H__ */ nuclear@0: nuclear@0: nuclear@0: /* END */