2012-04-21 21:13:50 +00:00
|
|
|
/* RetroArch - A frontend for libretro.
|
2014-01-01 00:50:59 +00:00
|
|
|
* Copyright (C) 2010-2014 - Hans-Kristian Arntzen
|
2017-01-22 12:40:32 +00:00
|
|
|
* Copyright (C) 2011-2017 - Daniel De Matteis
|
2017-12-12 07:55:31 +00:00
|
|
|
*
|
2012-04-21 21:13:50 +00:00
|
|
|
* RetroArch is free software: you can redistribute it and/or modify it under the terms
|
2012-02-12 14:23:35 +00:00
|
|
|
* of the GNU General Public License as published by the Free Software Found-
|
|
|
|
* ation, either version 3 of the License, or (at your option) any later version.
|
|
|
|
*
|
2012-04-21 21:13:50 +00:00
|
|
|
* RetroArch is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
|
2012-02-12 14:23:35 +00:00
|
|
|
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
|
|
|
|
* PURPOSE. See the GNU General Public License for more details.
|
|
|
|
*
|
2012-04-21 21:31:57 +00:00
|
|
|
* You should have received a copy of the GNU General Public License along with RetroArch.
|
2012-02-12 14:23:35 +00:00
|
|
|
* If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
2015-04-03 18:36:19 +00:00
|
|
|
#ifndef __FONT_DRIVER_H__
|
|
|
|
#define __FONT_DRIVER_H__
|
2012-02-12 14:23:35 +00:00
|
|
|
|
2012-12-15 02:35:04 +00:00
|
|
|
#include <stdint.h>
|
2015-12-05 11:07:22 +00:00
|
|
|
|
2014-10-21 03:05:52 +00:00
|
|
|
#include <boolean.h>
|
2016-06-03 04:02:49 +00:00
|
|
|
#include <retro_common_api.h>
|
2012-02-17 18:35:51 +00:00
|
|
|
|
2019-06-17 13:10:22 +00:00
|
|
|
#include "../retroarch.h"
|
2017-01-19 15:30:40 +00:00
|
|
|
|
2020-03-09 13:18:29 +00:00
|
|
|
#include "video_defines.h"
|
|
|
|
|
2016-06-03 04:02:49 +00:00
|
|
|
RETRO_BEGIN_DECLS
|
2014-01-22 15:38:42 +00:00
|
|
|
|
2015-12-05 11:07:22 +00:00
|
|
|
/* All coordinates and offsets are top-left oriented.
|
|
|
|
*
|
2017-12-12 07:55:31 +00:00
|
|
|
* This is a texture-atlas approach which allows text to
|
2015-12-05 11:07:22 +00:00
|
|
|
* be drawn in a single draw call.
|
|
|
|
*
|
2017-12-12 07:55:31 +00:00
|
|
|
* It is up to the code using this interface to actually
|
2015-12-05 11:07:22 +00:00
|
|
|
* generate proper vertex buffers and upload the atlas texture to GPU. */
|
|
|
|
|
|
|
|
struct font_glyph
|
|
|
|
{
|
|
|
|
unsigned width;
|
|
|
|
unsigned height;
|
|
|
|
|
|
|
|
/* Texel coordinate offset for top-left pixel of this glyph. */
|
|
|
|
unsigned atlas_offset_x;
|
|
|
|
unsigned atlas_offset_y;
|
|
|
|
|
2017-12-12 07:55:31 +00:00
|
|
|
/* When drawing this glyph, apply an offset to
|
2015-12-05 11:07:22 +00:00
|
|
|
* current X/Y draw coordinate. */
|
|
|
|
int draw_offset_x;
|
|
|
|
int draw_offset_y;
|
|
|
|
|
|
|
|
/* Advance X/Y draw coordinates after drawing this glyph. */
|
|
|
|
int advance_x;
|
|
|
|
int advance_y;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct font_atlas
|
|
|
|
{
|
|
|
|
uint8_t *buffer; /* Alpha channel. */
|
|
|
|
unsigned width;
|
|
|
|
unsigned height;
|
2016-10-21 16:25:21 +00:00
|
|
|
bool dirty;
|
2015-12-05 11:07:22 +00:00
|
|
|
};
|
|
|
|
|
2015-12-05 09:31:15 +00:00
|
|
|
struct font_params
|
|
|
|
{
|
2020-08-18 15:16:59 +00:00
|
|
|
/* Drop shadow offset.
|
|
|
|
* If both are 0, no drop shadow will be rendered. */
|
|
|
|
int drop_x, drop_y;
|
|
|
|
|
|
|
|
/* ABGR. Use the macros. */
|
|
|
|
uint32_t color;
|
|
|
|
|
2015-12-05 09:31:15 +00:00
|
|
|
float x;
|
|
|
|
float y;
|
|
|
|
float scale;
|
|
|
|
/* Drop shadow color multiplier. */
|
|
|
|
float drop_mod;
|
2016-04-09 06:23:59 +00:00
|
|
|
/* Drop shadow alpha */
|
|
|
|
float drop_alpha;
|
2020-08-18 15:16:59 +00:00
|
|
|
|
2015-12-05 09:31:15 +00:00
|
|
|
enum text_alignment text_align;
|
2020-08-18 15:16:59 +00:00
|
|
|
|
|
|
|
bool full_screen;
|
2015-12-05 09:31:15 +00:00
|
|
|
};
|
|
|
|
|
2020-03-31 15:49:16 +00:00
|
|
|
struct font_line_metrics
|
|
|
|
{
|
|
|
|
float height;
|
|
|
|
float ascender;
|
|
|
|
float descender;
|
|
|
|
};
|
|
|
|
|
2015-12-08 10:52:32 +00:00
|
|
|
typedef struct font_renderer
|
|
|
|
{
|
2017-01-25 13:47:24 +00:00
|
|
|
void *(*init)(void *data, const char *font_path,
|
|
|
|
float font_size, bool is_threaded);
|
|
|
|
void (*free)(void *data, bool is_threaded);
|
2020-03-09 20:34:14 +00:00
|
|
|
void (*render_msg)(void *userdata,
|
2017-01-19 15:30:40 +00:00
|
|
|
void *data, const char *msg,
|
2018-03-23 16:43:49 +00:00
|
|
|
const struct font_params *params);
|
2015-12-08 10:52:32 +00:00
|
|
|
const char *ident;
|
|
|
|
|
|
|
|
const struct font_glyph *(*get_glyph)(void *data, uint32_t code);
|
|
|
|
void (*bind_block)(void *data, void *block);
|
2020-03-07 00:41:00 +00:00
|
|
|
void (*flush)(unsigned width, unsigned height, void *data);
|
2017-12-12 07:55:31 +00:00
|
|
|
|
2015-12-08 10:52:32 +00:00
|
|
|
int (*get_message_width)(void *data, const char *msg, unsigned msg_len_full, float scale);
|
2020-03-31 15:49:16 +00:00
|
|
|
bool (*get_line_metrics)(void* data, struct font_line_metrics **metrics);
|
2015-12-08 10:52:32 +00:00
|
|
|
} font_renderer_t;
|
|
|
|
|
2015-12-05 11:07:22 +00:00
|
|
|
typedef struct font_renderer_driver
|
|
|
|
{
|
|
|
|
void *(*init)(const char *font_path, float font_size);
|
|
|
|
|
2016-10-21 16:25:21 +00:00
|
|
|
struct font_atlas *(*get_atlas)(void *data);
|
2015-12-05 11:07:22 +00:00
|
|
|
|
|
|
|
/* Returns NULL if no glyph for this code is found. */
|
|
|
|
const struct font_glyph *(*get_glyph)(void *data, uint32_t code);
|
|
|
|
|
|
|
|
void (*free)(void *data);
|
|
|
|
|
|
|
|
const char *(*get_default_font)(void);
|
|
|
|
|
|
|
|
const char *ident;
|
2017-12-12 07:55:31 +00:00
|
|
|
|
2020-03-31 15:49:16 +00:00
|
|
|
bool (*get_line_metrics)(void* data, struct font_line_metrics **metrics);
|
2015-12-05 11:07:22 +00:00
|
|
|
} font_renderer_driver_t;
|
|
|
|
|
2016-10-18 23:07:00 +00:00
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
const font_renderer_t *renderer;
|
|
|
|
void *renderer_data;
|
|
|
|
float size;
|
|
|
|
} font_data_t;
|
|
|
|
|
2015-12-05 11:07:22 +00:00
|
|
|
/* font_path can be NULL for default font. */
|
2018-07-13 22:54:14 +00:00
|
|
|
int font_renderer_create_default(
|
|
|
|
const font_renderer_driver_t **drv,
|
|
|
|
void **handle,
|
|
|
|
const char *font_path, unsigned font_size);
|
2017-12-12 07:55:31 +00:00
|
|
|
|
2020-01-04 15:24:14 +00:00
|
|
|
void font_driver_render_msg(void *data,
|
|
|
|
const char *msg, const void *params, void *font_data);
|
2015-12-05 09:31:15 +00:00
|
|
|
|
2015-12-05 10:34:56 +00:00
|
|
|
void font_driver_bind_block(void *font_data, void *block);
|
2015-12-05 09:59:03 +00:00
|
|
|
|
2016-10-18 23:07:00 +00:00
|
|
|
int font_driver_get_message_width(void *font_data, const char *msg, unsigned len, float scale);
|
|
|
|
|
2020-03-07 00:41:00 +00:00
|
|
|
void font_driver_flush(unsigned width, unsigned height, void *font_data);
|
2015-12-05 11:17:58 +00:00
|
|
|
|
2016-10-18 23:07:00 +00:00
|
|
|
void font_driver_free(void *font_data);
|
2015-12-05 11:10:12 +00:00
|
|
|
|
2017-04-29 14:52:52 +00:00
|
|
|
font_data_t *font_driver_init_first(
|
|
|
|
void *video_data,
|
|
|
|
const char *font_path,
|
|
|
|
float font_size,
|
|
|
|
bool threading_hint,
|
|
|
|
bool is_threaded,
|
|
|
|
enum font_driver_render_api api);
|
|
|
|
|
|
|
|
void font_driver_init_osd(
|
|
|
|
void *video_data,
|
2020-02-16 20:59:03 +00:00
|
|
|
const void *video_info_data,
|
2017-04-29 14:52:52 +00:00
|
|
|
bool threading_hint,
|
|
|
|
bool is_threaded,
|
|
|
|
enum font_driver_render_api api);
|
2020-02-16 20:59:03 +00:00
|
|
|
|
2016-10-18 23:07:00 +00:00
|
|
|
void font_driver_free_osd(void);
|
2015-12-05 09:31:15 +00:00
|
|
|
|
2019-02-17 15:54:24 +00:00
|
|
|
int font_driver_get_line_height(void *font_data, float scale);
|
2020-03-31 15:49:16 +00:00
|
|
|
int font_driver_get_line_ascender(void *font_data, float scale);
|
|
|
|
int font_driver_get_line_descender(void *font_data, float scale);
|
|
|
|
int font_driver_get_line_centre_offset(void *font_data, float scale);
|
2019-02-17 15:54:24 +00:00
|
|
|
|
2022-05-17 12:16:53 +00:00
|
|
|
extern font_renderer_t gl2_raster_font;
|
2021-11-23 07:45:54 +00:00
|
|
|
extern font_renderer_t gl3_raster_font;
|
2019-02-08 17:14:55 +00:00
|
|
|
extern font_renderer_t gl1_raster_font;
|
2015-12-05 11:07:22 +00:00
|
|
|
extern font_renderer_t d3d_xdk1_font;
|
|
|
|
extern font_renderer_t d3d_win32_font;
|
2019-01-07 20:49:55 +00:00
|
|
|
extern font_renderer_t ps2_font;
|
2015-12-05 11:07:22 +00:00
|
|
|
extern font_renderer_t vita2d_vita_font;
|
2016-09-29 19:14:12 +00:00
|
|
|
extern font_renderer_t ctr_font;
|
2017-05-21 02:05:41 +00:00
|
|
|
extern font_renderer_t wiiu_font;
|
2016-02-16 19:24:00 +00:00
|
|
|
extern font_renderer_t vulkan_raster_font;
|
2018-06-21 04:29:53 +00:00
|
|
|
extern font_renderer_t metal_raster_font;
|
2018-04-21 01:27:41 +00:00
|
|
|
extern font_renderer_t d3d10_font;
|
2018-01-24 19:51:19 +00:00
|
|
|
extern font_renderer_t d3d11_font;
|
2018-02-07 20:59:18 +00:00
|
|
|
extern font_renderer_t d3d12_font;
|
2016-12-01 17:13:36 +00:00
|
|
|
extern font_renderer_t caca_font;
|
2017-01-04 07:07:19 +00:00
|
|
|
extern font_renderer_t gdi_font;
|
2017-01-21 22:41:20 +00:00
|
|
|
extern font_renderer_t vga_font;
|
2018-07-12 20:55:08 +00:00
|
|
|
extern font_renderer_t sixel_font;
|
2018-09-12 19:44:53 +00:00
|
|
|
extern font_renderer_t switch_font;
|
2022-03-27 01:51:33 +00:00
|
|
|
extern font_renderer_t rsx_font;
|
2015-12-05 11:07:22 +00:00
|
|
|
|
|
|
|
extern font_renderer_driver_t stb_font_renderer;
|
2016-11-05 15:20:18 +00:00
|
|
|
extern font_renderer_driver_t stb_unicode_font_renderer;
|
2015-12-05 11:07:22 +00:00
|
|
|
extern font_renderer_driver_t freetype_font_renderer;
|
|
|
|
extern font_renderer_driver_t coretext_font_renderer;
|
|
|
|
extern font_renderer_driver_t bitmap_font_renderer;
|
|
|
|
|
2016-06-03 04:02:49 +00:00
|
|
|
RETRO_END_DECLS
|
2014-01-22 15:38:42 +00:00
|
|
|
|
2012-02-17 18:35:51 +00:00
|
|
|
#endif
|