4 new function, boundbox, width, height and rotation.
[blender-staging.git] / source / blender / blenfont / BLF_api.h
1 /**
2  * $Id:
3  *
4  * ***** BEGIN GPL LICENSE BLOCK *****
5  *
6  * This program is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU General Public License
8  * as published by the Free Software Foundation; either version 2
9  * of the License, or (at your option) any later version. 
10  *
11  * This program is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with this program; if not, write to the Free Software Foundation,
18  * Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
19  *
20  * The Original Code is Copyright (C) 2009 Blender Foundation.
21  * All rights reserved.
22  *
23  * 
24  * Contributor(s): Blender Foundation
25  *
26  * ***** END GPL LICENSE BLOCK *****
27  */
28
29 #ifndef BLF_API_H
30 #define BLF_API_H
31
32 int BLF_init(void);
33 void BLF_exit(void);
34
35 int BLF_load(char *name);
36 int BLF_load_mem(char *name, unsigned char *mem, int mem_size);
37
38 void BLF_set(int fontid);
39 void BLF_aspect(float aspect);
40 void BLF_position(float x, float y, float z);
41 void BLF_size(int size, int dpi);
42 void BLF_draw(char *str);
43
44 void BLF_boundbox(char *str, rctf *box);
45 float BLF_width(char *str);
46 float BLF_height(char *str);
47 void BLF_rotation(float angle);
48
49 /* Read the .Blanguages file, return 1 on success or 0 if fails. */
50 int BLF_lang_init(void);
51
52 /* Free the memory allocate for the .Blanguages. */
53 void BLF_lang_exit(void);
54
55 /* Set the current Language. */
56 void BLF_lang_set(int id);
57
58 /* Return a string with all the Language available. */
59 char *BLF_lang_pup(void);
60
61 /* Return the number of invalid lines in the .Blanguages file,
62  * zero means no error found.
63  */
64 int BLF_lang_error(void);
65
66 /* Return the code string for the specified language code. */
67 char *BLF_lang_find_code(short langid);
68
69 /* Add a path to the font dir paths. */
70 void BLF_dir_add(const char *path);
71
72 /* Remove a path from the font dir paths. */
73 void BLF_dir_rem(const char *path);
74
75 /* Return an array with all the font dir (this can be used for filesel) */
76 char **BLF_dir_get(int *ndir);
77
78 /* Free the data return by BLF_dir_get. */
79 void BLF_dir_free(char **dirs, int count);
80
81 #endif /* BLF_API_H */