2 * viking -- GPS Data and Topo Analyzer, Explorer, and Manager
4 * Copyright (C) 2003-2005, Evan Battaglia <gtoevan@gmx.net>
5 * Copyright (C) 2011, Rob Norris <rw_norris@hotmail.com>
6 * Copyright (C) 2012, Guilhem Bonnefille <guilhem.bonnefille@gmail.com>
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License as published by
10 * the Free Software Foundation; either version 2 of the License, or
11 * (at your option) any later version.
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
18 * You should have received a copy of the GNU General Public License
19 * along with this program; if not, write to the Free Software
20 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
24 /* gtk status bars: just plain dumb. this file shouldn't have to exist.
25 NB as of gtk 2.18 there are 'info bars' that could be useful... */
28 #include <glib/gi18n.h>
32 #include "vikstatus.h"
33 #include "background.h"
41 struct _VikStatusbar {
43 GtkWidget *status[VIK_STATUSBAR_NUM_TYPES];
44 gboolean empty[VIK_STATUSBAR_NUM_TYPES];
47 G_DEFINE_TYPE (VikStatusbar, vik_statusbar, GTK_TYPE_HBOX)
49 static guint vik_statusbar_signals[LAST_SIGNAL] = { 0 };
52 forward_signal (GObject *object, gpointer user_data)
54 gint item = GPOINTER_TO_INT (g_object_get_data ( object, "type" ));
55 VikStatusbar *vs = VIK_STATUSBAR (user_data);
57 // Clicking on the items field will bring up the background jobs window
58 if ( item == VIK_STATUSBAR_ITEMS )
59 a_background_show_window();
61 g_signal_emit (G_OBJECT (vs),
62 vik_statusbar_signals[CLICKED], 0,
69 vik_statusbar_class_init (VikStatusbarClass *klass)
71 vik_statusbar_signals[CLICKED] =
72 g_signal_new ("clicked",
73 G_TYPE_FROM_CLASS (klass),
75 G_STRUCT_OFFSET (VikStatusbarClass, clicked),
77 g_cclosure_marshal_VOID__INT,
81 klass->clicked = NULL;
85 vik_statusbar_init (VikStatusbar *vs)
89 for ( i = 0; i < VIK_STATUSBAR_NUM_TYPES; i++ ) {
92 if (i == VIK_STATUSBAR_ITEMS || i == VIK_STATUSBAR_ZOOM )
93 vs->status[i] = gtk_button_new();
96 vs->status[i] = gtk_statusbar_new();
97 gtk_statusbar_set_has_resize_grip ( GTK_STATUSBAR(vs->status[i]), FALSE );
99 g_object_set_data (G_OBJECT (vs->status[i]), "type", GINT_TO_POINTER(i));
102 gtk_box_pack_start ( GTK_BOX(vs), vs->status[VIK_STATUSBAR_TOOL], FALSE, FALSE, 1);
103 gtk_widget_set_size_request ( vs->status[VIK_STATUSBAR_TOOL], 125, -1 );
105 g_signal_connect ( G_OBJECT(vs->status[VIK_STATUSBAR_ITEMS]), "clicked", G_CALLBACK (forward_signal), vs);
106 gtk_button_set_relief ( GTK_BUTTON(vs->status[VIK_STATUSBAR_ITEMS]), GTK_RELIEF_NONE );
107 gtk_widget_set_tooltip_text (GTK_WIDGET (vs->status[VIK_STATUSBAR_ITEMS]), _("Current number of background tasks. Click to see the background jobs."));
108 gtk_box_pack_start ( GTK_BOX(vs), vs->status[VIK_STATUSBAR_ITEMS], FALSE, FALSE, 1);
109 gtk_widget_set_size_request ( vs->status[VIK_STATUSBAR_ITEMS], 100, -1 );
111 g_signal_connect ( G_OBJECT(vs->status[VIK_STATUSBAR_ZOOM]), "clicked", G_CALLBACK (forward_signal), vs);
112 gtk_button_set_relief ( GTK_BUTTON(vs->status[VIK_STATUSBAR_ZOOM]), GTK_RELIEF_NONE );
113 gtk_widget_set_tooltip_text (GTK_WIDGET (vs->status[VIK_STATUSBAR_ZOOM]), _("Current zoom level. Click to select a new one."));
114 gtk_box_pack_start ( GTK_BOX(vs), vs->status[VIK_STATUSBAR_ZOOM], FALSE, FALSE, 1);
115 gtk_widget_set_size_request ( vs->status[VIK_STATUSBAR_ZOOM], 100, -1 );
117 gtk_box_pack_start ( GTK_BOX(vs), vs->status[VIK_STATUSBAR_POSITION], FALSE, FALSE, 1);
118 gtk_widget_set_size_request ( vs->status[VIK_STATUSBAR_POSITION], 275, -1 );
120 gtk_box_pack_end ( GTK_BOX(vs), vs->status[VIK_STATUSBAR_INFO], TRUE, TRUE, 1);
122 // Set minimum overall size
123 // otherwise the individual size_requests above create an implicit overall size,
124 // and so one can't downsize horizontally as much as may be desired when the statusbar is on
125 gtk_widget_set_size_request ( GTK_WIDGET(vs), 50, -1 );
131 * Creates a new #VikStatusbar widget.
133 * Return value: the new #VikStatusbar widget.
138 VikStatusbar *vs = VIK_STATUSBAR ( g_object_new ( VIK_STATUSBAR_TYPE, NULL ) );
144 * vik_statusbar_set_message:
145 * @vs: the #VikStatusbar itself
146 * @field: the field to update
147 * @message: the message to use
149 * Update the message of the given field.
152 vik_statusbar_set_message ( VikStatusbar *vs, vik_statusbar_type_t field, const gchar *message )
154 if ( field >= 0 && field < VIK_STATUSBAR_NUM_TYPES )
156 if ( field == VIK_STATUSBAR_ITEMS || field == VIK_STATUSBAR_ZOOM )
158 gtk_button_set_label ( GTK_BUTTON(vs->status[field]), message);
162 GtkStatusbar *gsb = GTK_STATUSBAR(vs->status[field]);
164 if ( !vs->empty[field] )
165 gtk_statusbar_pop ( gsb, 0 );
167 vs->empty[field] = FALSE;
169 gtk_statusbar_push ( gsb, 0, message );