textscreen: Allow any widget in action area.

It may be desirable to wrap a window action in a txt_conditional_t
sometimes so that actions dynamically appear based on how the config
changes. So change the TXT_SetWindowAction() API to accept any widget
instead of mandating a txt_window_action_t.
This commit is contained in:
Simon Howard 2018-10-21 17:40:18 -04:00
parent 74cdbeddf5
commit 8c43337af2
2 changed files with 18 additions and 11 deletions

View file

@ -35,8 +35,10 @@
void TXT_SetWindowAction(txt_window_t *window,
txt_horiz_align_t position,
txt_window_action_t *action)
TXT_UNCAST_ARG(action))
{
TXT_CAST_ARG(txt_widget_t, action);
if (window->actions[position] != NULL)
{
TXT_DestroyWidget(window->actions[position]);
@ -48,7 +50,7 @@ void TXT_SetWindowAction(txt_window_t *window,
if (action != NULL)
{
action->widget.parent = &window->table.widget;
action->parent = &window->table.widget;
}
}
@ -82,7 +84,9 @@ txt_window_t *TXT_NewWindow(const char *title)
TXT_AddWidget(win, TXT_NewSeparator(NULL));
for (i=0; i<3; ++i)
{
win->actions[i] = NULL;
}
TXT_AddDesktopWindow(win);
@ -164,7 +168,7 @@ static void LayoutActionArea(txt_window_t *window)
if (window->actions[TXT_HORIZ_LEFT] != NULL)
{
widget = (txt_widget_t *) window->actions[TXT_HORIZ_LEFT];
widget = window->actions[TXT_HORIZ_LEFT];
TXT_CalcWidgetSize(widget);
@ -172,16 +176,17 @@ static void LayoutActionArea(txt_window_t *window)
widget->y = window->window_y + window->window_h - widget->h - 1;
// Adjust available space:
space_available -= widget->w;
space_left_offset += widget->w;
TXT_LayoutWidget(widget);
}
// Draw the right action
if (window->actions[TXT_HORIZ_RIGHT] != NULL)
{
widget = (txt_widget_t *) window->actions[TXT_HORIZ_RIGHT];
widget = window->actions[TXT_HORIZ_RIGHT];
TXT_CalcWidgetSize(widget);
@ -189,25 +194,27 @@ static void LayoutActionArea(txt_window_t *window)
widget->y = window->window_y + window->window_h - widget->h - 1;
// Adjust available space:
space_available -= widget->w;
TXT_LayoutWidget(widget);
}
// Draw the center action
if (window->actions[TXT_HORIZ_CENTER] != NULL)
{
widget = (txt_widget_t *) window->actions[TXT_HORIZ_CENTER];
widget = window->actions[TXT_HORIZ_CENTER];
TXT_CalcWidgetSize(widget);
// The left and right widgets have left a space sandwiched between
// them. Center this widget within that space.
widget->x = window->window_x
+ space_left_offset
+ (space_available - widget->w) / 2;
widget->y = window->window_y + window->window_h - widget->h - 1;
TXT_LayoutWidget(widget);
}
}
@ -417,7 +424,7 @@ static int MouseButtonPress(txt_window_t *window, int b)
for (i=0; i<3; ++i)
{
widget = (txt_widget_t *) window->actions[i];
widget = window->actions[i];
if (widget != NULL
&& x >= widget->x && x < (signed) (widget->x + widget->w)

View file

@ -72,7 +72,7 @@ struct txt_window_s
// Actions that appear in the box at the bottom of the window
txt_window_action_t *actions[3];
txt_widget_t *actions[3];
// Callback functions to invoke when keys/mouse buttons are pressed
@ -159,7 +159,7 @@ void TXT_SetWindowPosition(txt_window_t *window,
*/
void TXT_SetWindowAction(txt_window_t *window, txt_horiz_align_t position,
txt_window_action_t *action);
TXT_UNCAST_ARG(action));
/**
* Set a callback function to be invoked whenever a key is pressed within