3DS: Scale font based on glyph heights (fixes #961)

This commit is contained in:
Vicki Pfau 2018-01-15 05:48:19 -08:00
parent 67e03bda91
commit 9fac945e1c
2 changed files with 7 additions and 8 deletions

View File

@ -58,6 +58,7 @@ Misc:
- GB: Skip BIOS option now works - GB: Skip BIOS option now works
- Libretro: Add frameskip option - Libretro: Add frameskip option
- GBA Memory: 64 MiB GBA Video cartridge support - GBA Memory: 64 MiB GBA Video cartridge support
- 3DS: Scale font based on glyph heights (fixes mgba.io/i/961)
0.6.1: (2017-10-01) 0.6.1: (2017-10-01)
Bugfixes: Bugfixes:

View File

@ -11,13 +11,12 @@
#include "ctr-gpu.h" #include "ctr-gpu.h"
#define CELL_HEIGHT 16 #define FONT_SIZE 15.6f
#define CELL_WIDTH 16
#define FONT_SIZE 0.52f
struct GUIFont { struct GUIFont {
C3D_Tex* sheets; C3D_Tex* sheets;
C3D_Tex icons; C3D_Tex icons;
float size;
}; };
struct GUIFont* GUIFontCreate(void) { struct GUIFont* GUIFontCreate(void) {
@ -29,6 +28,7 @@ struct GUIFont* GUIFontCreate(void) {
C3D_Tex* tex; C3D_Tex* tex;
TGLP_s* glyphInfo = fontGetGlyphInfo(); TGLP_s* glyphInfo = fontGetGlyphInfo();
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;
@ -59,16 +59,14 @@ void GUIFontDestroy(struct GUIFont* font) {
} }
unsigned GUIFontHeight(const struct GUIFont* font) { unsigned GUIFontHeight(const struct GUIFont* font) {
UNUSED(font); return fontGetInfo()->lineFeed * font->size;
return fontGetInfo()->lineFeed * FONT_SIZE;
} }
unsigned GUIFontGlyphWidth(const struct GUIFont* font, uint32_t glyph) { unsigned GUIFontGlyphWidth(const struct GUIFont* font, uint32_t glyph) {
UNUSED(font);
int index = fontGlyphIndexFromCodePoint(glyph); int index = fontGlyphIndexFromCodePoint(glyph);
charWidthInfo_s* info = fontGetCharWidthInfo(index); charWidthInfo_s* info = fontGetCharWidthInfo(index);
if (info) { if (info) {
return info->charWidth * FONT_SIZE; return info->charWidth * font->size;
} }
return 0; return 0;
} }
@ -108,7 +106,7 @@ void GUIFontDrawGlyph(const struct GUIFont* font, int glyph_x, int glyph_y, uint
u16 v = tex->height * data.texcoord.bottom; u16 v = tex->height * data.texcoord.bottom;
ctrAddRectEx(color, x, y, ctrAddRectEx(color, x, y,
tex->width * width * FONT_SIZE, tex->height * height * -FONT_SIZE, tex->width * width * font->size, tex->height * height * -font->size,
u, v, tex->width * width, tex->height * height, 0); u, v, tex->width * width, tex->height * height, 0);
} }