mirror of
https://github.com/MidnightCommander/mc
synced 2025-01-18 17:29:28 +03:00
Refactoring of widget drawing to avoid multiple widget redraw.
Send MSG_DRAW message immediately after MSG_FOCUS/MSG_UNFOCUS. Thus, the MSG_DRAW message handler is the only place where widget should be drawn. Widget should not draw itself in other message handlers. Signed-off-by: Andrew Borodin <aborodin@vmail.ru>
This commit is contained in:
parent
aae31dbe43
commit
240350db95
@ -117,8 +117,6 @@ button_callback (Widget * w, Widget * sender, widget_msg_t msg, int parm, void *
|
|||||||
widget_move (w, 0, b->hotpos + off);
|
widget_move (w, 0, b->hotpos + off);
|
||||||
return MSG_HANDLED;
|
return MSG_HANDLED;
|
||||||
|
|
||||||
case MSG_UNFOCUS:
|
|
||||||
case MSG_FOCUS:
|
|
||||||
case MSG_DRAW:
|
case MSG_DRAW:
|
||||||
{
|
{
|
||||||
gboolean focused;
|
gboolean focused;
|
||||||
|
@ -83,14 +83,17 @@ check_callback (Widget * w, Widget * sender, widget_msg_t msg, int parm, void *d
|
|||||||
widget_move (w, 0, 1);
|
widget_move (w, 0, 1);
|
||||||
return MSG_HANDLED;
|
return MSG_HANDLED;
|
||||||
|
|
||||||
case MSG_FOCUS:
|
|
||||||
case MSG_UNFOCUS:
|
|
||||||
case MSG_DRAW:
|
case MSG_DRAW:
|
||||||
widget_selectcolor (w, msg == MSG_FOCUS, FALSE);
|
{
|
||||||
|
gboolean focused;
|
||||||
|
|
||||||
|
focused = widget_get_state (w, WST_FOCUSED);
|
||||||
|
widget_selectcolor (w, focused, FALSE);
|
||||||
widget_move (w, 0, 0);
|
widget_move (w, 0, 0);
|
||||||
tty_print_string ((c->state & C_BOOL) ? "[x] " : "[ ] ");
|
tty_print_string ((c->state & C_BOOL) ? "[x] " : "[ ] ");
|
||||||
hotkey_draw (w, c->text, msg == MSG_FOCUS);
|
hotkey_draw (w, c->text, focused);
|
||||||
return MSG_HANDLED;
|
return MSG_HANDLED;
|
||||||
|
}
|
||||||
|
|
||||||
case MSG_DESTROY:
|
case MSG_DESTROY:
|
||||||
release_hotkey (c->text);
|
release_hotkey (c->text);
|
||||||
|
@ -277,11 +277,8 @@ do_select_widget (WDialog * h, GList * w, select_dir_t dir)
|
|||||||
dlg_reorder_widgets (h->current, TRUE);
|
dlg_reorder_widgets (h->current, TRUE);
|
||||||
|
|
||||||
if (widget_overlapped (w0, WIDGET (h->current->data)))
|
if (widget_overlapped (w0, WIDGET (h->current->data)))
|
||||||
{
|
|
||||||
send_message (h->current->data, NULL, MSG_DRAW, 0, NULL);
|
|
||||||
widget_set_state (WIDGET (h->current->data), WST_FOCUSED, TRUE);
|
widget_set_state (WIDGET (h->current->data), WST_FOCUSED, TRUE);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
/* --------------------------------------------------------------------------------------------- */
|
/* --------------------------------------------------------------------------------------------- */
|
||||||
|
|
||||||
@ -966,7 +963,6 @@ add_widget_autopos (WDialog * h, void *w, widget_pos_flags_t pos_flags, const vo
|
|||||||
if (widget_get_state (wh, WST_ACTIVE))
|
if (widget_get_state (wh, WST_ACTIVE))
|
||||||
{
|
{
|
||||||
send_message (widget, NULL, MSG_INIT, 0, NULL);
|
send_message (widget, NULL, MSG_INIT, 0, NULL);
|
||||||
send_message (widget, NULL, MSG_DRAW, 0, NULL);
|
|
||||||
widget_set_state (widget, WST_FOCUSED, TRUE);
|
widget_set_state (widget, WST_FOCUSED, TRUE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1079,8 +1079,6 @@ input_callback (Widget * w, Widget * sender, widget_msg_t msg, int parm, void *d
|
|||||||
return input_execute_cmd (in, parm);
|
return input_execute_cmd (in, parm);
|
||||||
|
|
||||||
case MSG_RESIZE:
|
case MSG_RESIZE:
|
||||||
case MSG_FOCUS:
|
|
||||||
case MSG_UNFOCUS:
|
|
||||||
case MSG_DRAW:
|
case MSG_DRAW:
|
||||||
input_update (in, FALSE);
|
input_update (in, FALSE);
|
||||||
return MSG_HANDLED;
|
return MSG_HANDLED;
|
||||||
|
@ -482,8 +482,6 @@ listbox_callback (Widget * w, Widget * sender, widget_msg_t msg, int parm, void
|
|||||||
widget_move (l, l->cursor_y, 0);
|
widget_move (l, l->cursor_y, 0);
|
||||||
return MSG_HANDLED;
|
return MSG_HANDLED;
|
||||||
|
|
||||||
case MSG_FOCUS:
|
|
||||||
case MSG_UNFOCUS:
|
|
||||||
case MSG_DRAW:
|
case MSG_DRAW:
|
||||||
listbox_draw (l, widget_get_state (w, WST_FOCUSED));
|
listbox_draw (l, widget_get_state (w, WST_FOCUSED));
|
||||||
return MSG_HANDLED;
|
return MSG_HANDLED;
|
||||||
|
@ -108,24 +108,27 @@ radio_callback (Widget * w, Widget * sender, widget_msg_t msg, int parm, void *d
|
|||||||
}
|
}
|
||||||
|
|
||||||
case MSG_CURSOR:
|
case MSG_CURSOR:
|
||||||
widget_move (r, r->pos, 1);
|
|
||||||
widget_set_state (w, WST_FOCUSED, TRUE);
|
widget_set_state (w, WST_FOCUSED, TRUE);
|
||||||
|
widget_move (r, r->pos, 1);
|
||||||
return MSG_HANDLED;
|
return MSG_HANDLED;
|
||||||
|
|
||||||
case MSG_UNFOCUS:
|
|
||||||
case MSG_FOCUS:
|
|
||||||
case MSG_DRAW:
|
case MSG_DRAW:
|
||||||
|
{
|
||||||
|
gboolean focused;
|
||||||
|
|
||||||
|
focused = widget_get_state (w, WST_FOCUSED);
|
||||||
|
|
||||||
for (i = 0; i < r->count; i++)
|
for (i = 0; i < r->count; i++)
|
||||||
{
|
{
|
||||||
const gboolean focused = (i == r->pos && msg == MSG_FOCUS);
|
widget_selectcolor (w, i == r->pos && focused, FALSE);
|
||||||
|
widget_move (w, i, 0);
|
||||||
widget_selectcolor (w, focused, FALSE);
|
|
||||||
widget_move (r, i, 0);
|
|
||||||
tty_draw_hline (w->y + i, w->x, ' ', w->cols);
|
tty_draw_hline (w->y + i, w->x, ' ', w->cols);
|
||||||
tty_print_string ((r->sel == i) ? "(*) " : "( ) ");
|
tty_print_string ((r->sel == i) ? "(*) " : "( ) ");
|
||||||
hotkey_draw (w, r->texts[i], focused);
|
hotkey_draw (w, r->texts[i], i == r->pos && focused);
|
||||||
}
|
}
|
||||||
|
|
||||||
return MSG_HANDLED;
|
return MSG_HANDLED;
|
||||||
|
}
|
||||||
|
|
||||||
case MSG_DESTROY:
|
case MSG_DESTROY:
|
||||||
for (i = 0; i < r->count; i++)
|
for (i = 0; i < r->count; i++)
|
||||||
|
@ -245,7 +245,7 @@ widget_set_state (Widget * w, widget_state_t state, gboolean enable)
|
|||||||
{
|
{
|
||||||
case WST_DISABLED:
|
case WST_DISABLED:
|
||||||
ret = send_message (w, NULL, enable ? MSG_DISABLE : MSG_ENABLE, 0, NULL);
|
ret = send_message (w, NULL, enable ? MSG_DISABLE : MSG_ENABLE, 0, NULL);
|
||||||
if (ret == MSG_HANDLED)
|
if (ret == MSG_HANDLED && widget_get_state (WIDGET (w->owner), WST_ACTIVE))
|
||||||
ret = send_message (w, NULL, MSG_DRAW, 0, NULL);
|
ret = send_message (w, NULL, MSG_DRAW, 0, NULL);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -255,8 +255,9 @@ widget_set_state (Widget * w, widget_state_t state, gboolean enable)
|
|||||||
|
|
||||||
msg = enable ? MSG_FOCUS : MSG_UNFOCUS;
|
msg = enable ? MSG_FOCUS : MSG_UNFOCUS;
|
||||||
ret = send_message (w, NULL, msg, 0, NULL);
|
ret = send_message (w, NULL, msg, 0, NULL);
|
||||||
if (ret == MSG_HANDLED)
|
if (ret == MSG_HANDLED && widget_get_state (WIDGET (w->owner), WST_ACTIVE))
|
||||||
{
|
{
|
||||||
|
send_message (w, NULL, MSG_DRAW, 0, NULL);
|
||||||
/* Notify owner that focus was moved from one widget to another */
|
/* Notify owner that focus was moved from one widget to another */
|
||||||
send_message (w->owner, w, MSG_NOTIFY, (int) msg, NULL);
|
send_message (w->owner, w, MSG_NOTIFY, (int) msg, NULL);
|
||||||
}
|
}
|
||||||
|
@ -936,18 +936,13 @@ edit_callback (Widget * w, Widget * sender, widget_msg_t msg, int parm, void *da
|
|||||||
{
|
{
|
||||||
case MSG_FOCUS:
|
case MSG_FOCUS:
|
||||||
edit_set_buttonbar (e, find_buttonbar (w->owner));
|
edit_set_buttonbar (e, find_buttonbar (w->owner));
|
||||||
/* fall through */
|
return MSG_HANDLED;
|
||||||
|
|
||||||
case MSG_DRAW:
|
case MSG_DRAW:
|
||||||
e->force |= REDRAW_COMPLETELY;
|
e->force |= REDRAW_COMPLETELY;
|
||||||
edit_update_screen (e);
|
edit_update_screen (e);
|
||||||
return MSG_HANDLED;
|
return MSG_HANDLED;
|
||||||
|
|
||||||
case MSG_UNFOCUS:
|
|
||||||
/* redraw frame and status */
|
|
||||||
edit_status (e, FALSE);
|
|
||||||
return MSG_HANDLED;
|
|
||||||
|
|
||||||
case MSG_KEY:
|
case MSG_KEY:
|
||||||
{
|
{
|
||||||
int cmd, ch;
|
int cmd, ch;
|
||||||
@ -1296,7 +1291,7 @@ edit_update_screen (WEdit * e)
|
|||||||
|
|
||||||
edit_scroll_screen_over_cursor (e);
|
edit_scroll_screen_over_cursor (e);
|
||||||
edit_update_curs_col (e);
|
edit_update_curs_col (e);
|
||||||
edit_status (e, (void *) e == h->current->data);
|
edit_status (e, widget_get_state (WIDGET (e), WST_FOCUSED));
|
||||||
|
|
||||||
/* pop all events for this window for internal handling */
|
/* pop all events for this window for internal handling */
|
||||||
if (!is_idle ())
|
if (!is_idle ())
|
||||||
@ -1359,6 +1354,7 @@ edit_add_window (WDialog * h, int y, int x, int lines, int cols, const vfs_path_
|
|||||||
w->mouse_callback = edit_mouse_callback;
|
w->mouse_callback = edit_mouse_callback;
|
||||||
|
|
||||||
add_widget (h, w);
|
add_widget (h, w);
|
||||||
|
edit_set_buttonbar (edit, find_buttonbar (h));
|
||||||
dlg_redraw (h);
|
dlg_redraw (h);
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
@ -3683,9 +3683,7 @@ panel_callback (Widget * w, Widget * sender, widget_msg_t msg, int parm, void *d
|
|||||||
|
|
||||||
update_xterm_title_path ();
|
update_xterm_title_path ();
|
||||||
select_item (panel);
|
select_item (panel);
|
||||||
show_dir (panel);
|
|
||||||
paint_dir (panel);
|
paint_dir (panel);
|
||||||
panel->dirty = 0;
|
|
||||||
|
|
||||||
bb = find_buttonbar (w->owner);
|
bb = find_buttonbar (w->owner);
|
||||||
midnight_set_buttonbar (bb);
|
midnight_set_buttonbar (bb);
|
||||||
@ -3696,7 +3694,6 @@ panel_callback (Widget * w, Widget * sender, widget_msg_t msg, int parm, void *d
|
|||||||
/* Janne: look at this for the multiple panel options */
|
/* Janne: look at this for the multiple panel options */
|
||||||
stop_search (panel);
|
stop_search (panel);
|
||||||
panel->active = 0;
|
panel->active = 0;
|
||||||
show_dir (panel);
|
|
||||||
unselect_item (panel);
|
unselect_item (panel);
|
||||||
return MSG_HANDLED;
|
return MSG_HANDLED;
|
||||||
|
|
||||||
|
@ -973,10 +973,15 @@ tree_start_search (WTree * tree)
|
|||||||
static void
|
static void
|
||||||
tree_toggle_navig (WTree * tree)
|
tree_toggle_navig (WTree * tree)
|
||||||
{
|
{
|
||||||
|
WButtonBar *b;
|
||||||
|
|
||||||
tree_navigation_flag = !tree_navigation_flag;
|
tree_navigation_flag = !tree_navigation_flag;
|
||||||
buttonbar_set_label (find_buttonbar (WIDGET (tree)->owner), 4,
|
|
||||||
tree_navigation_flag ? Q_ ("ButtonBar|Static")
|
b = find_buttonbar (WIDGET (tree)->owner);
|
||||||
: Q_ ("ButtonBar|Dynamc"), tree_map, WIDGET (tree));
|
buttonbar_set_label (b, 4,
|
||||||
|
tree_navigation_flag ? Q_ ("ButtonBar|Static") : Q_ ("ButtonBar|Dynamc"),
|
||||||
|
tree_map, WIDGET (tree));
|
||||||
|
widget_redraw (WIDGET (b));
|
||||||
}
|
}
|
||||||
|
|
||||||
/* --------------------------------------------------------------------------------------------- */
|
/* --------------------------------------------------------------------------------------------- */
|
||||||
@ -1145,16 +1150,22 @@ tree_callback (Widget * w, Widget * sender, widget_msg_t msg, int parm, void *da
|
|||||||
{
|
{
|
||||||
WTree *tree = (WTree *) w;
|
WTree *tree = (WTree *) w;
|
||||||
WDialog *h = w->owner;
|
WDialog *h = w->owner;
|
||||||
WButtonBar *b = find_buttonbar (h);
|
WButtonBar *b;
|
||||||
|
|
||||||
switch (msg)
|
switch (msg)
|
||||||
{
|
{
|
||||||
case MSG_DRAW:
|
case MSG_DRAW:
|
||||||
tree_frame (h, tree);
|
tree_frame (h, tree);
|
||||||
show_tree (tree);
|
show_tree (tree);
|
||||||
|
if (widget_get_state (w, WST_FOCUSED))
|
||||||
|
{
|
||||||
|
b = find_buttonbar (h);
|
||||||
|
widget_redraw (WIDGET (b));
|
||||||
|
}
|
||||||
return MSG_HANDLED;
|
return MSG_HANDLED;
|
||||||
|
|
||||||
case MSG_FOCUS:
|
case MSG_FOCUS:
|
||||||
|
b = find_buttonbar (h);
|
||||||
buttonbar_set_label (b, 1, Q_ ("ButtonBar|Help"), tree_map, w);
|
buttonbar_set_label (b, 1, Q_ ("ButtonBar|Help"), tree_map, w);
|
||||||
buttonbar_set_label (b, 2, Q_ ("ButtonBar|Rescan"), tree_map, w);
|
buttonbar_set_label (b, 2, Q_ ("ButtonBar|Rescan"), tree_map, w);
|
||||||
buttonbar_set_label (b, 3, Q_ ("ButtonBar|Forget"), tree_map, w);
|
buttonbar_set_label (b, 3, Q_ ("ButtonBar|Forget"), tree_map, w);
|
||||||
@ -1166,22 +1177,14 @@ tree_callback (Widget * w, Widget * sender, widget_msg_t msg, int parm, void *da
|
|||||||
/* FIXME: mkdir is currently defunct */
|
/* FIXME: mkdir is currently defunct */
|
||||||
buttonbar_set_label (b, 7, Q_ ("ButtonBar|Mkdir"), tree_map, w);
|
buttonbar_set_label (b, 7, Q_ ("ButtonBar|Mkdir"), tree_map, w);
|
||||||
#else
|
#else
|
||||||
buttonbar_clear_label (b, 7, WIDGET (tree));
|
buttonbar_clear_label (b, 7, w);
|
||||||
#endif
|
#endif
|
||||||
buttonbar_set_label (b, 8, Q_ ("ButtonBar|Rmdir"), tree_map, w);
|
buttonbar_set_label (b, 8, Q_ ("ButtonBar|Rmdir"), tree_map, w);
|
||||||
widget_redraw (WIDGET (b));
|
|
||||||
|
|
||||||
/* FIXME: Should find a better way of only displaying the
|
|
||||||
currently selected item */
|
|
||||||
show_tree (tree);
|
|
||||||
return MSG_HANDLED;
|
return MSG_HANDLED;
|
||||||
|
|
||||||
/* FIXME: Should find a better way of changing the color of the
|
|
||||||
selected item */
|
|
||||||
|
|
||||||
case MSG_UNFOCUS:
|
case MSG_UNFOCUS:
|
||||||
tree->searching = 0;
|
tree->searching = 0;
|
||||||
show_tree (tree);
|
|
||||||
return MSG_HANDLED;
|
return MSG_HANDLED;
|
||||||
|
|
||||||
case MSG_KEY:
|
case MSG_KEY:
|
||||||
|
@ -684,6 +684,7 @@ mcview_callback (Widget * w, Widget * sender, widget_msg_t msg, int parm, void *
|
|||||||
|
|
||||||
case MSG_FOCUS:
|
case MSG_FOCUS:
|
||||||
view->dpy_bbar_dirty = TRUE;
|
view->dpy_bbar_dirty = TRUE;
|
||||||
|
/* TODO: get rid of draw here before MSG_DRAW */
|
||||||
mcview_update (view);
|
mcview_update (view);
|
||||||
return MSG_HANDLED;
|
return MSG_HANDLED;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user