mirror of https://github.com/mgba-emu/mgba.git
3DS: Update font code for ctrulib 1.6
This commit is contained in:
parent
6bd38d1565
commit
1a6d5ad7e3
|
@ -14,6 +14,7 @@
|
||||||
#define FONT_SIZE 15.6f
|
#define FONT_SIZE 15.6f
|
||||||
|
|
||||||
struct GUIFont {
|
struct GUIFont {
|
||||||
|
CFNT_s* font;
|
||||||
C3D_Tex* sheets;
|
C3D_Tex* sheets;
|
||||||
C3D_Tex icons;
|
C3D_Tex icons;
|
||||||
float size;
|
float size;
|
||||||
|
@ -27,14 +28,15 @@ struct GUIFont* GUIFontCreate(void) {
|
||||||
}
|
}
|
||||||
C3D_Tex* tex;
|
C3D_Tex* tex;
|
||||||
|
|
||||||
TGLP_s* glyphInfo = fontGetGlyphInfo();
|
guiFont->font = fontGetSystemFont();
|
||||||
|
TGLP_s* glyphInfo = fontGetGlyphInfo(guiFont->font);
|
||||||
guiFont->size = FONT_SIZE / glyphInfo->cellHeight;
|
guiFont->size = FONT_SIZE / glyphInfo->cellHeight;
|
||||||
guiFont->sheets = malloc(sizeof(*guiFont->sheets) * glyphInfo->nSheets);
|
guiFont->sheets = malloc(sizeof(*guiFont->sheets) * glyphInfo->nSheets);
|
||||||
|
|
||||||
int i;
|
int i;
|
||||||
for (i = 0; i < glyphInfo->nSheets; ++i) {
|
for (i = 0; i < glyphInfo->nSheets; ++i) {
|
||||||
tex = &guiFont->sheets[i];
|
tex = &guiFont->sheets[i];
|
||||||
tex->data = fontGetGlyphSheetTex(i);
|
tex->data = fontGetGlyphSheetTex(guiFont->font, i);
|
||||||
tex->fmt = glyphInfo->sheetFmt;
|
tex->fmt = glyphInfo->sheetFmt;
|
||||||
tex->size = glyphInfo->sheetSize;
|
tex->size = glyphInfo->sheetSize;
|
||||||
tex->width = glyphInfo->sheetWidth;
|
tex->width = glyphInfo->sheetWidth;
|
||||||
|
@ -59,12 +61,12 @@ void GUIFontDestroy(struct GUIFont* font) {
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned GUIFontHeight(const struct GUIFont* font) {
|
unsigned GUIFontHeight(const struct GUIFont* font) {
|
||||||
return fontGetInfo()->lineFeed * font->size;
|
return fontGetInfo(font->font)->lineFeed * font->size;
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned GUIFontGlyphWidth(const struct GUIFont* font, uint32_t glyph) {
|
unsigned GUIFontGlyphWidth(const struct GUIFont* font, uint32_t glyph) {
|
||||||
int index = fontGlyphIndexFromCodePoint(glyph);
|
int index = fontGlyphIndexFromCodePoint(font->font, glyph);
|
||||||
charWidthInfo_s* info = fontGetCharWidthInfo(index);
|
charWidthInfo_s* info = fontGetCharWidthInfo(font->font, index);
|
||||||
if (info) {
|
if (info) {
|
||||||
return info->charWidth * font->size;
|
return info->charWidth * font->size;
|
||||||
}
|
}
|
||||||
|
@ -91,9 +93,9 @@ void GUIFontIconMetrics(const struct GUIFont* font, enum GUIIcon icon, unsigned*
|
||||||
}
|
}
|
||||||
|
|
||||||
void GUIFontDrawGlyph(const struct GUIFont* font, int glyph_x, int glyph_y, uint32_t color, uint32_t glyph) {
|
void GUIFontDrawGlyph(const struct GUIFont* font, int glyph_x, int glyph_y, uint32_t color, uint32_t glyph) {
|
||||||
int index = fontGlyphIndexFromCodePoint(glyph);
|
int index = fontGlyphIndexFromCodePoint(font->font, glyph);
|
||||||
fontGlyphPos_s data;
|
fontGlyphPos_s data;
|
||||||
fontCalcGlyphPos(&data, index, 0, 1.0, 1.0);
|
fontCalcGlyphPos(&data, font->font, index, 0, 1.0, 1.0);
|
||||||
|
|
||||||
C3D_Tex* tex = &font->sheets[data.sheetIndex];
|
C3D_Tex* tex = &font->sheets[data.sheetIndex];
|
||||||
ctrActivateTexture(tex);
|
ctrActivateTexture(tex);
|
||||||
|
|
Loading…
Reference in New Issue