1 /***************************************************************************/ 2 /* */ 3 /* ftwinfnt.h */ 4 /* */ 5 /* FreeType API for accessing Windows fnt-specific data. */ 6 /* */ 7 /* Copyright 2003, 2004, 2008 by */ 8 /* David Turner, Robert Wilhelm, and Werner Lemberg. */ 9 /* */ 10 /* This file is part of the FreeType project, and may only be used, */ 11 /* modified, and distributed under the terms of the FreeType project */ 12 /* license, LICENSE.TXT. By continuing to use, modify, or distribute */ 13 /* this file you indicate that you have read the license and */ 14 /* understand and accept it fully. */ 15 /* */ 16 /***************************************************************************/ 17 18 19 #ifndef __FTWINFNT_H__ 20 #define __FTWINFNT_H__ 21 22 #include <ft2build.h> 23 #include FT_FREETYPE_H 24 25 #ifdef FREETYPE_H 26 #error "freetype.h of FreeType 1 has been loaded!" 27 #error "Please fix the directory search order for header files" 28 #error "so that freetype.h of FreeType 2 is found first." 29 #endif 30 31 32 FT_BEGIN_HEADER 33 34 35 /*************************************************************************/ 36 /* */ 37 /* <Section> */ 38 /* winfnt_fonts */ 39 /* */ 40 /* <Title> */ 41 /* Window FNT Files */ 42 /* */ 43 /* <Abstract> */ 44 /* Windows FNT specific API. */ 45 /* */ 46 /* <Description> */ 47 /* This section contains the declaration of Windows FNT specific */ 48 /* functions. */ 49 /* */ 50 /*************************************************************************/ 51 52 53 /************************************************************************* 54 * 55 * @enum: 56 * FT_WinFNT_ID_XXX 57 * 58 * @description: 59 * A list of valid values for the `charset' byte in 60 * @FT_WinFNT_HeaderRec. Exact mapping tables for the various cpXXXX 61 * encodings (except for cp1361) can be found at ftp://ftp.unicode.org 62 * in the MAPPINGS/VENDORS/MICSFT/WINDOWS subdirectory. cp1361 is 63 * roughly a superset of MAPPINGS/OBSOLETE/EASTASIA/KSC/JOHAB.TXT. 64 * 65 * @values: 66 * FT_WinFNT_ID_DEFAULT :: 67 * This is used for font enumeration and font creation as a 68 * `don't care' value. Valid font files don't contain this value. 69 * When querying for information about the character set of the font 70 * that is currently selected into a specified device context, this 71 * return value (of the related Windows API) simply denotes failure. 72 * 73 * FT_WinFNT_ID_SYMBOL :: 74 * There is no known mapping table available. 75 * 76 * FT_WinFNT_ID_MAC :: 77 * Mac Roman encoding. 78 * 79 * FT_WinFNT_ID_OEM :: 80 * From Michael Pöttgen <michael@poettgen.de>: 81 * 82 * The `Windows Font Mapping' article says that FT_WinFNT_ID_OEM 83 * is used for the charset of vector fonts, like `modern.fon', 84 * `roman.fon', and `script.fon' on Windows. 85 * 86 * The `CreateFont' documentation says: The FT_WinFNT_ID_OEM value 87 * specifies a character set that is operating-system dependent. 88 * 89 * The `IFIMETRICS' documentation from the `Windows Driver 90 * Development Kit' says: This font supports an OEM-specific 91 * character set. The OEM character set is system dependent. 92 * 93 * In general OEM, as opposed to ANSI (i.e., cp1252), denotes the 94 * second default codepage that most international versions of 95 * Windows have. It is one of the OEM codepages from 96 * 97 * http://www.microsoft.com/globaldev/reference/cphome.mspx, 98 * 99 * and is used for the `DOS boxes', to support legacy applications. 100 * A German Windows version for example usually uses ANSI codepage 101 * 1252 and OEM codepage 850. 102 * 103 * FT_WinFNT_ID_CP874 :: 104 * A superset of Thai TIS 620 and ISO 8859-11. 105 * 106 * FT_WinFNT_ID_CP932 :: 107 * A superset of Japanese Shift-JIS (with minor deviations). 108 * 109 * FT_WinFNT_ID_CP936 :: 110 * A superset of simplified Chinese GB 2312-1980 (with different 111 * ordering and minor deviations). 112 * 113 * FT_WinFNT_ID_CP949 :: 114 * A superset of Korean Hangul KS~C 5601-1987 (with different 115 * ordering and minor deviations). 116 * 117 * FT_WinFNT_ID_CP950 :: 118 * A superset of traditional Chinese Big~5 ETen (with different 119 * ordering and minor deviations). 120 * 121 * FT_WinFNT_ID_CP1250 :: 122 * A superset of East European ISO 8859-2 (with slightly different 123 * ordering). 124 * 125 * FT_WinFNT_ID_CP1251 :: 126 * A superset of Russian ISO 8859-5 (with different ordering). 127 * 128 * FT_WinFNT_ID_CP1252 :: 129 * ANSI encoding. A superset of ISO 8859-1. 130 * 131 * FT_WinFNT_ID_CP1253 :: 132 * A superset of Greek ISO 8859-7 (with minor modifications). 133 * 134 * FT_WinFNT_ID_CP1254 :: 135 * A superset of Turkish ISO 8859-9. 136 * 137 * FT_WinFNT_ID_CP1255 :: 138 * A superset of Hebrew ISO 8859-8 (with some modifications). 139 * 140 * FT_WinFNT_ID_CP1256 :: 141 * A superset of Arabic ISO 8859-6 (with different ordering). 142 * 143 * FT_WinFNT_ID_CP1257 :: 144 * A superset of Baltic ISO 8859-13 (with some deviations). 145 * 146 * FT_WinFNT_ID_CP1258 :: 147 * For Vietnamese. This encoding doesn't cover all necessary 148 * characters. 149 * 150 * FT_WinFNT_ID_CP1361 :: 151 * Korean (Johab). 152 */ 153 154 #define FT_WinFNT_ID_CP1252 0 155 #define FT_WinFNT_ID_DEFAULT 1 156 #define FT_WinFNT_ID_SYMBOL 2 157 #define FT_WinFNT_ID_MAC 77 158 #define FT_WinFNT_ID_CP932 128 159 #define FT_WinFNT_ID_CP949 129 160 #define FT_WinFNT_ID_CP1361 130 161 #define FT_WinFNT_ID_CP936 134 162 #define FT_WinFNT_ID_CP950 136 163 #define FT_WinFNT_ID_CP1253 161 164 #define FT_WinFNT_ID_CP1254 162 165 #define FT_WinFNT_ID_CP1258 163 166 #define FT_WinFNT_ID_CP1255 177 167 #define FT_WinFNT_ID_CP1256 178 168 #define FT_WinFNT_ID_CP1257 186 169 #define FT_WinFNT_ID_CP1251 204 170 #define FT_WinFNT_ID_CP874 222 171 #define FT_WinFNT_ID_CP1250 238 172 #define FT_WinFNT_ID_OEM 255 173 174 175 /*************************************************************************/ 176 /* */ 177 /* <Struct> */ 178 /* FT_WinFNT_HeaderRec */ 179 /* */ 180 /* <Description> */ 181 /* Windows FNT Header info. */ 182 /* */ 183 typedef struct FT_WinFNT_HeaderRec_ 184 { 185 FT_UShort version; 186 FT_ULong file_size; 187 FT_Byte copyright[60]; 188 FT_UShort file_type; 189 FT_UShort nominal_point_size; 190 FT_UShort vertical_resolution; 191 FT_UShort horizontal_resolution; 192 FT_UShort ascent; 193 FT_UShort internal_leading; 194 FT_UShort external_leading; 195 FT_Byte italic; 196 FT_Byte underline; 197 FT_Byte strike_out; 198 FT_UShort weight; 199 FT_Byte charset; 200 FT_UShort pixel_width; 201 FT_UShort pixel_height; 202 FT_Byte pitch_and_family; 203 FT_UShort avg_width; 204 FT_UShort max_width; 205 FT_Byte first_char; 206 FT_Byte last_char; 207 FT_Byte default_char; 208 FT_Byte break_char; 209 FT_UShort bytes_per_row; 210 FT_ULong device_offset; 211 FT_ULong face_name_offset; 212 FT_ULong bits_pointer; 213 FT_ULong bits_offset; 214 FT_Byte reserved; 215 FT_ULong flags; 216 FT_UShort A_space; 217 FT_UShort B_space; 218 FT_UShort C_space; 219 FT_UShort color_table_offset; 220 FT_ULong reserved1[4]; 221 222 } FT_WinFNT_HeaderRec; 223 224 225 /*************************************************************************/ 226 /* */ 227 /* <Struct> */ 228 /* FT_WinFNT_Header */ 229 /* */ 230 /* <Description> */ 231 /* A handle to an @FT_WinFNT_HeaderRec structure. */ 232 /* */ 233 typedef struct FT_WinFNT_HeaderRec_* FT_WinFNT_Header; 234 235 236 /********************************************************************** 237 * 238 * @function: 239 * FT_Get_WinFNT_Header 240 * 241 * @description: 242 * Retrieve a Windows FNT font info header. 243 * 244 * @input: 245 * face :: A handle to the input face. 246 * 247 * @output: 248 * aheader :: The WinFNT header. 249 * 250 * @return: 251 * FreeType error code. 0~means success. 252 * 253 * @note: 254 * This function only works with Windows FNT faces, returning an error 255 * otherwise. 256 */ 257 FT_EXPORT( FT_Error ) 258 FT_Get_WinFNT_Header( FT_Face face, 259 FT_WinFNT_HeaderRec *aheader ); 260 261 262 /* */ 263 264 FT_END_HEADER 265 266 #endif /* __FTWINFNT_H__ */ 267 268 269 /* END */ 270 271 272 /* Local Variables: */ 273 /* coding: utf-8 */ 274 /* End: */ 275