lcd/render.c: save 56 bytes
Introduce a utility function that reads a single byte from the current position in the font file.
This commit is contained in:
parent
81294835ec
commit
ad0c993136
|
@ -8,6 +8,7 @@
|
||||||
#include "fonts/smallfonts.h"
|
#include "fonts/smallfonts.h"
|
||||||
|
|
||||||
#include "filesystem/ff.h"
|
#include "filesystem/ff.h"
|
||||||
|
#include "render.h"
|
||||||
|
|
||||||
/* Global Variables */
|
/* Global Variables */
|
||||||
const struct FONT_DEF * font = NULL;
|
const struct FONT_DEF * font = NULL;
|
||||||
|
@ -36,10 +37,17 @@ void setExtFont(const char *fname){
|
||||||
|
|
||||||
int getFontHeight(void){
|
int getFontHeight(void){
|
||||||
if(font)
|
if(font)
|
||||||
return font->u8Height;
|
return font->u8Height;
|
||||||
return 8; // XXX: Should be done right.
|
return 8; // XXX: Should be done right.
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static uint8_t read_byte (void)
|
||||||
|
{
|
||||||
|
UINT readbytes;
|
||||||
|
uint8_t byte;
|
||||||
|
f_read(&file, &byte, sizeof(uint8_t), &readbytes);
|
||||||
|
return byte;
|
||||||
|
}
|
||||||
|
|
||||||
int _getFontData(int type, int offset){
|
int _getFontData(int type, int offset){
|
||||||
UINT readbytes;
|
UINT readbytes;
|
||||||
|
@ -51,10 +59,10 @@ int _getFontData(int type, int offset){
|
||||||
if(efont.type == FONT_EXTERNAL){
|
if(efont.type == FONT_EXTERNAL){
|
||||||
|
|
||||||
if (type == START_FONT){
|
if (type == START_FONT){
|
||||||
res = f_read(&file, &efont.def.u8Width, sizeof(uint8_t), &readbytes);
|
efont.def.u8Width = read_byte ();
|
||||||
res = f_read(&file, &efont.def.u8Height, sizeof(uint8_t), &readbytes);
|
efont.def.u8Height = read_byte ();
|
||||||
res = f_read(&file, &efont.def.u8FirstChar, sizeof(uint8_t), &readbytes);
|
efont.def.u8FirstChar = read_byte ();
|
||||||
res = f_read(&file, &efont.def.u8LastChar, sizeof(uint8_t), &readbytes);
|
efont.def.u8LastChar = read_byte ();
|
||||||
res = f_read(&file, &extras, sizeof(uint16_t), &readbytes);
|
res = f_read(&file, &extras, sizeof(uint16_t), &readbytes);
|
||||||
return 0;
|
return 0;
|
||||||
};
|
};
|
||||||
|
@ -72,9 +80,7 @@ int _getFontData(int type, int offset){
|
||||||
return 0;
|
return 0;
|
||||||
};
|
};
|
||||||
if(type == GET_WIDTH || type == GET_DATA){
|
if(type == GET_WIDTH || type == GET_DATA){
|
||||||
uint8_t width;
|
return read_byte ();
|
||||||
res = f_read(&file, &width, sizeof(uint8_t), &readbytes);
|
|
||||||
return width;
|
|
||||||
};
|
};
|
||||||
if(type == SEEK_DATA){
|
if(type == SEEK_DATA){
|
||||||
character=offset;
|
character=offset;
|
||||||
|
@ -87,7 +93,7 @@ int _getFontData(int type, int offset){
|
||||||
};
|
};
|
||||||
if(type == PEEK_DATA){
|
if(type == PEEK_DATA){
|
||||||
uint8_t width;
|
uint8_t width;
|
||||||
res = f_read(&file, &width, sizeof(uint8_t), &readbytes);
|
width = read_byte ();
|
||||||
f_lseek(&file,6+
|
f_lseek(&file,6+
|
||||||
(extras*sizeof(uint16_t))+
|
(extras*sizeof(uint16_t))+
|
||||||
((extras+font->u8LastChar-font->u8FirstChar)*sizeof(uint8_t))+
|
((extras+font->u8LastChar-font->u8FirstChar)*sizeof(uint8_t))+
|
||||||
|
@ -240,10 +246,10 @@ int DoChar(int sx, int sy, int c){
|
||||||
UINT res;
|
UINT res;
|
||||||
UINT readbytes;
|
UINT readbytes;
|
||||||
uint8_t testbyte;
|
uint8_t testbyte;
|
||||||
res = f_read(&file, &testbyte, sizeof(uint8_t), &readbytes);
|
testbyte = read_byte ();
|
||||||
if(testbyte>>4 ==15){
|
if(testbyte>>4 ==15){
|
||||||
res = f_read(&file, &preblank, sizeof(uint8_t), &readbytes);
|
preblank = read_byte ();
|
||||||
res = f_read(&file, &postblank, sizeof(uint8_t), &readbytes);
|
postblank = read_byte ();
|
||||||
width-=3;
|
width-=3;
|
||||||
width/=height;
|
width/=height;
|
||||||
res = f_read(&file, charBuf, width*height, &readbytes);
|
res = f_read(&file, charBuf, width*height, &readbytes);
|
||||||
|
|
Loading…
Reference in New Issue