1 // -*- c-basic-offset: 8; indent-tabs-mode: t -*-
2 // vim:ts=8:sw=8:noet:ai:
4 * Copyright (C) 2006 Evgeniy Stepanov <eugeni.stepanov@gmail.com>
6 * This file is part of libass.
8 * libass is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License as published by
10 * the Free Software Foundation; either version 2 of the License, or
11 * (at your option) any later version.
13 * libass is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
18 * You should have received a copy of the GNU General Public License along
19 * with libass; if not, write to the Free Software Foundation, Inc.,
20 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
23 #ifndef LIBASS_CACHE_H
24 #define LIBASS_CACHE_H
28 #include "ass_bitmap.h"
30 void ass_font_cache_init(void);
31 ass_font_t
* ass_font_cache_find(ass_font_desc_t
* desc
);
32 void* ass_font_cache_add(ass_font_t
* font
);
33 void ass_font_cache_done(void);
36 // describes a bitmap; bitmaps with equivalents structs are considered identical
37 typedef struct bitmap_hash_key_s
{
38 char bitmap
; // bool : true = bitmap, false = outline
40 double size
; // font size
41 uint32_t ch
; // character code
42 unsigned outline
; // border width, 16.16 fixed point value
44 char be
; // blur edges
45 double blur
; // gaussian blur
47 unsigned scale_x
, scale_y
; // 16.16
48 int frx
, fry
, frz
; // signed 16.16
49 int shift_x
, shift_y
; // shift vector that was added to glyph before applying rotation
50 // = 0, if frx = fry = frx = 0
51 // = (glyph base point) - (rotation origin), otherwise
53 FT_Vector advance
; // subpixel shift vector
56 typedef struct bitmap_hash_val_s
{
57 bitmap_t
* bm
; // the actual bitmaps
62 void ass_bitmap_cache_init(void);
63 void* cache_add_bitmap(bitmap_hash_key_t
* key
, bitmap_hash_val_t
* val
);
64 bitmap_hash_val_t
* cache_find_bitmap(bitmap_hash_key_t
* key
);
65 void ass_bitmap_cache_reset(void);
66 void ass_bitmap_cache_done(void);
68 // describes an outline glyph
69 typedef struct glyph_hash_key_s
{
71 double size
; // font size
72 uint32_t ch
; // character code
74 unsigned scale_x
, scale_y
; // 16.16
75 FT_Vector advance
; // subpixel shift vector
76 unsigned outline
; // border width, 16.16
79 typedef struct glyph_hash_val_s
{
81 FT_Glyph outline_glyph
;
82 FT_BBox bbox_scaled
; // bbox after scaling, but before rotation
83 FT_Vector advance
; // 26.6, advance distance to the next bitmap in line
86 void ass_glyph_cache_init(void);
87 void* cache_add_glyph(glyph_hash_key_t
* key
, glyph_hash_val_t
* val
);
88 glyph_hash_val_t
* cache_find_glyph(glyph_hash_key_t
* key
);
89 void ass_glyph_cache_reset(void);
90 void ass_glyph_cache_done(void);
92 typedef struct hashmap_s hashmap_t
;
93 typedef void (*hashmap_item_dtor_t
)(void* key
, size_t key_size
, void* value
, size_t value_size
);
94 typedef int (*hashmap_key_compare_t
)(void* key1
, void* key2
, size_t key_size
);
95 typedef unsigned (*hashmap_hash_t
)(void* key
, size_t key_size
);
97 hashmap_t
* hashmap_init(size_t key_size
, size_t value_size
, int nbuckets
,
98 hashmap_item_dtor_t item_dtor
, hashmap_key_compare_t key_compare
,
100 void hashmap_done(hashmap_t
* map
);
101 void* hashmap_insert(hashmap_t
* map
, void* key
, void* value
);
102 void* hashmap_find(hashmap_t
* map
, void* key
);
104 #endif /* LIBASS_CACHE_H */