From 426c7b45fabd3dea45f21ca89194624fda6a4dba Mon Sep 17 00:00:00 2001 From: Marko Lindqvist Date: Sat, 8 Oct 2022 02:10:59 +0300 Subject: [PATCH 26/26] gtk: Add tooltip to nationdlg columns See osdn #45512 Signed-off-by: Marko Lindqvist --- client/gui-gtk-3.0/plrdlg.c | 38 +++++++++++++++++++++++------------- client/gui-gtk-3.22/plrdlg.c | 38 +++++++++++++++++++++++------------- client/gui-gtk-4.0/plrdlg.c | 20 ++++++++++++++----- 3 files changed, 63 insertions(+), 33 deletions(-) diff --git a/client/gui-gtk-3.0/plrdlg.c b/client/gui-gtk-3.0/plrdlg.c index f205aa31aa..b5d1dabe16 100644 --- a/client/gui-gtk-3.0/plrdlg.c +++ b/client/gui-gtk-3.0/plrdlg.c @@ -68,6 +68,9 @@ static GtkListStore *players_dialog_store; #define PLR_DLG_COL_STYLE (0 + num_player_dlg_columns) #define PLR_DLG_COL_WEIGHT (1 + num_player_dlg_columns) #define PLR_DLG_COL_ID (2 + num_player_dlg_columns) +#define PLR_DLG_COL_TOOLTIP (3 + num_player_dlg_columns) + +#define PLR_DLG_COL_TOTAL (PLR_DLG_COL_TOOLTIP + 1) static void create_players_dialog(void); static void players_meet_callback(GtkMenuItem *item, gpointer data); @@ -265,7 +268,7 @@ static gint plrdlg_sort_func(GtkTreeModel *model, static GtkListStore *players_dialog_store_new(void) { GtkListStore *store; - GType model_types[num_player_dlg_columns + 3]; + GType model_types[num_player_dlg_columns + PLR_DLG_COL_TOTAL]; int i; for (i = 0; i < num_player_dlg_columns; i++) { @@ -285,10 +288,12 @@ static GtkListStore *players_dialog_store_new(void) break; } } - /* special (invisible rows) - Text style, weight and player id */ + + /* Special (invisible rows) - Text style, weight and player id */ model_types[i++] = G_TYPE_INT; /* PLR_DLG_COL_STYLE. */ model_types[i++] = G_TYPE_INT; /* PLR_DLG_COL_WEIGHT. */ model_types[i++] = G_TYPE_INT; /* PLR_DLG_COL_ID. */ + model_types[i++] = G_TYPE_STRING; /* PLR_DLG_COL_TOOLTIP */ store = gtk_list_store_newv(i, model_types); @@ -393,28 +398,28 @@ static GtkWidget* create_show_menu(void) { int i; GtkWidget *menu = gtk_menu_new(); - GtkWidget *item; - - /* index starting at one (1) here to force playername to always be shown */ + GtkWidget *item; + + /* Index starting at one (1) here to force playername to always be shown */ for (i = 1; i < num_player_dlg_columns; i++) { struct player_dlg_column *pcol; - + pcol = &player_dlg_columns[i]; item = gtk_check_menu_item_new_with_label(pcol->title); gtk_check_menu_item_set_active(GTK_CHECK_MENU_ITEM(item), pcol->show); gtk_menu_shell_append(GTK_MENU_SHELL(menu), item); g_signal_connect(item, "toggled", G_CALLBACK(toggle_view), pcol); } - + item = gtk_separator_menu_item_new(); gtk_menu_shell_append(GTK_MENU_SHELL(menu), item); - + item = gtk_check_menu_item_new_with_label(Q_("?show:Dead Players")); gtk_check_menu_item_set_active(GTK_CHECK_MENU_ITEM(item), gui_options.player_dlg_show_dead_players); gtk_menu_shell_append(GTK_MENU_SHELL(menu), item); g_signal_connect(item, "toggled", G_CALLBACK(toggle_dead_players), NULL); - + return menu; } @@ -442,6 +447,8 @@ void create_players_dialog(void) players_list = gtk_tree_view_new_with_model(GTK_TREE_MODEL (players_dialog_store)); + gtk_tree_view_set_tooltip_column(GTK_TREE_VIEW(players_list), + PLR_DLG_COL_TOOLTIP); gtk_widget_set_hexpand(players_list, TRUE); gtk_widget_set_vexpand(players_list, TRUE); g_object_unref(players_dialog_store); @@ -505,7 +512,7 @@ void create_players_dialog(void) gtk_tree_view_column_set_alignment(col, 1.0); break; } - + if (col) { gtk_tree_view_append_column(GTK_TREE_VIEW(players_list), col); } @@ -516,9 +523,9 @@ void create_players_dialog(void) sw = gtk_scrolled_window_new(NULL, NULL); gtk_scrolled_window_set_shadow_type(GTK_SCROLLED_WINDOW(sw), - GTK_SHADOW_ETCHED_IN); + GTK_SHADOW_ETCHED_IN); gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(sw), - GTK_POLICY_AUTOMATIC, GTK_POLICY_ALWAYS); + GTK_POLICY_AUTOMATIC, GTK_POLICY_ALWAYS); gtk_container_add(GTK_CONTAINER(sw), players_list); gtk_container_add(GTK_CONTAINER(players_dialog_shell->vbox), sw); @@ -526,7 +533,7 @@ void create_players_dialog(void) vbox = gtk_grid_new(); gtk_orientable_set_orientation(GTK_ORIENTABLE(vbox), GTK_ORIENTATION_VERTICAL); - + sep = gtk_separator_new(GTK_ORIENTATION_HORIZONTAL); gtk_container_add(GTK_CONTAINER(vbox), sep); @@ -675,7 +682,10 @@ static void fill_row(GtkListStore *store, GtkTreeIter *it, } } - /* now add some eye candy ... */ + gtk_list_store_set(store, it, PLR_DLG_COL_TOOLTIP, + score_tooltip(pplayer, pplayer->score.game), -1); + + /* Now add some eye candy ... */ if (client_has_player()) { switch (player_diplstate_get(client_player(), pplayer)->type) { case DS_WAR: diff --git a/client/gui-gtk-3.22/plrdlg.c b/client/gui-gtk-3.22/plrdlg.c index ed22efcc26..7547ac2acb 100644 --- a/client/gui-gtk-3.22/plrdlg.c +++ b/client/gui-gtk-3.22/plrdlg.c @@ -68,6 +68,9 @@ static GtkListStore *players_dialog_store; #define PLR_DLG_COL_STYLE (0 + num_player_dlg_columns) #define PLR_DLG_COL_WEIGHT (1 + num_player_dlg_columns) #define PLR_DLG_COL_ID (2 + num_player_dlg_columns) +#define PLR_DLG_COL_TOOLTIP (3 + num_player_dlg_columns) + +#define PLR_DLG_COL_TOTAL (PLR_DLG_COL_TOOLTIP + 1) static void create_players_dialog(void); static void players_meet_callback(GtkMenuItem *item, gpointer data); @@ -263,7 +266,7 @@ static gint plrdlg_sort_func(GtkTreeModel *model, static GtkListStore *players_dialog_store_new(void) { GtkListStore *store; - GType model_types[num_player_dlg_columns + 3]; + GType model_types[num_player_dlg_columns + PLR_DLG_COL_TOTAL]; int i; for (i = 0; i < num_player_dlg_columns; i++) { @@ -283,10 +286,12 @@ static GtkListStore *players_dialog_store_new(void) break; } } - /* special (invisible rows) - Text style, weight and player id */ + + /* Special (invisible rows) - Text style, weight and player id */ model_types[i++] = G_TYPE_INT; /* PLR_DLG_COL_STYLE. */ model_types[i++] = G_TYPE_INT; /* PLR_DLG_COL_WEIGHT. */ model_types[i++] = G_TYPE_INT; /* PLR_DLG_COL_ID. */ + model_types[i++] = G_TYPE_STRING; /* PLR_DLG_COL_TOOLTIP */ store = gtk_list_store_newv(i, model_types); @@ -391,28 +396,28 @@ static GtkWidget* create_show_menu(void) { int i; GtkWidget *menu = gtk_menu_new(); - GtkWidget *item; - - /* index starting at one (1) here to force playername to always be shown */ + GtkWidget *item; + + /* Index starting at one (1) here to force playername to always be shown */ for (i = 1; i < num_player_dlg_columns; i++) { struct player_dlg_column *pcol; - + pcol = &player_dlg_columns[i]; item = gtk_check_menu_item_new_with_label(pcol->title); gtk_check_menu_item_set_active(GTK_CHECK_MENU_ITEM(item), pcol->show); gtk_menu_shell_append(GTK_MENU_SHELL(menu), item); g_signal_connect(item, "toggled", G_CALLBACK(toggle_view), pcol); } - + item = gtk_separator_menu_item_new(); gtk_menu_shell_append(GTK_MENU_SHELL(menu), item); - + item = gtk_check_menu_item_new_with_label(Q_("?show:Dead Players")); gtk_check_menu_item_set_active(GTK_CHECK_MENU_ITEM(item), gui_options.player_dlg_show_dead_players); gtk_menu_shell_append(GTK_MENU_SHELL(menu), item); g_signal_connect(item, "toggled", G_CALLBACK(toggle_dead_players), NULL); - + return menu; } @@ -440,6 +445,8 @@ void create_players_dialog(void) players_list = gtk_tree_view_new_with_model(GTK_TREE_MODEL (players_dialog_store)); + gtk_tree_view_set_tooltip_column(GTK_TREE_VIEW(players_list), + PLR_DLG_COL_TOOLTIP); gtk_widget_set_hexpand(players_list, TRUE); gtk_widget_set_vexpand(players_list, TRUE); g_object_unref(players_dialog_store); @@ -503,7 +510,7 @@ void create_players_dialog(void) gtk_tree_view_column_set_alignment(col, 1.0); break; } - + if (col) { gtk_tree_view_append_column(GTK_TREE_VIEW(players_list), col); } @@ -514,9 +521,9 @@ void create_players_dialog(void) sw = gtk_scrolled_window_new(NULL, NULL); gtk_scrolled_window_set_shadow_type(GTK_SCROLLED_WINDOW(sw), - GTK_SHADOW_ETCHED_IN); + GTK_SHADOW_ETCHED_IN); gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(sw), - GTK_POLICY_AUTOMATIC, GTK_POLICY_ALWAYS); + GTK_POLICY_AUTOMATIC, GTK_POLICY_ALWAYS); gtk_container_add(GTK_CONTAINER(sw), players_list); gtk_container_add(GTK_CONTAINER(players_dialog_shell->vbox), sw); @@ -524,7 +531,7 @@ void create_players_dialog(void) vbox = gtk_grid_new(); gtk_orientable_set_orientation(GTK_ORIENTABLE(vbox), GTK_ORIENTATION_VERTICAL); - + sep = gtk_separator_new(GTK_ORIENTATION_HORIZONTAL); gtk_container_add(GTK_CONTAINER(vbox), sep); @@ -673,7 +680,10 @@ static void fill_row(GtkListStore *store, GtkTreeIter *it, } } - /* now add some eye candy ... */ + gtk_list_store_set(store, it, PLR_DLG_COL_TOOLTIP, + score_tooltip(pplayer, pplayer->score.game), -1); + + /* Now add some eye candy ... */ if (client_has_player()) { switch (player_diplstate_get(client_player(), pplayer)->type) { case DS_WAR: diff --git a/client/gui-gtk-4.0/plrdlg.c b/client/gui-gtk-4.0/plrdlg.c index 2a394c6cf1..894e6760c5 100644 --- a/client/gui-gtk-4.0/plrdlg.c +++ b/client/gui-gtk-4.0/plrdlg.c @@ -68,6 +68,9 @@ static GtkListStore *players_dialog_store; #define PLR_DLG_COL_STYLE (0 + num_player_dlg_columns) #define PLR_DLG_COL_WEIGHT (1 + num_player_dlg_columns) #define PLR_DLG_COL_ID (2 + num_player_dlg_columns) +#define PLR_DLG_COL_TOOLTIP (3 + num_player_dlg_columns) + +#define PLR_DLG_COL_TOTAL (PLR_DLG_COL_TOOLTIP + 1) static void create_players_dialog(void); static void players_meet_callback(GSimpleAction *action, GVariant *parameter, @@ -305,7 +308,7 @@ static gint plrdlg_sort_func(GtkTreeModel *model, static GtkListStore *players_dialog_store_new(void) { GtkListStore *store; - GType model_types[num_player_dlg_columns + 3]; + GType model_types[num_player_dlg_columns + PLR_DLG_COL_TOTAL]; int i; for (i = 0; i < num_player_dlg_columns; i++) { @@ -325,10 +328,12 @@ static GtkListStore *players_dialog_store_new(void) break; } } - /* special (invisible rows) - Text style, weight and player id */ + + /* Special (invisible rows) - Text style, weight and player id */ model_types[i++] = G_TYPE_INT; /* PLR_DLG_COL_STYLE. */ model_types[i++] = G_TYPE_INT; /* PLR_DLG_COL_WEIGHT. */ model_types[i++] = G_TYPE_INT; /* PLR_DLG_COL_ID. */ + model_types[i++] = G_TYPE_STRING; /* PLR_DLG_COL_TOOLTIP */ store = gtk_list_store_newv(i, model_types); @@ -450,7 +455,7 @@ static GMenu *create_show_menu(GActionGroup *group) #ifdef MENUS_GTK3 int i; - /* index starting at one (1) here to force playername to always be shown */ + /* Index starting at one (1) here to force playername to always be shown */ for (i = 1; i < num_player_dlg_columns; i++) { struct player_dlg_column *pcol; @@ -546,6 +551,8 @@ void create_players_dialog(void) players_list = gtk_tree_view_new_with_model(GTK_TREE_MODEL (players_dialog_store)); + gtk_tree_view_set_tooltip_column(GTK_TREE_VIEW(players_list), + PLR_DLG_COL_TOOLTIP); gtk_widget_set_hexpand(players_list, TRUE); gtk_widget_set_vexpand(players_list, TRUE); g_object_unref(players_dialog_store); @@ -630,7 +637,7 @@ void create_players_dialog(void) sw = gtk_scrolled_window_new(); gtk_scrolled_window_set_has_frame(GTK_SCROLLED_WINDOW(sw), TRUE); gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(sw), - GTK_POLICY_AUTOMATIC, GTK_POLICY_ALWAYS); + GTK_POLICY_AUTOMATIC, GTK_POLICY_ALWAYS); gtk_scrolled_window_set_child(GTK_SCROLLED_WINDOW(sw), players_list); gui_dialog_add_content_widget(players_dialog_shell, sw); @@ -758,7 +765,10 @@ static void fill_row(GtkListStore *store, GtkTreeIter *it, } } - /* now add some eye candy ... */ + gtk_list_store_set(store, it, PLR_DLG_COL_TOOLTIP, + score_tooltip(pplayer, pplayer->score.game), -1); + + /* Now add some eye candy ... */ if (client_has_player()) { switch (player_diplstate_get(client_player(), pplayer)->type) { case DS_WAR: -- 2.35.1