[3370] | 1 | /* SFont: a simple font-library that uses special bitmaps as fonts |
---|
| 2 | Copyright (C) 2003 Karl Bartel |
---|
| 3 | |
---|
| 4 | License: GPL or LGPL (at your choice) |
---|
| 5 | WWW: http://www.linux-games.com/sfont/ |
---|
| 6 | |
---|
| 7 | This program is free software; you can redistribute it and/or modify |
---|
| 8 | it under the terms of the GNU General Public License as published by |
---|
| 9 | the Free Software Foundation; either version 2 of the License, or |
---|
| 10 | (at your option) any later version. |
---|
| 11 | |
---|
| 12 | This program is distributed in the hope that it will be useful, |
---|
| 13 | but WITHOUT ANY WARRANTY; without even the implied warranty of |
---|
| 14 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
---|
| 15 | GNU General Public License for more details. |
---|
| 16 | |
---|
| 17 | You should have received a copy of the GNU General Public License |
---|
| 18 | along with this program; if not, write to the Free Software |
---|
| 19 | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
---|
| 20 | |
---|
| 21 | Karl Bartel |
---|
| 22 | Cecilienstr. 14 |
---|
| 23 | 12307 Berlin |
---|
| 24 | GERMANY |
---|
| 25 | karlb@gmx.net |
---|
| 26 | */ |
---|
| 27 | |
---|
| 28 | /************************************************************************ |
---|
| 29 | * SFONT - SDL Font Library by Karl Bartel <karlb@gmx.net> * |
---|
| 30 | * * |
---|
| 31 | * All functions are explained below. For further information, take a * |
---|
| 32 | * look at the example files, the links at the SFont web site, or * |
---|
| 33 | * contact me, if you problem isn' addressed anywhere. * |
---|
| 34 | * * |
---|
| 35 | ************************************************************************/ |
---|
| 36 | #ifndef SFONT_H |
---|
| 37 | #define SFONT_H |
---|
| 38 | |
---|
| 39 | #include <SDL.h> |
---|
| 40 | |
---|
| 41 | #ifdef __cplusplus |
---|
| 42 | extern "C" { |
---|
| 43 | #endif |
---|
| 44 | |
---|
| 45 | // Delcare one variable of this type for each font you are using. |
---|
| 46 | // To load the fonts, load the font image into YourFont->Surface |
---|
| 47 | // and call InitFont( YourFont ); |
---|
| 48 | typedef struct { |
---|
| 49 | SDL_Surface *Surface; |
---|
| 50 | int CharPos[512]; |
---|
| 51 | int MaxPos; |
---|
| 52 | } SFont_Font; |
---|
| 53 | |
---|
| 54 | // Initializes the font |
---|
| 55 | // Font: this contains the suface with the font. |
---|
| 56 | // The Surface must be loaded before calling this function |
---|
| 57 | SFont_Font* SFont_InitFont (SDL_Surface *Font); |
---|
| 58 | |
---|
| 59 | // Frees the font |
---|
| 60 | // Font: The font to free |
---|
| 61 | // The font must be loaded before using this function. |
---|
| 62 | void SFont_FreeFont(SFont_Font* Font); |
---|
| 63 | |
---|
| 64 | // Blits a string to a surface |
---|
| 65 | // Destination: the suface you want to blit to |
---|
| 66 | // text: a string containing the text you want to blit. |
---|
| 67 | void SFont_Write(SDL_Surface *Surface, const SFont_Font *Font, int x, int y, |
---|
| 68 | const char *text); |
---|
| 69 | |
---|
| 70 | // Returns the width of "text" in pixels |
---|
| 71 | int SFont_TextWidth(const SFont_Font* Font, const char *text); |
---|
| 72 | // Returns the height of "text" in pixels (which is always equal to Font->Surface->h) |
---|
| 73 | int SFont_TextHeight(const SFont_Font* Font); |
---|
| 74 | |
---|
| 75 | // Blits a string to Surface with centered x position |
---|
| 76 | void SFont_WriteCenter(SDL_Surface *Surface, const SFont_Font* Font, int y, |
---|
| 77 | const char *text); |
---|
| 78 | |
---|
| 79 | #ifdef __cplusplus |
---|
| 80 | } |
---|
| 81 | #endif |
---|
| 82 | |
---|
| 83 | #endif /* SFONT_H */ |
---|