From ed2fbc45c1cf58bc1e3427fca0522b688da0e07f Mon Sep 17 00:00:00 2001 From: Andy Spencer Date: Thu, 6 May 2010 06:33:19 +0000 Subject: [PATCH] Convert time selector to GtkTreeView --- data/main.ui.in | 29 ++++++++++++++++++++--------- src/aweather-gui.c | 28 +++++++++++++--------------- 2 files changed, 33 insertions(+), 24 deletions(-) diff --git a/data/main.ui.in b/data/main.ui.in index 986c029..8f178b9 100644 --- a/data/main.ui.in +++ b/data/main.ui.in @@ -11,7 +11,15 @@ - + + + + + + + + + @@ -21,14 +29,6 @@ - - - - - - - - AWeather @@ -321,6 +321,17 @@ True times False + + + Time + + + + 0 + + + + diff --git a/src/aweather-gui.c b/src/aweather-gui.c index 7c6e140..41069b0 100644 --- a/src/aweather-gui.c +++ b/src/aweather-gui.c @@ -264,28 +264,26 @@ static void prefs_setup(AWeatherGui *self) static void time_setup(AWeatherGui *self) { - /* Setup UI */ - GtkCalendar *cal = GTK_CALENDAR(aweather_gui_get_widget(self, "main_date_cal")); - GtkTreeView *view = GTK_TREE_VIEW(aweather_gui_get_widget(self, "main_time")); - GtkCellRenderer *rend = gtk_cell_renderer_text_new(); - GtkTreeViewColumn *col = gtk_tree_view_column_new_with_attributes( - "Time", rend, "text", 0, NULL); - gtk_tree_view_append_column(view, col); - g_object_set(rend, "size-points", 8.0, NULL); - /* Add times */ - GtkListStore *store = GTK_LIST_STORE(aweather_gui_get_object(self, "times")); + GtkTreeStore *store = GTK_TREE_STORE(aweather_gui_get_object(self, "times")); for (int hour = 0; hour < 24; hour++) { - for (int min = 0; min < 60; min += 10) { - GtkTreeIter iter; - gchar *str = g_strdup_printf("%02d:%02d", hour, min); - gtk_list_store_append(store, &iter); - gtk_list_store_set(store, &iter, 0, str, 1, hour, 2, min, -1); + GtkTreeIter hour_iter; + gchar *str = g_strdup_printf("%02d:00Z", hour); + gtk_tree_store_append(store, &hour_iter, NULL); + gtk_tree_store_set(store, &hour_iter, 0, str, 1, hour, 2, 0, -1); + g_free(str); + for (int min = 5; min < 60; min += 5) { + GtkTreeIter min_iter; + gchar *str = g_strdup_printf("%02d:%02dZ", hour, min); + gtk_tree_store_append(store, &min_iter, &hour_iter); + gtk_tree_store_set(store, &min_iter, 0, str, 1, hour, 2, min, -1); g_free(str); } } /* Connect signals */ + GtkWidget *cal = aweather_gui_get_widget(self, "main_date_cal"); + GtkWidget *view = aweather_gui_get_widget(self, "main_time"); g_signal_connect_swapped(cal, "day-selected-double-click", G_CALLBACK(on_time_changed), self); g_signal_connect_swapped(view, "row-activated", -- 2.43.2