1
0
mirror of https://github.com/lvgl/lvgl.git synced 2025-01-21 06:53:01 +08:00
lvgl/src/lv_misc/lv_font.h

205 lines
6.1 KiB
C
Raw Normal View History

2017-11-23 20:42:14 +01:00
/**
2017-11-23 21:28:36 +01:00
* @file lv_font.h
*
2017-11-23 20:42:14 +01:00
*/
2017-11-23 21:28:36 +01:00
#ifndef LV_FONT_H
#define LV_FONT_H
2017-11-23 20:42:14 +01:00
#ifdef __cplusplus
extern "C" {
#endif
/*********************
* INCLUDES
*********************/
#ifdef LV_CONF_INCLUDE_SIMPLE
#include "lv_conf.h"
#else
2019-03-17 08:33:03 +01:00
#include "../../../lv_conf.h"
#endif
2017-11-23 20:42:14 +01:00
#include <stdint.h>
#include <stddef.h>
2018-06-22 23:32:21 +02:00
#include <stdbool.h>
2017-11-23 20:42:14 +01:00
#include "lv_symbol_def.h"
2017-11-23 20:42:14 +01:00
/*********************
* DEFINES
*********************/
2019-04-27 19:37:19 +02:00
/*Number of fractional digits in the advanced width (`adv_w`) field of `lv_font_glyph_dsc_t`*/
#define LV_FONT_ADV_W_FRACT_DIGIT 4
2017-11-23 20:42:14 +01:00
/**********************
* TYPEDEFS
**********************/
2018-02-05 11:27:08 +01:00
typedef struct
{
2019-04-23 15:56:59 +02:00
uint32_t bitmap_index : 20; /* Start index of the bitmap. A font can be max 1 MB. */
2019-04-27 19:37:19 +02:00
uint32_t adv_w :12; /*The glyph needs this space. Draw the next glyph after this width. 8 bit integer, 4 bit fractional */
2019-04-23 15:56:59 +02:00
uint8_t box_w; /*Width of the glyph's bounding box*/
uint8_t box_h; /*Height of the glyph's bounding box*/
uint8_t ofs_x; /*x offset of the bounding box*/
int8_t ofs_y; /*y offset of the bounding box*/
} lv_font_glyph_dsc_t;
2018-02-05 11:27:08 +01:00
typedef struct {
const uint8_t * glyph_bitmap;
const lv_font_glyph_dsc_t * glyph_dsc;
const uint16_t * unicode_list;
uint16_t glyph_cnt; /*Number of glyphs in the font. */
}lv_font_dsc_built_in_t;
2017-11-23 21:28:36 +01:00
typedef struct _lv_font_struct
2017-11-23 20:42:14 +01:00
{
2018-02-05 11:27:08 +01:00
uint32_t unicode_first;
uint32_t unicode_last;
2019-04-22 05:21:35 +02:00
/*Get a glyph's descriptor from a font*/
const lv_font_glyph_dsc_t * (*get_glyph_dsc)(const struct _lv_font_struct *, uint32_t letter);
2019-04-22 05:21:35 +02:00
/*Get a glyph's bitmap from a font*/
const uint8_t * (*get_glyph_bitmap)(const struct _lv_font_struct *, uint32_t);
2019-04-22 05:21:35 +02:00
/*Pointer to the font in a font pack (must have the same line height)*/
2019-04-22 05:21:35 +02:00
struct _lv_font_struct * next_page;
uint8_t size; /*The original size*/
uint8_t line_height; /*The real line height where any text fits*/
uint8_t base_line; /*Base line measured from the top of the line*/
2019-04-23 15:56:59 +02:00
uint8_t bpp; /*Bit per pixel: 1, 2, 4 or 8*/
void * dsc; /*Store implementation specific data here*/
} lv_font_t;
2017-11-23 20:42:14 +01:00
/**********************
* GLOBAL PROTOTYPES
**********************/
/**
* Initialize the fonts
2017-11-23 20:42:14 +01:00
*/
2017-11-23 21:28:36 +01:00
void lv_font_init(void);
2017-11-23 20:42:14 +01:00
/**
2018-12-13 15:18:06 +01:00
* Add a font to an other to extend the character set.
* @param child the font to add
* @param parent this font will be extended. Using it later will contain the characters from `child`
2017-11-23 20:42:14 +01:00
*/
2019-04-04 07:15:40 +02:00
void lv_font_add(lv_font_t * child, lv_font_t * parent);
2017-11-23 20:42:14 +01:00
2018-12-13 15:18:06 +01:00
/**
* Remove a font from a character set.
* @param child the font to remove
* @param parent remove `child` from here
*/
void lv_font_remove(lv_font_t * child, lv_font_t * parent);
2018-06-22 23:32:21 +02:00
/**
* Tells if font which contains `letter` is monospace or not
* @param font_p point to font
* @param letter an UNICODE character code
* @return true: the letter is monospace; false not monospace
*/
bool lv_font_is_monospace(const lv_font_t * font_p, uint32_t letter);
2017-11-23 20:42:14 +01:00
/**
* Return with the bitmap of a font.
* @param font_p pointer to a font
2018-06-22 23:32:21 +02:00
* @param letter an UNICODE character code
2017-11-23 20:42:14 +01:00
* @return pointer to the bitmap of the letter
*/
2019-04-22 05:21:35 +02:00
const uint8_t * lv_font_get_glyph_bitmap(const lv_font_t * font_p, uint32_t letter);
2017-11-23 20:42:14 +01:00
/**
* Get the description of a glyph in a font.
* @param font_p pointer to a font
* @param letter an UNICODE character code
* @return pointer to a glyph descriptor
*/
const lv_font_glyph_dsc_t * lv_font_get_glyph_dsc(const lv_font_t * font_p, uint32_t letter);
uint8_t lv_font_get_width(const lv_font_t * font, uint32_t letter);
2018-06-22 23:32:21 +02:00
/**
* Get the width of a letter in a font. If `monospace` is set then return with it.
* @param font_p pointer to a font
* @param letter an UNICODE character code
* @return the width of a letter
*/
uint8_t lv_font_get_width(const lv_font_t * font_p, uint32_t letter);
/**
* Get the width of the letter without overwriting it with the `monospace` attribute
* @param font_p pointer to a font
* @param letter an UNICODE character code
* @return the width of a letter
*/
uint8_t lv_font_get_real_width(const lv_font_t * font_p, uint32_t letter);
2017-11-23 20:42:14 +01:00
/**
2019-04-23 15:56:59 +02:00
* Get the line height of a font. All characters fit into this height
2017-11-23 20:42:14 +01:00
* @param font_p pointer to a font
* @return the height of a font
*/
2019-04-23 15:56:59 +02:00
static inline uint8_t lv_font_get_line_height(const lv_font_t * font_p)
2017-11-23 20:42:14 +01:00
{
return font_p->line_height;//(uint8_t)((int16_t)font_p->ascent - font_p->descent);
2017-11-23 20:42:14 +01:00
}
/**
2018-02-09 12:40:00 +01:00
* Get the bit-per-pixel of font
* @param font pointer to font
* @param letter a letter from font (font extensions can have different bpp)
* @return bpp of the font (or font extension)
2017-11-23 20:42:14 +01:00
*/
uint8_t lv_font_get_bpp(const lv_font_t * font, uint32_t letter);
2018-02-09 12:40:00 +01:00
2019-04-24 05:44:15 +02:00
2018-02-09 12:40:00 +01:00
/**
2019-04-04 07:15:40 +02:00
* Generic bitmap get function used in 'font->get_bitmap' when the font contains all characters in
* the range
2018-02-09 12:40:00 +01:00
* @param font pointer to font
* @param unicode_letter an unicode letter which bitmap should be get
* @return pointer to the bitmap or NULL if not found
*/
2019-04-24 05:44:15 +02:00
const uint8_t * lv_font_get_glyph_bitmap_plain(const lv_font_t * font, uint32_t unicode_letter);
2018-02-09 12:40:00 +01:00
/**
2019-04-04 07:15:40 +02:00
* Generic glyph width get function used in 'font->get_width' when the font contains all characters
* in the range
* @param font pointer to font
* @param unicode_letter an unicode letter which width should be get
* @return width of the gylph or -1 if not found
*/
2019-04-24 05:44:15 +02:00
const lv_font_glyph_dsc_t * lv_font_get_glyph_dsc_plain(const lv_font_t * font, uint32_t unicode_letter);
2017-11-23 20:42:14 +01:00
/**********************
* MACROS
**********************/
2018-02-09 12:40:00 +01:00
#define LV_FONT_DECLARE(font_name) extern lv_font_t font_name;
2018-02-09 12:40:00 +01:00
2019-04-27 19:37:19 +02:00
#define LV_FONT_SET_ADV_W(_integer, _fract) ((_integer << LV_FONT_ADV_W_FRACT_DIGIT) + _fract)
#define LV_FONT_GET_ADV_W_INT(_adv_w) (_adw_v >> LV_FONT_ADV_W_FRACT_DIGIT)
#define LV_FONT_GET_ADV_W_FRACT(_adv_w) (_adw_v & ((1 << LV_FONT_ADV_W_FRACT_DIGIT) -1))
/**********************
* ADD BUILT IN FONTS
**********************/
#include "../lv_fonts/lv_font_builtin.h"
2017-11-23 20:42:14 +01:00
/*Declare the custom (user defined) fonts*/
#ifdef LV_FONT_CUSTOM_DECLARE
LV_FONT_CUSTOM_DECLARE
#endif
2017-11-23 20:42:14 +01:00
#ifdef __cplusplus
} /* extern "C" */
#endif
2017-11-26 23:57:39 +01:00
#endif /*USE_FONT*/