diff options
-rw-r--r-- | textscreen/txt_desktop.c | 2 | ||||
-rw-r--r-- | textscreen/txt_gui.c | 75 | ||||
-rw-r--r-- | textscreen/txt_gui.h | 4 |
3 files changed, 78 insertions, 3 deletions
diff --git a/textscreen/txt_desktop.c b/textscreen/txt_desktop.c index 78c9944e..b17f1514 100644 --- a/textscreen/txt_desktop.c +++ b/textscreen/txt_desktop.c @@ -118,6 +118,8 @@ void TXT_DrawDesktop(void) int i; char *title; + TXT_InitClipArea(); + if (desktop_title == NULL) title = ""; else diff --git a/textscreen/txt_gui.c b/textscreen/txt_gui.c index f860e87a..33c29ad7 100644 --- a/textscreen/txt_gui.c +++ b/textscreen/txt_gui.c @@ -25,6 +25,15 @@ #include "txt_io.h" #include "txt_main.h" +typedef struct txt_cliparea_s txt_cliparea_t; + +struct txt_cliparea_s +{ + int x1, x2; + int y1, y2; + txt_cliparea_t *next; +}; + // Array of border characters for drawing windows. The array looks like this: // // +-++ @@ -32,7 +41,7 @@ // +-++ // +-++ -static int borders[4][4] = +static const int borders[4][4] = { {0xda, 0xc4, 0xc2, 0xbf}, {0xb3, ' ', 0xb3, 0xb3}, @@ -40,8 +49,10 @@ static int borders[4][4] = {0xc0, 0xc4, 0xc1, 0xd9}, }; -#define VALID_X(y) ((y) >= 0 && (y) < TXT_SCREEN_W) -#define VALID_Y(y) ((y) >= 1 && (y) < TXT_SCREEN_H - 1) +static txt_cliparea_t *cliparea = NULL; + +#define VALID_X(x) ((x) >= cliparea->x1 && (x) < cliparea->x2) +#define VALID_Y(y) ((y) >= cliparea->y1 && (y) < cliparea->y2) void TXT_DrawDesktopBackground(char *title) { @@ -240,3 +251,61 @@ void TXT_DrawString(char *s) TXT_GotoXY(x + strlen(s), y); } +void TXT_InitClipArea(void) +{ + if (cliparea == NULL) + { + cliparea = malloc(sizeof(txt_cliparea_t)); + cliparea->x1 = 0; + cliparea->x2 = TXT_SCREEN_W; + cliparea->y1 = 1; + cliparea->y2 = TXT_SCREEN_H - 1; + cliparea->next = NULL; + } +} + +void TXT_PushClipArea(int x1, int x2, int y1, int y2) +{ + txt_cliparea_t *newarea; + + newarea = malloc(sizeof(txt_cliparea_t)); + + // Set the new clip area to the intersection of the old + // area and the new one. + + newarea->x1 = cliparea->x1; + newarea->x2 = cliparea->x2; + newarea->y1 = cliparea->y1; + newarea->y2 = cliparea->y2; + + if (x1 > newarea->x1) + newarea->x1 = x1; + if (x2 < newarea->x2) + newarea->x2 = x2; + if (y1 > newarea->x1) + newarea->y1 = y1; + if (y2 < newarea->y2) + newarea->y2 = y2; + + // Hook into the list + + newarea->next = cliparea; + cliparea = newarea; +} + +void TXT_PopClipArea(void) +{ + txt_cliparea_t *next_cliparea; + + // Never pop the last entry + + if (cliparea->next == NULL) + return; + + // Unlink the last entry and delete + + next_cliparea = cliparea->next; + free(cliparea); + cliparea = next_cliparea; +} + diff --git a/textscreen/txt_gui.h b/textscreen/txt_gui.h index 65c97c66..5c120f6c 100644 --- a/textscreen/txt_gui.h +++ b/textscreen/txt_gui.h @@ -32,5 +32,9 @@ void TXT_DrawWindowFrame(char *title, int x, int y, int w, int h); void TXT_DrawSeparator(int x, int y, int w); void TXT_DrawString(char *s); +void TXT_InitClipArea(void); +void TXT_PushClipArea(int x1, int x2, int y1, int y2); +void TXT_PopClipArea(void); + #endif /* #ifndef TXT_GUI_H */ |