diff options
Diffstat (limited to 'textscreen')
-rw-r--r-- | textscreen/txt_table.c | 2 | ||||
-rw-r--r-- | textscreen/txt_table.h | 2 | ||||
-rw-r--r-- | textscreen/txt_window.c | 147 | ||||
-rw-r--r-- | textscreen/txt_window.h | 15 |
4 files changed, 18 insertions, 148 deletions
diff --git a/textscreen/txt_table.c b/textscreen/txt_table.c index a23faeaf..f712b8ba 100644 --- a/textscreen/txt_table.c +++ b/textscreen/txt_table.c @@ -174,7 +174,7 @@ static void TXT_TableDrawer(txt_widget_t *widget, int w, int selected) free(column_widths); } -void TXT_AddTableWidget(void *uncast_table, void *uncast_widget) +void TXT_AddWidget(void *uncast_table, void *uncast_widget) { txt_widget_t *widget; txt_table_t *table; diff --git a/textscreen/txt_table.h b/textscreen/txt_table.h index 75582878..1610b3fd 100644 --- a/textscreen/txt_table.h +++ b/textscreen/txt_table.h @@ -51,7 +51,7 @@ struct txt_table_s txt_table_t *TXT_NewTable(int columns); void TXT_InitTable(txt_table_t *table, int columns); -void TXT_AddTableWidget(void *table, void *widget); +void TXT_AddWidget(void *table, void *widget); #endif /* #ifndef TXT_TABLE_T */ diff --git a/textscreen/txt_window.c b/textscreen/txt_window.c index fb08162e..f993a84e 100644 --- a/textscreen/txt_window.c +++ b/textscreen/txt_window.c @@ -39,15 +39,15 @@ txt_window_t *TXT_NewWindow(char *title) win = malloc(sizeof(txt_window_t)); + TXT_InitTable(&win->table, 1); + win->title = strdup(title); win->x = TXT_SCREEN_W / 2; win->y = TXT_SCREEN_H / 2; win->horiz_align = TXT_HORIZ_CENTER; win->vert_align = TXT_VERT_CENTER; - win->widgets = NULL; - win->num_widgets = 0; - win->selected = 0; + TXT_AddWidget(win, TXT_NewSeparator(NULL)); TXT_AddDesktopWindow(win); return win; @@ -55,52 +55,15 @@ txt_window_t *TXT_NewWindow(char *title) void TXT_CloseWindow(txt_window_t *window) { - int i; + free(window->title); - // Free all widgets + // Destroy table and window - for (i=0; i<window->num_widgets; ++i) - { - TXT_DestroyWidget(window->widgets[i]); - } + TXT_DestroyWidget((txt_widget_t *) window); - // Free window resources - - free(window->widgets); - free(window->title); - free(window); - TXT_RemoveDesktopWindow(window); } -static void CalcWindowSize(txt_window_t *window, int *w, int *h) -{ - txt_widget_t *widget; - int max_width; - int height; - int i; - int ww, wh; - - max_width = 10; - height = 0; - - for (i=0; i<window->num_widgets; ++i) - { - TXT_CalcWidgetSize(window->widgets[i], &ww, &wh); - - if (ww > max_width) - max_width = ww; - - if (window->widgets[i]->visible) - { - height += wh; - } - } - - *w = max_width; - *h = height; -} - static void CalcWindowPosition(txt_window_t *window, int *x, int *y, int w, int h) @@ -141,7 +104,7 @@ void TXT_DrawWindow(txt_window_t *window) int i; int ww, wh; - CalcWindowSize(window, &widgets_w, &widgets_h); + TXT_CalcWidgetSize((txt_widget_t *) window, &widgets_w, &widgets_h); // Actual window size after padding @@ -159,56 +122,12 @@ void TXT_DrawWindow(txt_window_t *window) // Draw all widgets - x = window_x + 1; - y = window_y + 2; - - for (i=0; i<window->num_widgets; ++i) - { - if (window->widgets[i]->visible) - { - TXT_GotoXY(x, y); - TXT_DrawWidget(window->widgets[i], - widgets_w, - i == window->selected); - TXT_CalcWidgetSize(window->widgets[i], &ww, &wh); - y += wh; - } - } + TXT_GotoXY(window_x + 1, window_y + 2); + TXT_DrawWidget((txt_widget_t *) window, widgets_w, 1); // Separator for action area - TXT_DrawSeparator(window_x, y, window_w); -} - -void TXT_AddWidget(txt_window_t *window, void *uncast_widget) -{ - txt_widget_t *widget; - - widget = (txt_widget_t *) uncast_widget; - - if (window->num_widgets == 0) - { - // This is the first widget added. - // - // The first widget in a window should always be a separator. - // If we are not adding a separator now, add one in first. - - if (widget->widget_class != &txt_separator_class) - { - txt_separator_t *separator; - - separator = TXT_NewSeparator(NULL); - - window->widgets = malloc(sizeof(txt_widget_t *)); - window->widgets[0] = &separator->widget; - window->num_widgets = 1; - } - } - - window->widgets = realloc(window->widgets, - sizeof(txt_widget_t *) * (window->num_widgets + 1)); - window->widgets[window->num_widgets] = widget; - ++window->num_widgets; + TXT_DrawSeparator(window_x, window_y + 2 + widgets_h, window_w); } void TXT_SetWindowPosition(txt_window_t *window, @@ -226,50 +145,6 @@ void TXT_WindowKeyPress(txt_window_t *window, int c) { // Send to the currently selected widget first - if (window->selected > 0 && window->selected <= window->num_widgets) - { - if (TXT_WidgetKeyPress(window->widgets[window->selected], c)) - { - return; - } - } - - if (c == KEY_DOWNARROW) - { - int newsel; - - // Move cursor down to the next selectable widget - - for (newsel = window->selected + 1; - newsel < window->num_widgets; - ++newsel) - { - if (window->widgets[newsel]->visible - && window->widgets[newsel]->selectable) - { - window->selected = newsel; - break; - } - } - } - - if (c == KEY_UPARROW) - { - int newsel; - - // Move cursor down to the next selectable widget - - for (newsel = window->selected - 1; - newsel >= 0; - --newsel) - { - if (window->widgets[newsel]->visible - && window->widgets[newsel]->selectable) - { - window->selected = newsel; - break; - } - } - } + TXT_WidgetKeyPress((txt_widget_t *) window, c); } diff --git a/textscreen/txt_window.h b/textscreen/txt_window.h index 5dc799c7..0afe81aa 100644 --- a/textscreen/txt_window.h +++ b/textscreen/txt_window.h @@ -42,9 +42,14 @@ typedef enum } txt_horiz_align_t; #include "txt_widget.h" +#include "txt_table.h" struct txt_window_s { + // Base class: all windows are tables with one column. + + txt_table_t table; + // Window title char *title; @@ -54,20 +59,10 @@ struct txt_window_s txt_vert_align_t vert_align; txt_horiz_align_t horiz_align; int x, y; - - // Widgets in this window - - txt_widget_t **widgets; - int num_widgets; - - // Index of the current selected widget. - - int selected; }; txt_window_t *TXT_NewWindow(char *title); void TXT_CloseWindow(txt_window_t *window); -void TXT_AddWidget(txt_window_t *window, void *widget); void TXT_SetWindowPosition(txt_window_t *window, txt_horiz_align_t horiz_align, txt_vert_align_t vert_align, |