2 * Copyright (C) 2006 Evgeniy Stepanov <eugeni.stepanov@gmail.com>
3 * Copyright (C) 2009 Grigori Goronzy <greg@geekmind.org>
5 * This file is part of libass.
7 * Permission to use, copy, modify, and distribute this software for any
8 * purpose with or without fee is hereby granted, provided that the above
9 * copyright notice and this permission notice appear in all copies.
11 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
12 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
13 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
14 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
15 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
16 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
17 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
20 #ifndef LIBASS_RENDER_H
21 #define LIBASS_RENDER_H
25 #include FT_FREETYPE_H
28 #include FT_SYNTHESIS_H
32 #include "ass_bitmap.h"
33 #include "ass_cache.h"
34 #include "ass_utils.h"
35 #include "ass_fontconfig.h"
36 #include "ass_library.h"
37 #include "ass_drawing.h"
39 #define GLYPH_CACHE_MAX 1000
40 #define BITMAP_CACHE_MAX_SIZE 30 * 1048576
54 typedef struct free_list
{
56 struct free_list
*next
;
62 double font_size_coeff
; // font size multiplier
63 double line_spacing
; // additional line spacing (in frame pixels)
64 int top_margin
; // height of top margin. Everything except toptitles is shifted down by top_margin.
65 int bottom_margin
; // height of bottom margin. (frame_height - top_margin - bottom_margin) is original video height.
68 int use_margins
; // 0 - place all subtitles inside original frame
69 // 1 - use margins for placing toptitles and subtitles
70 double aspect
; // frame aspect ratio, d_width / d_height.
71 double storage_aspect
; // pixel ratio of the source image
81 int top
, height
, left
, width
;
82 int detect_collisions
;
95 // GlyphInfo and TextInfo are used for text centering and word-wrapping operations
98 unsigned skip
; // skip glyph when layouting text
100 FT_Glyph outline_glyph
;
101 Bitmap
*bm
; // glyph bitmap
102 Bitmap
*bm_o
; // outline bitmap
103 Bitmap
*bm_s
; // shadow bitmap
106 char linebreak
; // the first (leading) glyph of some line ?
107 uint32_t c
[4]; // colors
108 FT_Vector advance
; // 26.6
110 int effect_timing
; // time duration of current karaoke word
111 // after process_karaoke_effects: distance in pixels from the glyph origin.
112 // part of the glyph to the left of it is displayed in a different color.
113 int effect_skip_timing
; // delay after the end of last karaoke word
114 int asc
, desc
; // font max ascender and descender
115 int be
; // blur edges
116 double blur
; // gaussian blur
119 double frx
, fry
, frz
; // rotation
120 double fax
, fay
; // text shearing
122 BitmapHashKey hash_key
;
140 // Values like current font face, color, screen position, clipping and so on are stored here.
148 int flags
; // decoration flags (underline/strike-through)
151 int alignment
; // alignment overrides go here; if zero, style value will be used
152 double frx
, fry
, frz
;
153 double fax
, fay
; // text shearing
155 EVENT_NORMAL
, // "normal" top-, sub- or mid- title
156 EVENT_POSITIONED
, // happens after pos(,), margins are ignored
157 EVENT_HSCROLL
, // "Banner" transition effect, text_width is unlimited
158 EVENT_VSCROLL
// "Scroll up", "Scroll down" transition effects
160 double pos_x
, pos_y
; // position
161 double org_x
, org_y
; // origin
162 char have_origin
; // origin is explicitly defined; if 0, get_base_point() is used
163 double scale_x
, scale_y
;
164 double hspacing
; // distance between letters, in pixels
165 double border_x
; // outline width
167 uint32_t c
[4]; // colors(Primary, Secondary, so on) in RGBA
168 int clip_x0
, clip_y0
, clip_x1
, clip_y1
;
169 char clip_mode
; // 1 = iclip
170 char detect_collisions
;
171 uint32_t fade
; // alpha from \fad
172 char be
; // blur edges
173 double blur
; // gaussian blur
176 int drawing_mode
; // not implemented; when != 0 text is discarded, except for style override tags
177 ASS_Drawing
*drawing
; // current drawing
178 ASS_Drawing
*clip_drawing
; // clip vector
179 int clip_drawing_mode
; // 0 = regular clip, 1 = inverse clip
183 int effect_skip_timing
;
186 SCROLL_LR
, // left-to-right
188 SCROLL_TB
, // top-to-bottom
190 } scroll_direction
; // for EVENT_HSCROLL, EVENT_VSCROLL
197 int treat_family_as_pattern
;
203 Hashmap
*glyph_cache
;
204 Hashmap
*bitmap_cache
;
205 Hashmap
*composite_cache
;
207 size_t bitmap_max_size
;
210 struct ass_renderer
{
211 ASS_Library
*library
;
212 FT_Library ftlibrary
;
213 FCInstance
*fontconfig_priv
;
214 ASS_Settings settings
;
216 ASS_SynthPriv
*synth_priv
;
218 ASS_Image
*images_root
; // rendering result is stored here
219 ASS_Image
*prev_images_root
;
221 EventImages
*eimg
; // temporary buffer for sorting rendered events
222 int eimg_size
; // allocated buffer size
225 int width
, height
; // screen dimensions
226 int orig_height
; // frame height ( = screen height - margins )
227 int orig_width
; // frame width ( = screen width - margins )
228 int orig_height_nocrop
; // frame height ( = screen height - margins + cropheight)
229 int orig_width_nocrop
; // frame width ( = screen width - margins + cropwidth)
231 long long time
; // frame's timestamp, ms
233 double font_scale_x
; // x scale applied to all glyphs to preserve text aspect ratio
244 typedef struct render_priv
{
245 int top
, height
, left
, width
;
257 int a
, b
; // top and height
258 int ha
, hb
; // left and width
261 void reset_render_context(ASS_Renderer
*render_priv
);
262 void ass_free_images(ASS_Image
*img
);
264 #endif /* LIBASS_RENDER_H */