src/fontcche.h
author Tampax86
Thu, 17 Jul 2025 22:03:19 -0400
changeset 0 b2e3aa63e96c
permissions -rw-r--r--
First commit
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
     1
/*
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
     2
SDL_FontCache v0.10.0: A font cache for SDL and SDL_ttf
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
     3
by Jonathan Dearborn
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
     4
(minor changes have been made by Migdyn for use in Devious Licks)
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
     5
Dedicated to the memory of Florian Hufsky
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
     6
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
     7
License:
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
     8
    The short:
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
     9
    Use it however you'd like, but keep the copyright and license notice
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    10
    whenever these files or parts of them are distributed in uncompiled form.
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    11
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    12
    The long:
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    13
Copyright (c) 2019 Jonathan Dearborn
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    14
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    15
Permission is hereby granted, free of charge, to any person obtaining a copy
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    16
of this software and associated documentation files (the "Software"), to deal
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    17
in the Software without restriction, including without limitation the rights
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    18
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    19
copies of the Software, and to permit persons to whom the Software is
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    20
furnished to do so, subject to the following conditions:
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    21
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    22
The above copyright notice and this permission notice shall be included in
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    23
all copies or substantial portions of the Software.
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    24
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    25
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    26
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    27
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    28
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    29
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    30
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    31
THE SOFTWARE.
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    32
*/
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    33
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    34
#ifndef _SDL_FONTCACHE_H__
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    35
#define _SDL_FONTCACHE_H__
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    36
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    37
#include "SDL2/SDL.h"
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    38
#include "SDL2/SDL_ttf.h"
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    39
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    40
#ifdef FC_USE_SDL_GPU
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    41
    #include "SDL_gpu.h"
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    42
#endif
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    43
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    44
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    45
#include <stdarg.h>
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    46
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    47
#ifdef __cplusplus
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    48
extern "C" {
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    49
#endif
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    50
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    51
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    52
// Let's pretend this exists...
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    53
#define TTF_STYLE_OUTLINE	16
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    54
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    55
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    56
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    57
// Differences between SDL_Renderer and SDL_gpu
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    58
#ifdef FC_USE_SDL_GPU
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    59
#define FC_Rect GPU_Rect
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    60
#define FC_Target GPU_Target
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    61
#define FC_Image GPU_Image
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    62
#define FC_Log GPU_LogError
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    63
#else
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    64
#define FC_Rect SDL_Rect
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    65
#define FC_Target SDL_Renderer
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    66
#define FC_Image SDL_Texture
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    67
#define FC_Log SDL_Log
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    68
#endif
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    69
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    70
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    71
// SDL_FontCache types
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    72
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    73
typedef enum
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    74
{
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    75
    FC_ALIGN_LEFT,
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    76
    FC_ALIGN_CENTER,
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    77
    FC_ALIGN_RIGHT
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    78
} FC_AlignEnum;
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    79
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    80
typedef enum
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    81
{
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    82
    FC_FILTER_NEAREST,
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    83
    FC_FILTER_LINEAR
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    84
} FC_FilterEnum;
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    85
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    86
typedef struct FC_Scale
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    87
{
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    88
    float x;
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    89
    float y;
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    90
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    91
} FC_Scale;
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    92
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    93
typedef struct FC_Effect
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    94
{
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    95
    FC_AlignEnum alignment;
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    96
    FC_Scale scale;
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    97
    SDL_Color color;
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    98
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
    99
} FC_Effect;
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   100
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   101
// Opaque type
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   102
typedef struct FC_Font FC_Font;
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   103
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   104
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   105
typedef struct FC_GlyphData
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   106
{
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   107
    SDL_Rect rect;
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   108
    int cache_level;
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   109
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   110
} FC_GlyphData;
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   111
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   112
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   113
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   114
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   115
// Object creation
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   116
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   117
FC_Rect FC_MakeRect(float x, float y, float w, float h);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   118
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   119
FC_Scale FC_MakeScale(float x, float y);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   120
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   121
SDL_Color FC_MakeColor(Uint8 r, Uint8 g, Uint8 b, Uint8 a);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   122
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   123
FC_Effect FC_MakeEffect(FC_AlignEnum alignment, FC_Scale scale, SDL_Color color);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   124
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   125
FC_GlyphData FC_MakeGlyphData(int cache_level, Sint16 x, Sint16 y, Uint16 w, Uint16 h);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   126
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   127
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   128
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   129
// Font object
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   130
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   131
FC_Font* FC_CreateFont(void);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   132
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   133
#ifdef FC_USE_SDL_GPU
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   134
Uint8 FC_LoadFont(FC_Font* font, const char* filename_ttf, Uint32 pointSize, SDL_Color color, int style);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   135
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   136
Uint8 FC_LoadFontFromTTF(FC_Font* font, TTF_Font* ttf, SDL_Color color);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   137
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   138
Uint8 FC_LoadFont_RW(FC_Font* font, SDL_RWops* file_rwops_ttf, Uint8 own_rwops, Uint32 pointSize, SDL_Color color, int style);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   139
#else
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   140
Uint8 FC_LoadFont(FC_Font* font, SDL_Renderer* renderer, const char* filename_ttf, Uint32 pointSize, SDL_Color color, int style);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   141
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   142
Uint8 FC_LoadFontFromTTF(FC_Font* font, SDL_Renderer* renderer, TTF_Font* ttf, SDL_Color color);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   143
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   144
Uint8 FC_LoadFont_RW(FC_Font* font, SDL_Renderer* renderer, SDL_RWops* file_rwops_ttf, Uint8 own_rwops, Uint32 pointSize, SDL_Color color, int style);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   145
#endif
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   146
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   147
#ifndef FC_USE_SDL_GPU
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   148
// note: handle SDL event types SDL_RENDER_TARGETS_RESET(>= SDL 2.0.2) and SDL_RENDER_DEVICE_RESET(>= SDL 2.0.4)
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   149
void FC_ResetFontFromRendererReset(FC_Font* font, SDL_Renderer* renderer, Uint32 evType);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   150
#endif
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   151
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   152
void FC_ClearFont(FC_Font* font);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   153
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   154
void FC_FreeFont(FC_Font* font);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   155
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   156
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   157
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   158
// Built-in loading strings
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   159
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   160
char* FC_GetStringASCII(void);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   161
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   162
char* FC_GetStringLatin1(void);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   163
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   164
char* FC_GetStringASCII_Latin1(void);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   165
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   166
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   167
// UTF-8 to SDL_FontCache codepoint conversion
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   168
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   169
/*!
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   170
Returns the Uint32 codepoint (not UTF-32) parsed from the given UTF-8 string.
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   171
\param c A pointer to a string of proper UTF-8 character values.
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   172
\param advance_pointer If true, the source pointer will be incremented to skip the extra bytes from multibyte codepoints.
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   173
*/
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   174
Uint32 FC_GetCodepointFromUTF8(const char** c, Uint8 advance_pointer);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   175
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   176
/*!
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   177
Parses the given codepoint and stores the UTF-8 bytes in 'result'.  The result is NULL terminated.
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   178
\param result A memory buffer for the UTF-8 values.  Must be at least 5 bytes long.
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   179
\param codepoint The Uint32 codepoint to parse (not UTF-32).
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   180
*/
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   181
void FC_GetUTF8FromCodepoint(char* result, Uint32 codepoint);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   182
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   183
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   184
// UTF-8 string operations
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   185
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   186
/*! Allocates a new string of 'size' bytes that is already NULL-terminated.  The NULL byte counts toward the size limit, as usual.  Returns NULL if size is 0. */
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   187
char* U8_alloc(unsigned int size);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   188
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   189
/*! Deallocates the given string. */
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   190
void U8_free(char* string);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   191
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   192
/*! Allocates a copy of the given string. */
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   193
char* U8_strdup(const char* string);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   194
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   195
/*! Returns the number of UTF-8 characters in the given string. */
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   196
int U8_strlen(const char* string);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   197
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   198
/*! Returns the number of bytes in the UTF-8 multibyte character pointed at by 'character'. */
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   199
int U8_charsize(const char* character);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   200
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   201
/*! Copies the source multibyte character into the given buffer without overrunning it.  Returns 0 on failure. */
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   202
int U8_charcpy(char* buffer, const char* source, int buffer_size);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   203
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   204
/*! Returns a pointer to the next UTF-8 character. */
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   205
const char* U8_next(const char* string);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   206
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   207
/*! Inserts a UTF-8 string into 'string' at the given position.  Use a position of -1 to append.  Returns 0 when unable to insert the string. */
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   208
int U8_strinsert(char* string, int position, const char* source, int max_bytes);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   209
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   210
/*! Erases the UTF-8 character at the given position, moving the subsequent characters down. */
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   211
void U8_strdel(char* string, int position);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   212
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   213
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   214
// Internal settings
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   215
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   216
/*! Sets the string from which to load the initial glyphs.  Use this if you need upfront loading for any reason (such as lack of render-target support). */
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   217
void FC_SetLoadingString(FC_Font* font, const char* string);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   218
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   219
/*! Returns the size of the internal buffer which is used for unpacking variadic text data.  This buffer is shared by all FC_Fonts. */
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   220
unsigned int FC_GetBufferSize(void);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   221
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   222
/*! Changes the size of the internal buffer which is used for unpacking variadic text data.  This buffer is shared by all FC_Fonts. */
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   223
void FC_SetBufferSize(unsigned int size);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   224
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   225
/*! Returns the width of a single horizontal tab in multiples of the width of a space (default: 4) */
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   226
unsigned int FC_GetTabWidth(void);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   227
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   228
/*! Changes the width of a horizontal tab in multiples of the width of a space (default: 4) */
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   229
void FC_SetTabWidth(unsigned int width_in_spaces);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   230
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   231
void FC_SetRenderCallback(FC_Rect (*callback)(FC_Image* src, FC_Rect* srcrect, FC_Target* dest, float x, float y, float xscale, float yscale));
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   232
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   233
FC_Rect FC_DefaultRenderCallback(FC_Image* src, FC_Rect* srcrect, FC_Target* dest, float x, float y, float xscale, float yscale);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   234
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   235
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   236
// Custom caching
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   237
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   238
/*! Returns the number of cache levels that are active. */
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   239
int FC_GetNumCacheLevels(FC_Font* font);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   240
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   241
/*! Returns the cache source texture at the given cache level. */
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   242
FC_Image* FC_GetGlyphCacheLevel(FC_Font* font, int cache_level);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   243
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   244
// TODO: Specify ownership of the texture (should be shareable)
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   245
/*! Sets a cache source texture for rendering.  New cache levels must be sequential. */
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   246
Uint8 FC_SetGlyphCacheLevel(FC_Font* font, int cache_level, FC_Image* cache_texture);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   247
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   248
/*! Copies the given surface to the given cache level as a texture.  New cache levels must be sequential. */
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   249
Uint8 FC_UploadGlyphCache(FC_Font* font, int cache_level, SDL_Surface* data_surface);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   250
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   251
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   252
/*! Returns the number of codepoints that are stored in the font's glyph data map. */
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   253
unsigned int FC_GetNumCodepoints(FC_Font* font);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   254
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   255
/*! Copies the stored codepoints into the given array. */
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   256
void FC_GetCodepoints(FC_Font* font, Uint32* result);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   257
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   258
/*! Stores the glyph data for the given codepoint in 'result'.  Returns 0 if the codepoint was not found in the cache. */
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   259
Uint8 FC_GetGlyphData(FC_Font* font, FC_GlyphData* result, Uint32 codepoint);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   260
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   261
/*! Sets the glyph data for the given codepoint.  Duplicates are not checked.  Returns a pointer to the stored data. */
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   262
FC_GlyphData* FC_SetGlyphData(FC_Font* font, Uint32 codepoint, FC_GlyphData glyph_data);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   263
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   264
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   265
// Rendering
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   266
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   267
FC_Rect FC_Draw(FC_Font* font, FC_Target* dest, float x, float y, const char* formatted_text, ...);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   268
FC_Rect FC_DrawAlign(FC_Font* font, FC_Target* dest, float x, float y, FC_AlignEnum align, const char* formatted_text, ...);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   269
FC_Rect FC_DrawScale(FC_Font* font, FC_Target* dest, float x, float y, FC_Scale scale, const char* formatted_text, ...);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   270
FC_Rect FC_DrawColor(FC_Font* font, FC_Target* dest, float x, float y, SDL_Color color, const char* formatted_text, ...);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   271
FC_Rect FC_DrawEffect(FC_Font* font, FC_Target* dest, float x, float y, FC_Effect effect, const char* formatted_text, ...);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   272
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   273
FC_Rect FC_DrawBox(FC_Font* font, FC_Target* dest, FC_Rect box, const char* formatted_text, ...);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   274
FC_Rect FC_DrawBoxAlign(FC_Font* font, FC_Target* dest, FC_Rect box, FC_AlignEnum align, const char* formatted_text, ...);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   275
FC_Rect FC_DrawBoxScale(FC_Font* font, FC_Target* dest, FC_Rect box, FC_Scale scale, const char* formatted_text, ...);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   276
FC_Rect FC_DrawBoxColor(FC_Font* font, FC_Target* dest, FC_Rect box, SDL_Color color, const char* formatted_text, ...);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   277
FC_Rect FC_DrawBoxEffect(FC_Font* font, FC_Target* dest, FC_Rect box, FC_Effect effect, const char* formatted_text, ...);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   278
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   279
FC_Rect FC_DrawColumn(FC_Font* font, FC_Target* dest, float x, float y, Uint16 width, const char* formatted_text, ...);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   280
FC_Rect FC_DrawColumnAlign(FC_Font* font, FC_Target* dest, float x, float y, Uint16 width, FC_AlignEnum align, const char* formatted_text, ...);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   281
FC_Rect FC_DrawColumnScale(FC_Font* font, FC_Target* dest, float x, float y, Uint16 width, FC_Scale scale, const char* formatted_text, ...);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   282
FC_Rect FC_DrawColumnColor(FC_Font* font, FC_Target* dest, float x, float y, Uint16 width, SDL_Color color, const char* formatted_text, ...);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   283
FC_Rect FC_DrawColumnEffect(FC_Font* font, FC_Target* dest, float x, float y, Uint16 width, FC_Effect effect, const char* formatted_text, ...);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   284
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   285
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   286
// Getters
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   287
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   288
FC_FilterEnum FC_GetFilterMode(FC_Font* font);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   289
Uint16 FC_GetLineHeight(FC_Font* font);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   290
Uint16 FC_GetHeight(FC_Font* font, const char* formatted_text, ...);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   291
Uint16 FC_GetWidth(FC_Font* font, const char* formatted_text, ...);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   292
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   293
// Returns a 1-pixel wide box in front of the character in the given position (index)
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   294
FC_Rect FC_GetCharacterOffset(FC_Font* font, Uint16 position_index, int column_width, const char* formatted_text, ...);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   295
Uint16 FC_GetColumnHeight(FC_Font* font, Uint16 width, const char* formatted_text, ...);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   296
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   297
int FC_GetAscent(FC_Font* font, const char* formatted_text, ...);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   298
int FC_GetDescent(FC_Font* font, const char* formatted_text, ...);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   299
int FC_GetBaseline(FC_Font* font);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   300
int FC_GetSpacing(FC_Font* font);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   301
int FC_GetLineSpacing(FC_Font* font);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   302
Uint16 FC_GetMaxWidth(FC_Font* font);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   303
SDL_Color FC_GetDefaultColor(FC_Font* font);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   304
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   305
FC_Rect FC_GetBounds(FC_Font* font, float x, float y, FC_AlignEnum align, FC_Scale scale, const char* formatted_text, ...);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   306
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   307
Uint8 FC_InRect(float x, float y, FC_Rect input_rect);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   308
// Given an offset (x,y) from the text draw position (the upper-left corner), returns the character position (UTF-8 index)
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   309
Uint16 FC_GetPositionFromOffset(FC_Font* font, float x, float y, int column_width, FC_AlignEnum align, const char* formatted_text, ...);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   310
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   311
// Returns the number of characters in the new wrapped text written into `result`.
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   312
int FC_GetWrappedText(FC_Font* font, char* result, int max_result_size, Uint16 width, const char* formatted_text, ...);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   313
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   314
// Setters
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   315
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   316
void FC_SetFilterMode(FC_Font* font, FC_FilterEnum filter);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   317
void FC_SetSpacing(FC_Font* font, int LetterSpacing);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   318
void FC_SetLineSpacing(FC_Font* font, int LineSpacing);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   319
void FC_SetDefaultColor(FC_Font* font, SDL_Color color);
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   320
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   321
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   322
#ifdef __cplusplus
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   323
}
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   324
#endif
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   325
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   326
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   327
b2e3aa63e96c First commit
Tampax86
parents:
diff changeset
   328
#endif