aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorThomas Saunders <trsaunders@gmail.com>2012-06-23 23:04:35 +0100
committerThomas Saunders <trsaunders@gmail.com>2012-06-23 23:04:35 +0100
commit23a3bf0efa969cf8f3443c6b148fa7f2b6cd74af (patch)
tree0269cb9898f26ab00f5aa143310d860989323152
parent5c7d3819be53ede62bffccaadc70ee5fc0734d5c (diff)
downloaduGFX-23a3bf0efa969cf8f3443c6b148fa7f2b6cd74af.tar.gz
uGFX-23a3bf0efa969cf8f3443c6b148fa7f2b6cd74af.tar.bz2
uGFX-23a3bf0efa969cf8f3443c6b148fa7f2b6cd74af.zip
clear the end of lines when shifting down
-rw-r--r--console.c26
-rw-r--r--console.h9
2 files changed, 14 insertions, 21 deletions
diff --git a/console.c b/console.c
index 4e21a795..96793bad 100644
--- a/console.c
+++ b/console.c
@@ -78,13 +78,9 @@ msg_t lcdConsoleInit(GLCDConsole *console, uint16_t x0, uint16_t y0, uint16_t x1
uint16_t x,y;
console->vmt = &vmt;
- /* read font, get size */
- /* TODO: this is messy. improve font handling.
- * this assumes that all characters are as wide as A */
+ /* read font, get height */
console->fy = font[FONT_TABLE_HEIGHT_IDX];
- chi = *(uint16_t*)(&font[FONT_TABLE_CHAR_LOOKUP_IDX + ('A'-0x20)*2]);
- ptr = font + chi;
- console->fx = *(ptr++);
+
/* calculate the size of the console in characters */
console->sx = (x1-x0);
@@ -104,7 +100,6 @@ msg_t lcdConsoleInit(GLCDConsole *console, uint16_t x0, uint16_t y0, uint16_t x1
console->color = color;
console->font = font;
- console->full = FALSE;
}
msg_t lcdConsoleUpdate(GLCDConsole *console) {
@@ -112,15 +107,11 @@ msg_t lcdConsoleUpdate(GLCDConsole *console) {
}
msg_t lcdConsolePut(GLCDConsole *console, char c) {
- uint8_t width = console->fx;
uint16_t i;
uint16_t s = console->wptr;
+ uint8_t width;
bool_t redraw = FALSE;
- if(console->full) {
- return RDY_RESET;
- }
-
/* write character to current position in buffer and update wptr */
console->buf[console->wptr] = c;
@@ -137,22 +128,25 @@ msg_t lcdConsolePut(GLCDConsole *console, char c) {
* checks to see if this is out of range will be performed at the start of that character
*/
do {
+ width = lcdMeasureChar(console->buf[s]);
if(console->buf[s] == '\n') {
+ /* clear the text at the end of the line */
+ if(console->cx < console->sx)
+ lcdDrawRect(console->cx, console->cy, console->sx, console->cy + console->fy,
+ 1, console->bkcolor);
console->cx = 0;
console->cy += console->fy;
} else if(console->buf[s] == '\r') {
/* TODO: work backwards through the buffer to the start of the current line */
//console->cx = 0;
} else {
- if(console->cx >= console->sx) {
+ if((console->cx + width) >= console->sx) {
console->cx = 0;
console->cy += console->fy;
}
if((console->cy + console->fy) >= console->sy) {
/* we've gone beyond the end of the console */
- //console->full = TRUE;
- //return RDY_RESET;
/* start at beginning of buffer and remove the first line */
/* increment s from bstrt until it has been incremented more than
@@ -164,7 +158,7 @@ msg_t lcdConsolePut(GLCDConsole *console, char c) {
s++;
/* TODO: increment based on the width of the character at s */
/* TODO: this doesn't handle carriage return */
- console->cx += width;
+ console->cx += lcdMeasureChar(console->buf[s % console->blen]);
}
/* update bstrt to the new start point of the console */
diff --git a/console.h b/console.h
index 10e061ff..13b77605 100644
--- a/console.h
+++ b/console.h
@@ -38,18 +38,17 @@ struct GLCDConsole {
/* font */
const uint8_t *font;
/* lcd area to use */
- uint16_t x0,y0,x1,y1;
- /* current cursor position, in character coordinates (not pixels) */
+ uint16_t x0,y0;
+ /* current cursor position, in pixels */
uint16_t cx,cy;
- /* console size in characters */
+ /* console size in pixels */
uint16_t sx,sy;
/* foreground and background colour */
uint16_t bkcolor, color;
/* font size in pixels */
- uint8_t fx,fy;
+ uint8_t fy;
/* buffer index */
uint16_t wptr, blen, bstrt;
- bool_t full;
};
#ifdef __cplusplus