VLP_LAST_SIGNAL
};
-static void layers_panel_class_init ( VikLayersPanelClass *klass );
-static void layers_panel_init ( VikLayersPanel *vlp );
-
static guint layers_panel_signals[VLP_LAST_SIGNAL] = { 0 };
static GObjectClass *parent_class;
static void layers_move_item_down ( VikLayersPanel *vlp );
static void layers_panel_finalize ( GObject *gob );
-GType vik_layers_panel_get_type()
-{
- static GType vlp_type = 0;
-
- if (!vlp_type)
- {
- static const GTypeInfo vlp_info =
- {
- sizeof (VikLayersPanelClass),
- NULL, /* base_init */
- NULL, /* base_finalize */
- (GClassInitFunc) layers_panel_class_init,
- NULL, /* class_finalize */
- NULL, /* class_data */
- sizeof (VikLayersPanel),
- 0,
- (GInstanceInitFunc) layers_panel_init,
- };
- vlp_type = g_type_register_static ( GTK_TYPE_VBOX, "VikLayersPanel", &vlp_info, 0 );
- }
+G_DEFINE_TYPE (VikLayersPanel, vik_layers_panel, GTK_TYPE_VBOX)
- return vlp_type;
-}
-
-static void layers_panel_class_init ( VikLayersPanelClass *klass )
+static void vik_layers_panel_class_init ( VikLayersPanelClass *klass )
{
GObjectClass *object_class;
return vlp->vvp;
}
-static void layers_panel_init ( VikLayersPanel *vlp )
+static void vik_layers_panel_init ( VikLayersPanel *vlp )
{
GtkWidget *hbox;
GtkWidget *addbutton, *addimage;
}
}
-void vik_layers_panel_emit_update ( VikLayersPanel *vlp )
+/**
+ * Invoke the actual drawing via signal method
+ */
+static gboolean idle_draw_panel ( VikLayersPanel *vlp )
{
g_signal_emit ( G_OBJECT(vlp), layers_panel_signals[VLP_UPDATE_SIGNAL], 0 );
+ return FALSE; // Nothing else to do
+}
+
+void vik_layers_panel_emit_update ( VikLayersPanel *vlp )
+{
+ // Only ever draw when there is time to do so
+ if ( g_thread_self() != vik_window_get_thread (VIK_WINDOW(VIK_GTK_WINDOW_FROM_WIDGET(vlp))) )
+ // Drawing requested from another (background) thread, so handle via the gdk thread method
+ gdk_threads_add_idle ( (GSourceFunc) idle_draw_panel, vlp );
+ else
+ g_idle_add ( (GSourceFunc) idle_draw_panel, vlp );
}
static void layers_item_toggled (VikLayersPanel *vlp, GtkTreeIter *iter)
static void layers_item_edited (VikLayersPanel *vlp, GtkTreeIter *iter, const gchar *new_text)
{
+ if ( !new_text )
+ return;
+
+ if ( new_text[0] == '\0' ) {
+ a_dialog_error_msg ( GTK_WINDOW(VIK_WINDOW_FROM_WIDGET(vlp)), _("New name can not be blank.") );
+ return;
+ }
+
if ( vik_treeview_item_get_type ( vlp->vt, iter ) == VIK_TREEVIEW_TYPE_LAYER )
{
VikLayer *l;
{
if (event->button == 3)
{
- GtkTreeIter iter;
+ static GtkTreeIter iter;
if ( vik_treeview_get_iter_at_pos ( vlp->vt, &iter, event->x, event->y ) )
{
layers_popup ( vlp, &iter, 3 );
*
* Create a new layer and add to panel.
*/
-gboolean vik_layers_panel_new_layer ( VikLayersPanel *vlp, gint type )
+gboolean vik_layers_panel_new_layer ( VikLayersPanel *vlp, VikLayerTypeEnum type )
{
VikLayer *l;
g_assert ( vlp->vvp );
a_dialog_info_msg ( VIK_GTK_WINDOW_FROM_WIDGET(vlp), _("Aggregate Layers have no settable properties.") );
VikLayer *layer = VIK_LAYER( vik_treeview_item_get_pointer ( vlp->vt, &iter ) );
if (vik_layer_properties ( layer, vlp->vvp ))
- vik_layer_emit_update ( layer, FALSE );
+ vik_layer_emit_update ( layer );
return TRUE;
}
else
}
#endif
-VikLayer *vik_layers_panel_get_layer_of_type ( VikLayersPanel *vlp, gint type )
+VikLayer *vik_layers_panel_get_layer_of_type ( VikLayersPanel *vlp, VikLayerTypeEnum type )
{
VikLayer *rv = vik_layers_panel_get_selected ( vlp );
if ( rv == NULL || rv->type != type )