annotate libass/ass_font.c @ 22028:24dc4ec0d08d

Doxygen comments for used DirectShow methods. Info was got from DirectShow SDK.
author voroshil
date Sun, 28 Jan 2007 16:53:33 +0000
parents 0d8005d2fe5c
children 4a958bd08920
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
21277
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
1 // -*- c-basic-offset: 8; indent-tabs-mode: t -*-
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
2 // vim:ts=8:sw=8:noet:ai:
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
3 /*
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
4 Copyright (C) 2006 Evgeniy Stepanov <eugeni.stepanov@gmail.com>
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
5
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
6 This program is free software; you can redistribute it and/or modify
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
7 it under the terms of the GNU General Public License as published by
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
8 the Free Software Foundation; either version 2 of the License, or
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
9 (at your option) any later version.
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
10
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
11 This program is distributed in the hope that it will be useful,
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
14 GNU General Public License for more details.
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
15
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
16 You should have received a copy of the GNU General Public License
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
17 along with this program; if not, write to the Free Software
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
18 Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
19 */
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
20
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
21 #include "config.h"
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
22
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
23 #include <inttypes.h>
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
24 #include <ft2build.h>
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
25 #include FT_FREETYPE_H
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
26 #include FT_SYNTHESIS_H
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
27 #include FT_GLYPH_H
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
28
21458
7af6c25a0cfc Keep embedded fonts in ass_library_t and perform actual disk write
eugeni
parents: 21351
diff changeset
29 #include "ass.h"
7af6c25a0cfc Keep embedded fonts in ass_library_t and perform actual disk write
eugeni
parents: 21351
diff changeset
30 #include "ass_library.h"
21277
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
31 #include "ass_font.h"
21321
7b7627ff1937 Move ass_font_desc_t and ass_font_t declarations to ass_font.h.
eugeni
parents: 21320
diff changeset
32 #include "ass_bitmap.h"
7b7627ff1937 Move ass_font_desc_t and ass_font_t declarations to ass_font.h.
eugeni
parents: 21320
diff changeset
33 #include "ass_cache.h"
21277
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
34 #include "ass_fontconfig.h"
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
35 #include "mputils.h"
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
36
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
37 /**
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
38 * Select Microfost Unicode CharMap, if the font has one.
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
39 * Otherwise, let FreeType decide.
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
40 */
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
41 static void charmap_magic(FT_Face face)
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
42 {
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
43 int i;
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
44 for (i = 0; i < face->num_charmaps; ++i) {
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
45 FT_CharMap cmap = face->charmaps[i];
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
46 unsigned pid = cmap->platform_id;
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
47 unsigned eid = cmap->encoding_id;
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
48 if (pid == 3 /*microsoft*/ && (eid == 1 /*unicode bmp*/ || eid == 10 /*full unicode*/)) {
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
49 FT_Set_Charmap(face, cmap);
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
50 break;
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
51 }
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
52 }
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
53 }
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
54
21630
0d8005d2fe5c Update some comments.
eugeni
parents: 21620
diff changeset
55 /**
0d8005d2fe5c Update some comments.
eugeni
parents: 21620
diff changeset
56 * \brief find a memory font by name
0d8005d2fe5c Update some comments.
eugeni
parents: 21620
diff changeset
57 */
21460
62bd8e0d3a0f Open embedded fonts directly from memory.
eugeni
parents: 21458
diff changeset
58 static int find_font(ass_library_t* library, char* name)
62bd8e0d3a0f Open embedded fonts directly from memory.
eugeni
parents: 21458
diff changeset
59 {
62bd8e0d3a0f Open embedded fonts directly from memory.
eugeni
parents: 21458
diff changeset
60 int i;
62bd8e0d3a0f Open embedded fonts directly from memory.
eugeni
parents: 21458
diff changeset
61 for (i = 0; i < library->num_fontdata; ++i)
62bd8e0d3a0f Open embedded fonts directly from memory.
eugeni
parents: 21458
diff changeset
62 if (strcasecmp(name, library->fontdata[i].name) == 0)
62bd8e0d3a0f Open embedded fonts directly from memory.
eugeni
parents: 21458
diff changeset
63 return i;
62bd8e0d3a0f Open embedded fonts directly from memory.
eugeni
parents: 21458
diff changeset
64 return -1;
62bd8e0d3a0f Open embedded fonts directly from memory.
eugeni
parents: 21458
diff changeset
65 }
62bd8e0d3a0f Open embedded fonts directly from memory.
eugeni
parents: 21458
diff changeset
66
21630
0d8005d2fe5c Update some comments.
eugeni
parents: 21620
diff changeset
67 /**
0d8005d2fe5c Update some comments.
eugeni
parents: 21620
diff changeset
68 * \brief Create a new ass_font_t according to "desc" argument
0d8005d2fe5c Update some comments.
eugeni
parents: 21620
diff changeset
69 */
21460
62bd8e0d3a0f Open embedded fonts directly from memory.
eugeni
parents: 21458
diff changeset
70 ass_font_t* ass_font_new(ass_library_t* library, FT_Library ftlibrary, void* fc_priv, ass_font_desc_t* desc)
21277
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
71 {
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
72 char* path;
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
73 int index;
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
74 FT_Face face;
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
75 int error;
21317
dcfd069efd8f Move ass_font_t allocation to ass_font.h.
eugeni
parents: 21314
diff changeset
76 ass_font_t* font;
21460
62bd8e0d3a0f Open embedded fonts directly from memory.
eugeni
parents: 21458
diff changeset
77 int mem_idx;
21317
dcfd069efd8f Move ass_font_t allocation to ass_font.h.
eugeni
parents: 21314
diff changeset
78
dcfd069efd8f Move ass_font_t allocation to ass_font.h.
eugeni
parents: 21314
diff changeset
79 font = ass_font_cache_find(desc);
dcfd069efd8f Move ass_font_t allocation to ass_font.h.
eugeni
parents: 21314
diff changeset
80 if (font)
dcfd069efd8f Move ass_font_t allocation to ass_font.h.
eugeni
parents: 21314
diff changeset
81 return font;
21277
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
82
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
83 path = fontconfig_select(fc_priv, desc->family, desc->bold, desc->italic, &index);
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
84
21460
62bd8e0d3a0f Open embedded fonts directly from memory.
eugeni
parents: 21458
diff changeset
85 mem_idx = find_font(library, path);
62bd8e0d3a0f Open embedded fonts directly from memory.
eugeni
parents: 21458
diff changeset
86 if (mem_idx >= 0) {
21615
62989854d340 Avoid "pointer targets differ in signedness" warnings.
eugeni
parents: 21614
diff changeset
87 error = FT_New_Memory_Face(ftlibrary, (unsigned char*)library->fontdata[mem_idx].data,
21460
62bd8e0d3a0f Open embedded fonts directly from memory.
eugeni
parents: 21458
diff changeset
88 library->fontdata[mem_idx].size, 0, &face);
62bd8e0d3a0f Open embedded fonts directly from memory.
eugeni
parents: 21458
diff changeset
89 if (error) {
62bd8e0d3a0f Open embedded fonts directly from memory.
eugeni
parents: 21458
diff changeset
90 mp_msg(MSGT_ASS, MSGL_WARN, MSGTR_LIBASS_ErrorOpeningMemoryFont, path);
62bd8e0d3a0f Open embedded fonts directly from memory.
eugeni
parents: 21458
diff changeset
91 return 0;
62bd8e0d3a0f Open embedded fonts directly from memory.
eugeni
parents: 21458
diff changeset
92 }
62bd8e0d3a0f Open embedded fonts directly from memory.
eugeni
parents: 21458
diff changeset
93 } else {
21620
ef93ebaef504 Cosmetics: fix indentation.
eugeni
parents: 21619
diff changeset
94 error = FT_New_Face(ftlibrary, path, index, &face);
ef93ebaef504 Cosmetics: fix indentation.
eugeni
parents: 21619
diff changeset
95 if (error) {
ef93ebaef504 Cosmetics: fix indentation.
eugeni
parents: 21619
diff changeset
96 mp_msg(MSGT_ASS, MSGL_WARN, MSGTR_LIBASS_ErrorOpeningFont, path, index);
ef93ebaef504 Cosmetics: fix indentation.
eugeni
parents: 21619
diff changeset
97 return 0;
ef93ebaef504 Cosmetics: fix indentation.
eugeni
parents: 21619
diff changeset
98 }
21460
62bd8e0d3a0f Open embedded fonts directly from memory.
eugeni
parents: 21458
diff changeset
99 }
21277
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
100
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
101 charmap_magic(face);
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
102
21317
dcfd069efd8f Move ass_font_t allocation to ass_font.h.
eugeni
parents: 21314
diff changeset
103 font = calloc(1, sizeof(ass_font_t));
21349
11679d93c7d8 Add FT_Library to ass_font_t.
eugeni
parents: 21321
diff changeset
104 font->ftlibrary = ftlibrary;
21619
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
105 font->faces[0] = face;
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
106 font->n_faces = 1;
21277
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
107 font->desc.family = strdup(desc->family);
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
108 font->desc.bold = desc->bold;
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
109 font->desc.italic = desc->italic;
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
110
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
111 font->m.xx = font->m.yy = (FT_Fixed)0x10000L;
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
112 font->m.xy = font->m.yy = 0;
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
113 font->v.x = font->v.y = 0;
21314
4b2e5a74a2eb Initialize font size with 0.
eugeni
parents: 21279
diff changeset
114 font->size = 0;
21277
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
115
21351
c611dfc4cb85 If a glyph is not found in the current font, switch to another one.
eugeni
parents: 21350
diff changeset
116 #ifdef HAVE_FONTCONFIG
c611dfc4cb85 If a glyph is not found in the current font, switch to another one.
eugeni
parents: 21350
diff changeset
117 font->charset = FcCharSetCreate();
c611dfc4cb85 If a glyph is not found in the current font, switch to another one.
eugeni
parents: 21350
diff changeset
118 #endif
c611dfc4cb85 If a glyph is not found in the current font, switch to another one.
eugeni
parents: 21350
diff changeset
119
21317
dcfd069efd8f Move ass_font_t allocation to ass_font.h.
eugeni
parents: 21314
diff changeset
120 ass_font_cache_add(font);
dcfd069efd8f Move ass_font_t allocation to ass_font.h.
eugeni
parents: 21314
diff changeset
121
dcfd069efd8f Move ass_font_t allocation to ass_font.h.
eugeni
parents: 21314
diff changeset
122 return font;
21277
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
123 }
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
124
21630
0d8005d2fe5c Update some comments.
eugeni
parents: 21620
diff changeset
125 /**
0d8005d2fe5c Update some comments.
eugeni
parents: 21620
diff changeset
126 * \brief Set font transformation matrix and shift vector
0d8005d2fe5c Update some comments.
eugeni
parents: 21620
diff changeset
127 **/
21277
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
128 void ass_font_set_transform(ass_font_t* font, FT_Matrix* m, FT_Vector* v)
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
129 {
21619
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
130 int i;
21616
2704273f398d FT_Set_Transform is fast enough to be called once for each glyph.
eugeni
parents: 21615
diff changeset
131 font->m.xx = m->xx;
2704273f398d FT_Set_Transform is fast enough to be called once for each glyph.
eugeni
parents: 21615
diff changeset
132 font->m.xy = m->xy;
2704273f398d FT_Set_Transform is fast enough to be called once for each glyph.
eugeni
parents: 21615
diff changeset
133 font->m.yx = m->yx;
2704273f398d FT_Set_Transform is fast enough to be called once for each glyph.
eugeni
parents: 21615
diff changeset
134 font->m.yy = m->yy;
2704273f398d FT_Set_Transform is fast enough to be called once for each glyph.
eugeni
parents: 21615
diff changeset
135 font->v.x = v->x;
2704273f398d FT_Set_Transform is fast enough to be called once for each glyph.
eugeni
parents: 21615
diff changeset
136 font->v.y = v->y;
21619
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
137 for (i = 0; i < font->n_faces; ++i)
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
138 FT_Set_Transform(font->faces[i], &font->m, &font->v);
21277
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
139 }
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
140
21630
0d8005d2fe5c Update some comments.
eugeni
parents: 21620
diff changeset
141 /**
0d8005d2fe5c Update some comments.
eugeni
parents: 21620
diff changeset
142 * \brief Set font size
0d8005d2fe5c Update some comments.
eugeni
parents: 21620
diff changeset
143 **/
21277
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
144 void ass_font_set_size(ass_font_t* font, int size)
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
145 {
21619
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
146 int i;
21319
415e2119e91c Don't call FT_Set_Transform/FT_Set_Pixel_Sizes if values have not changed.
eugeni
parents: 21317
diff changeset
147 if (font->size != size) {
21320
4a7e96f1eebf Cosmetics: reindent.
eugeni
parents: 21319
diff changeset
148 font->size = size;
21619
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
149 for (i = 0; i < font->n_faces; ++i)
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
150 FT_Set_Pixel_Sizes(font->faces[i], 0, size);
21319
415e2119e91c Don't call FT_Set_Transform/FT_Set_Pixel_Sizes if values have not changed.
eugeni
parents: 21317
diff changeset
151 }
21277
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
152 }
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
153
21351
c611dfc4cb85 If a glyph is not found in the current font, switch to another one.
eugeni
parents: 21350
diff changeset
154 #ifdef HAVE_FONTCONFIG
21630
0d8005d2fe5c Update some comments.
eugeni
parents: 21620
diff changeset
155 /**
0d8005d2fe5c Update some comments.
eugeni
parents: 21620
diff changeset
156 * \brief Select a new FT_Face with the given character
0d8005d2fe5c Update some comments.
eugeni
parents: 21620
diff changeset
157 * The new face is added to the end of font->faces.
0d8005d2fe5c Update some comments.
eugeni
parents: 21620
diff changeset
158 **/
21618
8111d4625194 Avoid storing font file path and index in ass_font_t.
eugeni
parents: 21616
diff changeset
159 static void ass_font_reselect(void* fontconfig_priv, ass_font_t* font, uint32_t ch)
21351
c611dfc4cb85 If a glyph is not found in the current font, switch to another one.
eugeni
parents: 21350
diff changeset
160 {
c611dfc4cb85 If a glyph is not found in the current font, switch to another one.
eugeni
parents: 21350
diff changeset
161 char* path;
c611dfc4cb85 If a glyph is not found in the current font, switch to another one.
eugeni
parents: 21350
diff changeset
162 int index;
c611dfc4cb85 If a glyph is not found in the current font, switch to another one.
eugeni
parents: 21350
diff changeset
163 FT_Face face;
c611dfc4cb85 If a glyph is not found in the current font, switch to another one.
eugeni
parents: 21350
diff changeset
164 int error;
21619
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
165
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
166 if (font->n_faces == ASS_FONT_MAX_FACES)
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
167 return;
21351
c611dfc4cb85 If a glyph is not found in the current font, switch to another one.
eugeni
parents: 21350
diff changeset
168
c611dfc4cb85 If a glyph is not found in the current font, switch to another one.
eugeni
parents: 21350
diff changeset
169 path = fontconfig_select_with_charset(fontconfig_priv, font->desc.family, font->desc.bold,
c611dfc4cb85 If a glyph is not found in the current font, switch to another one.
eugeni
parents: 21350
diff changeset
170 font->desc.italic, &index, font->charset);
c611dfc4cb85 If a glyph is not found in the current font, switch to another one.
eugeni
parents: 21350
diff changeset
171
c611dfc4cb85 If a glyph is not found in the current font, switch to another one.
eugeni
parents: 21350
diff changeset
172 error = FT_New_Face(font->ftlibrary, path, index, &face);
c611dfc4cb85 If a glyph is not found in the current font, switch to another one.
eugeni
parents: 21350
diff changeset
173 if (error) {
c611dfc4cb85 If a glyph is not found in the current font, switch to another one.
eugeni
parents: 21350
diff changeset
174 mp_msg(MSGT_ASS, MSGL_WARN, MSGTR_LIBASS_ErrorOpeningFont, path, index);
c611dfc4cb85 If a glyph is not found in the current font, switch to another one.
eugeni
parents: 21350
diff changeset
175 return;
c611dfc4cb85 If a glyph is not found in the current font, switch to another one.
eugeni
parents: 21350
diff changeset
176 }
c611dfc4cb85 If a glyph is not found in the current font, switch to another one.
eugeni
parents: 21350
diff changeset
177 charmap_magic(face);
c611dfc4cb85 If a glyph is not found in the current font, switch to another one.
eugeni
parents: 21350
diff changeset
178
21618
8111d4625194 Avoid storing font file path and index in ass_font_t.
eugeni
parents: 21616
diff changeset
179 error = FT_Get_Char_Index(face, ch);
8111d4625194 Avoid storing font file path and index in ass_font_t.
eugeni
parents: 21616
diff changeset
180 if (error == 0) { // the new font face is not better then the old one
8111d4625194 Avoid storing font file path and index in ass_font_t.
eugeni
parents: 21616
diff changeset
181 FT_Done_Face(face);
8111d4625194 Avoid storing font file path and index in ass_font_t.
eugeni
parents: 21616
diff changeset
182 return;
8111d4625194 Avoid storing font file path and index in ass_font_t.
eugeni
parents: 21616
diff changeset
183 }
8111d4625194 Avoid storing font file path and index in ass_font_t.
eugeni
parents: 21616
diff changeset
184
21619
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
185 font->faces[font->n_faces++] = face;
21351
c611dfc4cb85 If a glyph is not found in the current font, switch to another one.
eugeni
parents: 21350
diff changeset
186
21619
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
187 FT_Set_Transform(face, &font->m, &font->v);
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
188 FT_Set_Pixel_Sizes(face, 0, font->size);
21351
c611dfc4cb85 If a glyph is not found in the current font, switch to another one.
eugeni
parents: 21350
diff changeset
189 }
c611dfc4cb85 If a glyph is not found in the current font, switch to another one.
eugeni
parents: 21350
diff changeset
190 #endif
c611dfc4cb85 If a glyph is not found in the current font, switch to another one.
eugeni
parents: 21350
diff changeset
191
21630
0d8005d2fe5c Update some comments.
eugeni
parents: 21620
diff changeset
192 /**
0d8005d2fe5c Update some comments.
eugeni
parents: 21620
diff changeset
193 * \brief Get maximal font ascender and descender.
0d8005d2fe5c Update some comments.
eugeni
parents: 21620
diff changeset
194 * \param ch character code
0d8005d2fe5c Update some comments.
eugeni
parents: 21620
diff changeset
195 * The values are extracted from the font face that provides glyphs for the given character
0d8005d2fe5c Update some comments.
eugeni
parents: 21620
diff changeset
196 **/
21614
5d2ca7ca18b5 Move ascender, descender, and kerning computation to ass_font.c.
eugeni
parents: 21460
diff changeset
197 void ass_font_get_asc_desc(ass_font_t* font, uint32_t ch, int* asc, int* desc)
5d2ca7ca18b5 Move ascender, descender, and kerning computation to ass_font.c.
eugeni
parents: 21460
diff changeset
198 {
21619
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
199 int i;
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
200 for (i = 0; i < font->n_faces; ++i) {
21620
ef93ebaef504 Cosmetics: fix indentation.
eugeni
parents: 21619
diff changeset
201 FT_Face face = font->faces[i];
ef93ebaef504 Cosmetics: fix indentation.
eugeni
parents: 21619
diff changeset
202 if (FT_Get_Char_Index(face, ch)) {
ef93ebaef504 Cosmetics: fix indentation.
eugeni
parents: 21619
diff changeset
203 int v, v2;
ef93ebaef504 Cosmetics: fix indentation.
eugeni
parents: 21619
diff changeset
204 v = face->size->metrics.ascender;
ef93ebaef504 Cosmetics: fix indentation.
eugeni
parents: 21619
diff changeset
205 v2 = FT_MulFix(face->bbox.yMax, face->size->metrics.y_scale);
ef93ebaef504 Cosmetics: fix indentation.
eugeni
parents: 21619
diff changeset
206 *asc = (v > v2 * 0.9) ? v : v2;
21614
5d2ca7ca18b5 Move ascender, descender, and kerning computation to ass_font.c.
eugeni
parents: 21460
diff changeset
207
21620
ef93ebaef504 Cosmetics: fix indentation.
eugeni
parents: 21619
diff changeset
208 v = - face->size->metrics.descender;
ef93ebaef504 Cosmetics: fix indentation.
eugeni
parents: 21619
diff changeset
209 v2 = - FT_MulFix(face->bbox.yMin, face->size->metrics.y_scale);
ef93ebaef504 Cosmetics: fix indentation.
eugeni
parents: 21619
diff changeset
210 *desc = (v > v2 * 0.9) ? v : v2;
ef93ebaef504 Cosmetics: fix indentation.
eugeni
parents: 21619
diff changeset
211 return;
21619
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
212 }
21614
5d2ca7ca18b5 Move ascender, descender, and kerning computation to ass_font.c.
eugeni
parents: 21460
diff changeset
213 }
5d2ca7ca18b5 Move ascender, descender, and kerning computation to ass_font.c.
eugeni
parents: 21460
diff changeset
214
5d2ca7ca18b5 Move ascender, descender, and kerning computation to ass_font.c.
eugeni
parents: 21460
diff changeset
215 *asc = *desc = 0;
5d2ca7ca18b5 Move ascender, descender, and kerning computation to ass_font.c.
eugeni
parents: 21460
diff changeset
216 }
5d2ca7ca18b5 Move ascender, descender, and kerning computation to ass_font.c.
eugeni
parents: 21460
diff changeset
217
21630
0d8005d2fe5c Update some comments.
eugeni
parents: 21620
diff changeset
218 /**
0d8005d2fe5c Update some comments.
eugeni
parents: 21620
diff changeset
219 * \brief Get a glyph
0d8005d2fe5c Update some comments.
eugeni
parents: 21620
diff changeset
220 * \param ch character code
0d8005d2fe5c Update some comments.
eugeni
parents: 21620
diff changeset
221 **/
21277
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
222 FT_Glyph ass_font_get_glyph(void* fontconfig_priv, ass_font_t* font, uint32_t ch)
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
223 {
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
224 int error;
21619
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
225 int index = 0;
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
226 int i;
21277
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
227 FT_Glyph glyph;
21619
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
228 FT_Face face = 0;
21350
5337cdeec169 Skip glyphs with char code < 0x20.
eugeni
parents: 21349
diff changeset
229
5337cdeec169 Skip glyphs with char code < 0x20.
eugeni
parents: 21349
diff changeset
230 if (ch < 0x20)
5337cdeec169 Skip glyphs with char code < 0x20.
eugeni
parents: 21349
diff changeset
231 return 0;
21619
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
232 if (font->n_faces == 0)
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
233 return 0;
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
234
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
235 for (i = 0; i < font->n_faces; ++i) {
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
236 face = font->faces[i];
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
237 index = FT_Get_Char_Index(face, ch);
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
238 if (index)
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
239 break;
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
240 }
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
241
21351
c611dfc4cb85 If a glyph is not found in the current font, switch to another one.
eugeni
parents: 21350
diff changeset
242 #ifdef HAVE_FONTCONFIG
c611dfc4cb85 If a glyph is not found in the current font, switch to another one.
eugeni
parents: 21350
diff changeset
243 FcCharSetAddChar(font->charset, ch);
c611dfc4cb85 If a glyph is not found in the current font, switch to another one.
eugeni
parents: 21350
diff changeset
244 if (index == 0) {
c611dfc4cb85 If a glyph is not found in the current font, switch to another one.
eugeni
parents: 21350
diff changeset
245 mp_msg(MSGT_ASS, MSGL_INFO, MSGTR_LIBASS_GlyphNotFoundReselectingFont,
c611dfc4cb85 If a glyph is not found in the current font, switch to another one.
eugeni
parents: 21350
diff changeset
246 ch, font->desc.family, font->desc.bold, font->desc.italic);
21618
8111d4625194 Avoid storing font file path and index in ass_font_t.
eugeni
parents: 21616
diff changeset
247 ass_font_reselect(fontconfig_priv, font, ch);
21619
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
248 face = font->faces[font->n_faces - 1];
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
249 index = FT_Get_Char_Index(face, ch);
21351
c611dfc4cb85 If a glyph is not found in the current font, switch to another one.
eugeni
parents: 21350
diff changeset
250 if (index == 0) {
c611dfc4cb85 If a glyph is not found in the current font, switch to another one.
eugeni
parents: 21350
diff changeset
251 mp_msg(MSGT_ASS, MSGL_ERR, MSGTR_LIBASS_GlyphNotFound,
c611dfc4cb85 If a glyph is not found in the current font, switch to another one.
eugeni
parents: 21350
diff changeset
252 ch, font->desc.family, font->desc.bold, font->desc.italic);
c611dfc4cb85 If a glyph is not found in the current font, switch to another one.
eugeni
parents: 21350
diff changeset
253 }
c611dfc4cb85 If a glyph is not found in the current font, switch to another one.
eugeni
parents: 21350
diff changeset
254 }
c611dfc4cb85 If a glyph is not found in the current font, switch to another one.
eugeni
parents: 21350
diff changeset
255 #endif
c611dfc4cb85 If a glyph is not found in the current font, switch to another one.
eugeni
parents: 21350
diff changeset
256
21619
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
257 error = FT_Load_Glyph(face, index, FT_LOAD_NO_BITMAP );
21277
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
258 if (error) {
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
259 mp_msg(MSGT_ASS, MSGL_WARN, MSGTR_LIBASS_ErrorLoadingGlyph);
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
260 return 0;
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
261 }
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
262
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
263 #if (FREETYPE_MAJOR > 2) || \
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
264 ((FREETYPE_MAJOR == 2) && (FREETYPE_MINOR >= 2)) || \
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
265 ((FREETYPE_MAJOR == 2) && (FREETYPE_MINOR == 1) && (FREETYPE_PATCH >= 10))
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
266 // FreeType >= 2.1.10 required
21619
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
267 if (!(face->style_flags & FT_STYLE_FLAG_ITALIC) &&
21277
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
268 (font->desc.italic > 55)) {
21619
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
269 FT_GlyphSlot_Oblique(face->glyph);
21277
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
270 }
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
271 #endif
21619
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
272 error = FT_Get_Glyph(face->glyph, &glyph);
21277
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
273 if (error) {
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
274 mp_msg(MSGT_ASS, MSGL_WARN, MSGTR_LIBASS_ErrorLoadingGlyph);
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
275 return 0;
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
276 }
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
277
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
278 return glyph;
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
279 }
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
280
21630
0d8005d2fe5c Update some comments.
eugeni
parents: 21620
diff changeset
281 /**
0d8005d2fe5c Update some comments.
eugeni
parents: 21620
diff changeset
282 * \brief Get kerning for the pair of glyphs.
0d8005d2fe5c Update some comments.
eugeni
parents: 21620
diff changeset
283 **/
21614
5d2ca7ca18b5 Move ascender, descender, and kerning computation to ass_font.c.
eugeni
parents: 21460
diff changeset
284 FT_Vector ass_font_get_kerning(ass_font_t* font, uint32_t c1, uint32_t c2)
5d2ca7ca18b5 Move ascender, descender, and kerning computation to ass_font.c.
eugeni
parents: 21460
diff changeset
285 {
5d2ca7ca18b5 Move ascender, descender, and kerning computation to ass_font.c.
eugeni
parents: 21460
diff changeset
286 FT_Vector v = {0, 0};
21619
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
287 int i;
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
288
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
289 for (i = 0; i < font->n_faces; ++i) {
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
290 FT_Face face = font->faces[i];
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
291 int i1 = FT_Get_Char_Index(face, c1);
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
292 int i2 = FT_Get_Char_Index(face, c2);
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
293 if (i1 && i2) {
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
294 if (FT_HAS_KERNING(face))
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
295 FT_Get_Kerning(face, i1, i2, FT_KERNING_DEFAULT, &v);
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
296 return v;
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
297 }
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
298 if (i1 || i2) // these glyphs are from different font faces, no kerning information
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
299 return v;
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
300 }
21614
5d2ca7ca18b5 Move ascender, descender, and kerning computation to ass_font.c.
eugeni
parents: 21460
diff changeset
301 return v;
5d2ca7ca18b5 Move ascender, descender, and kerning computation to ass_font.c.
eugeni
parents: 21460
diff changeset
302 }
5d2ca7ca18b5 Move ascender, descender, and kerning computation to ass_font.c.
eugeni
parents: 21460
diff changeset
303
21630
0d8005d2fe5c Update some comments.
eugeni
parents: 21620
diff changeset
304 /**
0d8005d2fe5c Update some comments.
eugeni
parents: 21620
diff changeset
305 * \brief Deallocate ass_font_t
0d8005d2fe5c Update some comments.
eugeni
parents: 21620
diff changeset
306 **/
21277
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
307 void ass_font_free(ass_font_t* font)
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
308 {
21619
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
309 int i;
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
310 for (i = 0; i < font->n_faces; ++i)
b4b51eb2904f Keep reselected fonts in an array, adding new ones to the end. Glyph
eugeni
parents: 21618
diff changeset
311 if (font->faces[i]) FT_Done_Face(font->faces[i]);
21277
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
312 if (font->desc.family) free(font->desc.family);
21351
c611dfc4cb85 If a glyph is not found in the current font, switch to another one.
eugeni
parents: 21350
diff changeset
313 #ifdef HAVE_FONTCONFIG
c611dfc4cb85 If a glyph is not found in the current font, switch to another one.
eugeni
parents: 21350
diff changeset
314 if (font->charset) FcCharSetDestroy(font->charset);
c611dfc4cb85 If a glyph is not found in the current font, switch to another one.
eugeni
parents: 21350
diff changeset
315 #endif
21317
dcfd069efd8f Move ass_font_t allocation to ass_font.h.
eugeni
parents: 21314
diff changeset
316 free(font);
21277
0603972f083c Move fonts-related code to a separate file.
eugeni
parents:
diff changeset
317 }