hb-font.h 7.4 KB
Newer Older
1 2 3
/*
 * Copyright (C) 2009  Red Hat, Inc.
 *
B
Behdad Esfahbod 已提交
4
 *  This is part of HarfBuzz, a text shaping library.
5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30
 *
 * Permission is hereby granted, without written agreement and without
 * license or royalty fees, to use, copy, modify, and distribute this
 * software and its documentation for any purpose, provided that the
 * above copyright notice and the following two paragraphs appear in
 * all copies of this software.
 *
 * IN NO EVENT SHALL THE COPYRIGHT HOLDER BE LIABLE TO ANY PARTY FOR
 * DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES
 * ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN
 * IF THE COPYRIGHT HOLDER HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
 * DAMAGE.
 *
 * THE COPYRIGHT HOLDER SPECIFICALLY DISCLAIMS ANY WARRANTIES, INCLUDING,
 * BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
 * FITNESS FOR A PARTICULAR PURPOSE.  THE SOFTWARE PROVIDED HEREUNDER IS
 * ON AN "AS IS" BASIS, AND THE COPYRIGHT HOLDER HAS NO OBLIGATION TO
 * PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS.
 *
 * Red Hat Author(s): Behdad Esfahbod
 */

#ifndef HB_FONT_H
#define HB_FONT_H

#include "hb-common.h"
B
Behdad Esfahbod 已提交
31
#include "hb-blob.h"
32 33 34

HB_BEGIN_DECLS

B
Behdad Esfahbod 已提交
35

B
Behdad Esfahbod 已提交
36 37
typedef struct _hb_face_t hb_face_t;
typedef struct _hb_font_t hb_font_t;
B
Behdad Esfahbod 已提交
38

39
/*
B
Behdad Esfahbod 已提交
40
 * hb_face_t
41 42
 */

B
Behdad Esfahbod 已提交
43 44 45
hb_face_t *
hb_face_create_for_data (hb_blob_t    *blob,
			 unsigned int  index);
46

B
Behdad Esfahbod 已提交
47
typedef hb_blob_t * (*hb_get_table_func_t)  (hb_tag_t tag, void *user_data);
48

B
Behdad Esfahbod 已提交
49
/* calls destroy() when not needing user_data anymore */
B
Behdad Esfahbod 已提交
50 51 52 53
hb_face_t *
hb_face_create_for_tables (hb_get_table_func_t  get_table,
			   hb_destroy_func_t    destroy,
			   void                *user_data);
54

B
Behdad Esfahbod 已提交
55 56
hb_face_t *
hb_face_reference (hb_face_t *face);
57

B
Behdad Esfahbod 已提交
58 59
unsigned int
hb_face_get_reference_count (hb_face_t *face);
60 61

void
B
Behdad Esfahbod 已提交
62
hb_face_destroy (hb_face_t *face);
63

B
Behdad Esfahbod 已提交
64 65 66 67 68 69 70 71 72 73 74 75 76
/* XXX
 *
 * I have two major concerns about this API as it is right now:
 *
 *   - Jonathan Kew convinced me to make it return NULL if table not found (280af1bd),
 *     however, that is WRONG IMO.  The API should not differentiate between a non-existing
 *     table vs a zero-length table vs a very short table.  It only leads to implementations
 *     that check for non-NULL and assume that they've got a usable table going on...  This
 *     actually happened with Firefox.
 *
 *   - It has to be renamed to reference_table() since unlike any other _get_ API, a reference
 *     ownership transfer happens and the user is responsible to destroy the result.
 */
B
Behdad Esfahbod 已提交
77 78 79
hb_blob_t *
hb_face_get_table (hb_face_t *face,
		   hb_tag_t   tag);
80

B
Behdad Esfahbod 已提交
81 82 83
unsigned int
hb_face_get_upem (hb_face_t *face);

84 85

/*
B
Behdad Esfahbod 已提交
86
 * hb_font_funcs_t
87 88
 */

B
Behdad Esfahbod 已提交
89 90 91 92
typedef struct _hb_font_funcs_t hb_font_funcs_t;

hb_font_funcs_t *
hb_font_funcs_create (void);
93

B
Behdad Esfahbod 已提交
94 95
hb_font_funcs_t *
hb_font_funcs_reference (hb_font_funcs_t *ffuncs);
96

B
Behdad Esfahbod 已提交
97
unsigned int
B
Behdad Esfahbod 已提交
98
hb_font_funcs_get_reference_count (hb_font_funcs_t *ffuncs);
B
Behdad Esfahbod 已提交
99

100
void
B
Behdad Esfahbod 已提交
101
hb_font_funcs_destroy (hb_font_funcs_t *ffuncs);
102

B
Behdad Esfahbod 已提交
103 104
hb_font_funcs_t *
hb_font_funcs_copy (hb_font_funcs_t *ffuncs);
105

106 107 108
void
hb_font_funcs_make_immutable (hb_font_funcs_t *ffuncs);

B
Behdad Esfahbod 已提交
109 110
hb_bool_t
hb_font_funcs_is_immutable (hb_font_funcs_t *ffuncs);
B
Behdad Esfahbod 已提交
111 112 113

/* funcs */

114
typedef struct _hb_glyph_extents_t
B
Behdad Esfahbod 已提交
115
{
116 117
    hb_position_t x_bearing;
    hb_position_t y_bearing;
B
Behdad Esfahbod 已提交
118 119
    hb_position_t width;
    hb_position_t height;
120
} hb_glyph_extents_t;
B
Behdad Esfahbod 已提交
121 122

typedef hb_codepoint_t (*hb_font_get_glyph_func_t) (hb_font_t *font, hb_face_t *face, const void *user_data,
123
						    hb_codepoint_t unicode, hb_codepoint_t variation_selector);
124 125 126 127 128
typedef void (*hb_font_get_glyph_advance_func_t) (hb_font_t *font, hb_face_t *face, const void *user_data,
						  hb_codepoint_t glyph,
						  hb_position_t *x_advance, hb_position_t *y_advance);
typedef void (*hb_font_get_glyph_extents_func_t) (hb_font_t *font, hb_face_t *face, const void *user_data,
						  hb_codepoint_t glyph,
129
						  hb_glyph_extents_t *extents);
B
Behdad Esfahbod 已提交
130
typedef hb_bool_t (*hb_font_get_contour_point_func_t) (hb_font_t *font, hb_face_t *face, const void *user_data,
131 132
						       unsigned int point_index, hb_codepoint_t glyph,
						       hb_position_t *x, hb_position_t *y);
B
Behdad Esfahbod 已提交
133 134 135
typedef hb_position_t (*hb_font_get_kerning_func_t) (hb_font_t *font, hb_face_t *face, const void *user_data,
						     hb_codepoint_t first_glyph, hb_codepoint_t second_glyph);

136 137

void
B
Behdad Esfahbod 已提交
138 139
hb_font_funcs_set_glyph_func (hb_font_funcs_t *ffuncs,
			      hb_font_get_glyph_func_t glyph_func);
140 141

void
142 143 144 145 146 147
hb_font_funcs_set_glyph_advance_func (hb_font_funcs_t *ffuncs,
				      hb_font_get_glyph_advance_func_t glyph_advance_func);

void
hb_font_funcs_set_glyph_extents_func (hb_font_funcs_t *ffuncs,
				      hb_font_get_glyph_extents_func_t glyph_extents_func);
148 149

void
150 151
hb_font_funcs_set_contour_point_func (hb_font_funcs_t *ffuncs,
				      hb_font_get_contour_point_func_t contour_point_func);
152 153

void
B
Behdad Esfahbod 已提交
154 155
hb_font_funcs_set_kerning_func (hb_font_funcs_t *ffuncs,
				hb_font_get_kerning_func_t kerning_func);
156 157


B
Behdad Esfahbod 已提交
158 159 160 161 162
/* These never return NULL.  Return fallback defaults instead. */

hb_font_get_glyph_func_t
hb_font_funcs_get_glyph_func (hb_font_funcs_t *ffuncs);

163 164 165 166 167 168
hb_font_get_glyph_advance_func_t
hb_font_funcs_get_glyph_advance_func (hb_font_funcs_t *ffuncs);

hb_font_get_glyph_extents_func_t
hb_font_funcs_get_glyph_extents_func (hb_font_funcs_t *ffuncs);

B
Behdad Esfahbod 已提交
169 170 171 172 173 174 175
hb_font_get_contour_point_func_t
hb_font_funcs_get_contour_point_func (hb_font_funcs_t *ffuncs);

hb_font_get_kerning_func_t
hb_font_funcs_get_kerning_func (hb_font_funcs_t *ffuncs);


B
Behdad Esfahbod 已提交
176 177 178 179
hb_codepoint_t
hb_font_get_glyph (hb_font_t *font, hb_face_t *face,
		   hb_codepoint_t unicode, hb_codepoint_t variation_selector);

180 181 182 183
void
hb_font_get_glyph_advance (hb_font_t *font, hb_face_t *face,
			   hb_codepoint_t glyph,
			   hb_position_t *x_advance, hb_position_t *y_advance);
B
Behdad Esfahbod 已提交
184 185

void
186 187
hb_font_get_glyph_extents (hb_font_t *font, hb_face_t *face,
			   hb_codepoint_t glyph,
188
			   hb_glyph_extents_t *extents);
189 190 191 192 193

hb_bool_t
hb_font_get_contour_point (hb_font_t *font, hb_face_t *face,
			   unsigned int point_index, hb_codepoint_t glyph,
			   hb_position_t *x, hb_position_t *y);
B
Behdad Esfahbod 已提交
194 195 196 197 198 199

hb_position_t
hb_font_get_kerning (hb_font_t *font, hb_face_t *face,
		     hb_codepoint_t first_glyph, hb_codepoint_t second_glyph);


200 201 202 203 204 205 206
/*
 * hb_font_t
 */

/* Fonts are very light-weight objects */

hb_font_t *
B
Behdad Esfahbod 已提交
207
hb_font_create (void);
208 209 210 211

hb_font_t *
hb_font_reference (hb_font_t *font);

B
Behdad Esfahbod 已提交
212 213 214
unsigned int
hb_font_get_reference_count (hb_font_t *font);

215 216 217
void
hb_font_destroy (hb_font_t *font);

B
Behdad Esfahbod 已提交
218
void
B
Behdad Esfahbod 已提交
219 220 221 222
hb_font_set_funcs (hb_font_t         *font,
		   hb_font_funcs_t   *klass,
		   hb_destroy_func_t  destroy,
		   void              *user_data);
223

B
Behdad Esfahbod 已提交
224 225 226 227 228
/* Returns what was set and unsets it, but doesn't destroy(user_data).
 * This is useful for wrapping / chaining font_funcs_t's.
 *
 * The client is responsible for:
 *
B
Behdad Esfahbod 已提交
229 230
 *   - Take ownership of the reference on the returned klass,
 *
B
Behdad Esfahbod 已提交
231 232 233 234 235 236 237 238 239
 *   - Calling "destroy(user_data)" exactly once if returned destroy func
 *     is not NULL and the returned info is not needed anymore.
 */
void
hb_font_unset_funcs (hb_font_t          *font,
		     hb_font_funcs_t   **klass,
		     hb_destroy_func_t  *destroy,
		     void              **user_data);

B
Behdad Esfahbod 已提交
240

241
/*
B
Behdad Esfahbod 已提交
242
 * We should add support for full matrices.
243 244 245
 */
void
hb_font_set_scale (hb_font_t *font,
B
Behdad Esfahbod 已提交
246 247
		   unsigned int x_scale,
		   unsigned int y_scale);
248

B
Behdad Esfahbod 已提交
249 250 251 252 253
void
hb_font_get_scale (hb_font_t *font,
		   unsigned int *x_scale,
		   unsigned int *y_scale);

254 255 256 257 258 259 260 261
/*
 * A zero value means "no hinting in that direction"
 */
void
hb_font_set_ppem (hb_font_t *font,
		  unsigned int x_ppem,
		  unsigned int y_ppem);

B
Behdad Esfahbod 已提交
262 263 264 265 266
void
hb_font_get_ppem (hb_font_t *font,
		  unsigned int *x_ppem,
		  unsigned int *y_ppem);

267 268 269 270

HB_END_DECLS

#endif /* HB_FONT_H */