From 878f56837d56b2cf6bf4fb25418b8da756d998de Mon Sep 17 00:00:00 2001 From: oliverschmidt <oliverschmidt> Date: Thu, 20 Dec 2007 20:45:06 +0000 Subject: [PATCH] Did more aggressive fullscreen ctk codesize optimization. Now ctk draw implementations need adjustment as the struct window member x and y are gone. Another potential optimization would be to remove clipping... --- core/ctk/ctk-conio.c | 28 +++++++++++++++++++++++----- core/ctk/ctk.c | 7 ++----- core/ctk/ctk.h | 7 +------ 3 files changed, 26 insertions(+), 16 deletions(-) diff --git a/core/ctk/ctk-conio.c b/core/ctk/ctk-conio.c index 1de112d99..ef255d0d9 100644 --- a/core/ctk/ctk-conio.c +++ b/core/ctk/ctk-conio.c @@ -29,7 +29,7 @@ * * This file is part of the "ctk" console GUI toolkit for cc65 * - * $Id: ctk-conio.c,v 1.10 2007/12/16 13:00:51 oliverschmidt Exp $ + * $Id: ctk-conio.c,v 1.11 2007/12/20 20:45:06 oliverschmidt Exp $ * */ @@ -240,8 +240,13 @@ ctk_draw_widget(struct ctk_widget *w, unsigned char focus, struct ctk_window *win = w->window; unsigned char posx, posy; +#if CTK_CONF_WINDOWS posx = win->x + 1; posy = win->y + 1 + CTK_CONF_MENUS; +#else /* CTK_CONF_WINDOWS */ + posx = 0; + posy = 0; +#endif /* CTK_CONF_WINDOWS */ if(w == win->focused) { focus |= CTK_FOCUS_WIDGET; @@ -259,7 +264,9 @@ ctk_draw_clear_window(struct ctk_window *window, unsigned char focus, unsigned char clipy1, unsigned char clipy2) { unsigned char i; +#if CTK_CONF_WINDOWS unsigned char h; +#endif /* CTK_CONF_WINDOWS */ if(focus & CTK_FOCUS_WINDOW) { (void)textcolor(WINDOWCOLOR_FOCUS); @@ -267,6 +274,7 @@ ctk_draw_clear_window(struct ctk_window *window, unsigned char focus, (void)textcolor(WINDOWCOLOR); } +#if CTK_CONF_WINDOWS h = window->y + 1 + CTK_CONF_MENUS + window->h; /* Clear window contents. */ @@ -275,6 +283,13 @@ ctk_draw_clear_window(struct ctk_window *window, unsigned char focus, cclearxy(window->x + 1, i, window->w); } } +#else /* CTK_CONF_WINDOWS */ + for(i = 0; i < window->h; ++i) { + if(i >= clipy1 && i < clipy2) { + cclearxy(0, i, window->w); + } + } +#endif /* CTK_CONF_WINDOWS */ } /*-----------------------------------------------------------------------------------*/ static void @@ -311,11 +326,10 @@ ctk_draw_window(struct ctk_window *window, unsigned char focus, unsigned char clipy1, unsigned char clipy2, unsigned char draw_borders) { +#if CTK_CONF_WINDOWS unsigned char x, y; unsigned char x1, y1, x2, y2; -#if CTK_CONF_WINDOWS unsigned char h; -#endif /* CTK_CONF_WINDOWS */ if(window->y + CTK_CONF_MENUS >= clipy2) { return; @@ -328,7 +342,6 @@ ctk_draw_window(struct ctk_window *window, unsigned char focus, x2 = x1 + window->w; y2 = y1 + window->h; -#if CTK_CONF_WINDOWS if(draw_borders) { /* Draw window frame. */ @@ -373,9 +386,14 @@ ctk_draw_window(struct ctk_window *window, unsigned char focus, cputcxy(x2, y2, (char)CH_LRCORNER); } } -#endif /* CTK_CONF_WINDOWS */ draw_window_contents(window, focus, clipy1, clipy2, x1, x2, y + 1, y2); + +#else /* CTK_CONF_WINDOWS */ + + draw_window_contents(window, focus, clipy1, clipy2, 0, window->w, 0, window->h); + +#endif /* CTK_CONF_WINDOWS */ } /*-----------------------------------------------------------------------------------*/ #if CTK_CONF_WINDOWS diff --git a/core/ctk/ctk.c b/core/ctk/ctk.c index 1fcd8a3e2..07e13303f 100644 --- a/core/ctk/ctk.c +++ b/core/ctk/ctk.c @@ -44,7 +44,7 @@ * * This file is part of the Contiki operating system. * - * $Id: ctk.c,v 1.17 2007/12/15 21:29:46 oliverschmidt Exp $ + * $Id: ctk.c,v 1.18 2007/12/20 20:45:06 oliverschmidt Exp $ * */ @@ -688,9 +688,6 @@ window_new(CC_REGISTER_ARG struct ctk_window *window, } else { window->y = (height - h - 2 - ctk_draw_windowtitle_height) / 2; } -#else /* CTK_CONF_WINDOWS */ - window->x = -1; - window->y = -1; #endif /* CTK_CONF_WINDOWS */ window->w = w; @@ -1613,13 +1610,13 @@ PROCESS_THREAD(ctk_process, ev, data) ctk_window_open(window); redraw |= REDRAW_ALL; } else { -#endif /* CTK_CONF_WINDOWS */ /* Find out which widget currently is under the mouse pointer and give it focus, unless it already has focus. */ mxc = mxc - window->x - ctk_draw_windowborder_width; myc = myc - window->y - ctk_draw_windowtitle_height; +#endif /* CTK_CONF_WINDOWS */ /* See if the mouse pointer is on a widget. If so, it should be selected and, if the button is clicked, diff --git a/core/ctk/ctk.h b/core/ctk/ctk.h index 38151844a..65175d9fb 100644 --- a/core/ctk/ctk.h +++ b/core/ctk/ctk.h @@ -43,7 +43,7 @@ * * This file is part of the Contiki desktop OS. * - * $Id: ctk.h,v 1.4 2007/12/14 23:34:19 oliverschmidt Exp $ + * $Id: ctk.h,v 1.5 2007/12/20 20:45:06 oliverschmidt Exp $ * */ @@ -528,11 +528,6 @@ struct ctk_window { characters. */ y; /**< The y coordinate of the window, in characters. */ -#else /* CTK_CONF_WINDOWS */ - signed char x, /**< The x coordinate of the window, in - characters. */ - y; /**< The y coordinate of the window, in - characters. */ #endif /* CTK_CONF_WINDOWS */ unsigned char w, /**< The width of the window, excluding window borders. */