From 95a0ede1bf9b72bef2e6c4ec1195d05305efc6af Mon Sep 17 00:00:00 2001 From: Marko Lindqvist Date: Sun, 19 Mar 2023 07:58:30 +0200 Subject: [PATCH 25/25] Add tooltip for Turn Done button when fixedlength enabled Affects gtk- and Qt-clients. Requested by Alina Lenk See osdn #45887 Signed-off-by: Marko Lindqvist --- client/gui-gtk-3.22/gui_main.c | 41 +++++++++++++++++++++++----------- client/gui-gtk-3.22/gui_main.h | 6 +++-- client/gui-gtk-3.22/mapctrl.c | 2 ++ client/gui-gtk-4.0/gui_main.c | 41 +++++++++++++++++++++++----------- client/gui-gtk-4.0/gui_main.h | 6 +++-- client/gui-gtk-4.0/mapctrl.c | 2 ++ client/gui-qt/fc_client.cpp | 1 + client/gui-qt/gui_main.cpp | 2 +- client/gui-qt/mapctrl.cpp | 7 ++++-- client/gui-qt/mapview.cpp | 5 ++--- client/gui-qt/sidebar.cpp | 19 ++++++++++++++++ client/gui-qt/sidebar.h | 3 ++- 12 files changed, 98 insertions(+), 37 deletions(-) diff --git a/client/gui-gtk-3.22/gui_main.c b/client/gui-gtk-3.22/gui_main.c index a95248ea46..1c06a05014 100644 --- a/client/gui-gtk-3.22/gui_main.c +++ b/client/gui-gtk-3.22/gui_main.c @@ -1120,6 +1120,25 @@ static void setup_canvas_color_for_state(GtkStateFlags state) } #endif +/**********************************************************************//** + Update tooltip of the Turn Done button +**************************************************************************/ +void update_turn_done_tooltip(void) +{ + struct option *opt = optset_option_by_name(server_optset, "fixedlength"); + + if (opt != NULL && option_bool_get(opt)) { + gtk_widget_set_tooltip_text(turn_done_button, + _("Fixed length turns")); + } else { + char buf[256]; + + fc_snprintf(buf, sizeof(buf), "%s:\n%s", + _("Turn Done"), _("Shift+Return")); + gtk_widget_set_tooltip_text(turn_done_button, buf); + } +} + /**********************************************************************//** Do the heavy lifting for the widget setup. **************************************************************************/ @@ -1129,7 +1148,6 @@ static void setup_widgets(void) GtkWidget *frame, *table, *table2, *paned, *sw, *text; GtkWidget *button, *view, *vgrid, *right_vbox = NULL; int i; - char buf[256]; GtkWidget *notebook, *statusbar; GtkWidget *dtach_lowbox = NULL; struct sprite *spr; @@ -1138,9 +1156,9 @@ static void setup_widgets(void) notebook = gtk_notebook_new(); - /* stop mouse wheel notebook page switching. */ + /* Stop mouse wheel notebook page switching. */ g_signal_connect(notebook, "scroll_event", - G_CALLBACK(gtk_true), NULL); + G_CALLBACK(gtk_true), NULL); toplevel_tabs = notebook; gtk_notebook_set_show_tabs(GTK_NOTEBOOK(notebook), FALSE); @@ -1225,7 +1243,7 @@ static void setup_widgets(void) gtk_grid_attach_next_to(GTK_GRID(hgrid), vgrid, right_vbox, GTK_POS_LEFT, 1, 1); - /* overview canvas */ + /* Overview canvas */ ahbox = detached_widget_new(); gtk_widget_set_hexpand(ahbox, FALSE); gtk_widget_set_vexpand(ahbox, FALSE); @@ -1308,7 +1326,7 @@ static void setup_widgets(void) gtk_grid_set_column_homogeneous(GTK_GRID(table), TRUE); gtk_container_add(GTK_CONTAINER(avbox), table); - /* citizens for taxrates */ + /* Citizens for taxrates */ ebox = gtk_event_box_new(); gtk_event_box_set_visible_window(GTK_EVENT_BOX(ebox), FALSE); gtk_grid_attach(GTK_GRID(table), ebox, 0, 0, 10, 1); @@ -1332,7 +1350,7 @@ static void setup_widgets(void) gtk_container_add(GTK_CONTAINER(ebox), econ_label[i]); } - /* science, environmental, govt, timeout */ + /* Science, environmental, govt, timeout */ spr = client_research_sprite(); if (spr != NULL) { bulb_label = gtk_image_new_from_surface(spr->surface); @@ -1404,17 +1422,14 @@ static void setup_widgets(void) gtk_container_add(GTK_CONTAINER(frame), timeout_label); - /* turn done */ + /* Turn done */ turn_done_button = gtk_button_new_with_label(_("Turn Done")); gtk_grid_attach(GTK_GRID(table), turn_done_button, 0, 2, 10, 1); g_signal_connect(turn_done_button, "clicked", G_CALLBACK(end_turn_callback), NULL); - - fc_snprintf(buf, sizeof(buf), "%s:\n%s", - _("Turn Done"), _("Shift+Return")); - gtk_widget_set_tooltip_text(turn_done_button, buf); + update_turn_done_tooltip(); /* Selected unit status */ @@ -2249,8 +2264,8 @@ static gboolean show_info_popup(GtkWidget *w, GdkEventButton *ev, gpointer data) **************************************************************************/ static void end_turn_callback(GtkWidget *w, gpointer data) { - gtk_widget_set_sensitive(turn_done_button, FALSE); - user_ended_turn(); + gtk_widget_set_sensitive(turn_done_button, FALSE); + user_ended_turn(); } /**********************************************************************//** diff --git a/client/gui-gtk-3.22/gui_main.h b/client/gui-gtk-3.22/gui_main.h index ebdc8c9205..8e3976829c 100644 --- a/client/gui-gtk-3.22/gui_main.h +++ b/client/gui-gtk-3.22/gui_main.h @@ -22,7 +22,7 @@ #define GUI_GTK_OPTION_STR(optname) "gui_gtk3_22_" #optname #define GUI_GTK_DEFAULT_THEME_NAME FC_GTK3_22_DEFAULT_THEME_NAME -/* network string charset conversion */ +/* Network string charset conversion */ gchar *ntoh_str(const gchar *netstr); extern PangoFontDescription *city_names_style; @@ -88,4 +88,6 @@ bool is_gui_up(void); gboolean fc_lost_focus(GtkWidget *w, GdkEventKey *ev, gpointer data); gboolean fc_gained_focus(GtkWidget *w, GdkEventKey *ev, gpointer data); -#endif /* FC__GUI_MAIN_H */ +void update_turn_done_tooltip(void); + +#endif /* FC__GUI_MAIN_H */ diff --git a/client/gui-gtk-3.22/mapctrl.c b/client/gui-gtk-3.22/mapctrl.c index 268f39abc4..d1a0b70339 100644 --- a/client/gui-gtk-3.22/mapctrl.c +++ b/client/gui-gtk-3.22/mapctrl.c @@ -209,6 +209,8 @@ void popup_newcity_dialog(struct unit *punit, const char *suggestname) void set_turn_done_button_state(bool state) { gtk_widget_set_sensitive(turn_done_button, state); + + update_turn_done_tooltip(); } /**********************************************************************//** diff --git a/client/gui-gtk-4.0/gui_main.c b/client/gui-gtk-4.0/gui_main.c index e66dda03b9..4ff9b5a761 100644 --- a/client/gui-gtk-4.0/gui_main.c +++ b/client/gui-gtk-4.0/gui_main.c @@ -1040,6 +1040,25 @@ bool terminate_signal_processing(void) return TRUE; } +/**********************************************************************//** + Update tooltip of the Turn Done button +**************************************************************************/ +void update_turn_done_tooltip(void) +{ + struct option *opt = optset_option_by_name(server_optset, "fixedlength"); + + if (opt != NULL && option_bool_get(opt)) { + gtk_widget_set_tooltip_text(turn_done_button, + _("Fixed length turns")); + } else { + char buf[256]; + + fc_snprintf(buf, sizeof(buf), "%s:\n%s", + _("Turn Done"), _("Shift+Return")); + gtk_widget_set_tooltip_text(turn_done_button, buf); + } +} + /**********************************************************************//** Do the heavy lifting for the widget setup. **************************************************************************/ @@ -1049,7 +1068,6 @@ static void setup_widgets(void) GtkWidget *frame, *table, *table2, *paned, *sw, *text; GtkWidget *button, *view, *vgrid, *vbox, *right_vbox = NULL; int i; - char buf[256]; GtkWidget *notebook, *statusbar; GtkWidget *dtach_lowbox = NULL; struct sprite *spr; @@ -1097,7 +1115,7 @@ static void setup_widgets(void) gtk_widget_set_margin_start(ingame_votebar, 2); gtk_widget_set_margin_top(ingame_votebar, 2); - /* *** everything in the top *** */ + /* *** Everything in the top *** */ page = gtk_scrolled_window_new(); gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(page), @@ -1152,7 +1170,7 @@ static void setup_widgets(void) GTK_POS_LEFT, 1, 1); grid_col++; - /* overview canvas */ + /* Overview canvas */ ahbox = detached_widget_new(); gtk_widget_set_hexpand(ahbox, FALSE); gtk_widget_set_vexpand(ahbox, FALSE); @@ -1165,15 +1183,15 @@ static void setup_widgets(void) gtk_widget_set_margin_top(overview_scrolled_window, 1); gtk_widget_set_margin_bottom(overview_scrolled_window, 1); gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW (overview_scrolled_window), - GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC); + GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC); overview_canvas = gtk_drawing_area_new(); gtk_widget_set_halign(overview_canvas, GTK_ALIGN_CENTER); gtk_widget_set_valign(overview_canvas, GTK_ALIGN_CENTER); gtk_widget_set_size_request(overview_canvas, overview_canvas_store_width, - overview_canvas_store_height); + overview_canvas_store_height); gtk_widget_set_size_request(overview_scrolled_window, overview_canvas_store_width, - overview_canvas_store_height); + overview_canvas_store_height); gtk_widget_set_hexpand(overview_canvas, TRUE); gtk_widget_set_vexpand(overview_canvas, TRUE); @@ -1243,7 +1261,7 @@ static void setup_widgets(void) gtk_grid_set_column_homogeneous(GTK_GRID(table), TRUE); gtk_box_append(GTK_BOX(avbox), table); - /* citizens for taxrates */ + /* Citizens for taxrates */ table2 = gtk_grid_new(); gtk_grid_attach(GTK_GRID(table), table2, 0, 0, 10, 1); econ_widget = table2; @@ -1262,7 +1280,7 @@ static void setup_widgets(void) gtk_grid_attach(GTK_GRID(table2), econ_label[i], i, 0, 1, 1); } - /* science, environmental, govt, timeout */ + /* Science, environmental, govt, timeout */ spr = client_research_sprite(); if (spr != NULL) { bulb_label = picture_new_from_surface(spr->surface); @@ -1326,17 +1344,14 @@ static void setup_widgets(void) gtk_frame_set_child(GTK_FRAME(frame), timeout_label); - /* turn done */ + /* Turn done */ turn_done_button = gtk_button_new_with_label(_("Turn Done")); gtk_grid_attach(GTK_GRID(table), turn_done_button, 0, 2, 10, 1); g_signal_connect(turn_done_button, "clicked", G_CALLBACK(end_turn_callback), NULL); - - fc_snprintf(buf, sizeof(buf), "%s:\n%s", - _("Turn Done"), _("Shift+Return")); - gtk_widget_set_tooltip_text(turn_done_button, buf); + update_turn_done_tooltip(); /* Selected unit status */ diff --git a/client/gui-gtk-4.0/gui_main.h b/client/gui-gtk-4.0/gui_main.h index 85cbce647e..1e557b4b27 100644 --- a/client/gui-gtk-4.0/gui_main.h +++ b/client/gui-gtk-4.0/gui_main.h @@ -22,7 +22,7 @@ #define GUI_GTK_OPTION_STR(optname) "gui_gtk4_" #optname #define GUI_GTK_DEFAULT_THEME_NAME FC_GTK4_DEFAULT_THEME_NAME -/* network string charset conversion */ +/* Network string charset conversion */ gchar *ntoh_str(const gchar *netstr); extern PangoFontDescription *city_names_style; @@ -85,4 +85,6 @@ gboolean fc_lost_focus(GtkEventControllerFocus *controller, gboolean fc_gained_focus(GtkEventControllerFocus *controller, gpointer data); -#endif /* FC__GUI_MAIN_H */ +void update_turn_done_tooltip(void); + +#endif /* FC__GUI_MAIN_H */ diff --git a/client/gui-gtk-4.0/mapctrl.c b/client/gui-gtk-4.0/mapctrl.c index 9e6065c2ed..4aa59bf385 100644 --- a/client/gui-gtk-4.0/mapctrl.c +++ b/client/gui-gtk-4.0/mapctrl.c @@ -152,6 +152,8 @@ void popup_newcity_dialog(struct unit *punit, const char *suggestname) void set_turn_done_button_state(bool state) { gtk_widget_set_sensitive(turn_done_button, state); + + update_turn_done_tooltip(); } /**********************************************************************//** diff --git a/client/gui-qt/fc_client.cpp b/client/gui-qt/fc_client.cpp index db0d5a29f1..57375416c0 100644 --- a/client/gui-qt/fc_client.cpp +++ b/client/gui-qt/fc_client.cpp @@ -1062,6 +1062,7 @@ QString fc_icons::get_path(const QString &id) void fc_game_tab_widget::resizeEvent(QResizeEvent *event) { QSize size; + size = event->size(); if (C_S_RUNNING <= client_state()) { gui()->sidebar_wdg->resize_me(size.height()); diff --git a/client/gui-qt/gui_main.cpp b/client/gui-qt/gui_main.cpp index e588dbfebd..00ef1f7dc0 100644 --- a/client/gui-qt/gui_main.cpp +++ b/client/gui-qt/gui_main.cpp @@ -358,7 +358,7 @@ void qtg_real_focus_units_changed(void) } /**********************************************************************//** - Enqueue a callback to be called during an idle moment. The 'callback' + Enqueue a callback to be called during an idle moment. The 'callback' function should be called sometimes soon, and passed the 'data' pointer as its data. **************************************************************************/ diff --git a/client/gui-qt/mapctrl.cpp b/client/gui-qt/mapctrl.cpp index 9d40b015ce..ef5db727b4 100644 --- a/client/gui-qt/mapctrl.cpp +++ b/client/gui-qt/mapctrl.cpp @@ -41,12 +41,13 @@ #include "shortcuts.h" extern void side_disable_endturn(bool do_restore); +extern void update_turn_done_tooltip(void); extern void qload_lua_script(); extern void qreload_lua_script(); extern "C" int city_buy_production(struct city *pcity); /**********************************************************************//** - Popup a dialog to ask for the name of a new city. The given string + Popup a dialog to ask for the name of a new city. The given string should be used as a suggestion. **************************************************************************/ void popup_newcity_dialog(struct unit *punit, const char *suggestname) @@ -74,12 +75,14 @@ void popup_newcity_dialog(struct unit *punit, const char *suggestname) } /**********************************************************************//** - A turn done button should be provided for the player. This function + A turn done button should be provided for the player. This function is called to toggle it between active/inactive. **************************************************************************/ void set_turn_done_button_state(bool state) { side_disable_endturn(state); + + update_turn_done_tooltip(); } /**********************************************************************//** diff --git a/client/gui-qt/mapview.cpp b/client/gui-qt/mapview.cpp index 59be953441..6ede52fcae 100644 --- a/client/gui-qt/mapview.cpp +++ b/client/gui-qt/mapview.cpp @@ -1090,8 +1090,8 @@ void qtg_update_timeout_label(void) /**********************************************************************//** If do_restore is false it should change the turn button style (to - draw the user's attention to it). If called regularly from a timer - this will give a blinking turn done button. If do_restore is true + draw the user's attention to it). If called regularly from a timer + this will give a blinking turn done button. If do_restore is true this should reset the turn done button to the default style. **************************************************************************/ void update_turn_done_button(bool do_restore) @@ -1100,7 +1100,6 @@ void update_turn_done_button(bool do_restore) return; } side_blink_endturn(do_restore); - } diff --git a/client/gui-qt/sidebar.cpp b/client/gui-qt/sidebar.cpp index 2f1858d1bd..54b0e56893 100644 --- a/client/gui-qt/sidebar.cpp +++ b/client/gui-qt/sidebar.cpp @@ -652,6 +652,24 @@ void side_center_unit() request_center_focus_unit(); } +/**********************************************************************//** + Update tooltip of the Turn Done button +**************************************************************************/ +void update_turn_done_tooltip() +{ + struct option *opt = optset_option_by_name(server_optset, "fixedlength"); + + if (opt != NULL && option_bool_get(opt)) { + gui()->sw_endturn->setToolTip(_("Fixed length turns")); + } else { + char buf[256]; + + fc_snprintf(buf, sizeof(buf), "%s:\n%s", + _("Turn Done"), _("Shift+Return")); + gui()->sw_endturn->setToolTip(buf); + } +} + /***********************************************************************//** Disables end turn button if asked ***************************************************************************/ @@ -660,6 +678,7 @@ void side_disable_endturn(bool do_restore) if (gui()->current_page() != PAGE_GAME) { return; } + gui()->sw_endturn->disabled = !do_restore; gui()->sw_endturn->update_final_pixmap(); } diff --git a/client/gui-qt/sidebar.h b/client/gui-qt/sidebar.h index a23be40a9c..b25eeefcb8 100644 --- a/client/gui-qt/sidebar.h +++ b/client/gui-qt/sidebar.h @@ -32,6 +32,7 @@ typedef void (*pfcn_bool)(bool); typedef void (*pfcn)(void); void side_blink_endturn(bool do_restore); +void update_turn_done_tooltip(); void side_center_unit(); void side_disable_endturn(bool do_restore); void side_finish_turn(bool nothing); @@ -53,7 +54,7 @@ public: int type = SW_STD); ~fc_sidewidget(); int get_priority(); - QPixmap* get_pixmap(); + QPixmap *get_pixmap(); void paint(QPainter *painter, QPaintEvent *event); void resize_pixmap(int width, int height); void set_custom_labels(QString l); -- 2.39.2