switch ( type )
{
- case VIK_TREEVIEW_TYPE_LAYER: visible = (VIK_LAYER(p)->visible ^= 1); break;
- case VIK_TREEVIEW_TYPE_SUBLAYER: visible = vik_layer_sublayer_toggle_visible ( VIK_LAYER(vik_treeview_item_get_parent(vlp->vt, iter)), vik_treeview_item_get_data(vlp->vt, iter), p); break;
+ case VIK_TREEVIEW_TYPE_LAYER:
+ visible = (VIK_LAYER(p)->visible ^= 1);
+ vik_layer_emit_update_although_invisible ( VIK_LAYER(p) ); /* set trigger for half-drawn */
+ break;
+ case VIK_TREEVIEW_TYPE_SUBLAYER:
+ visible = vik_layer_sublayer_toggle_visible ( VIK_LAYER(vik_treeview_item_get_parent(vlp->vt, iter)),
+ vik_treeview_item_get_data(vlp->vt, iter), p);
+ vik_layer_emit_update_although_invisible ( VIK_LAYER(vik_treeview_item_get_parent(vlp->vt, iter)) );
+ break;
default: return;
}
vik_treeview_item_set_visible ( vlp->vt, iter, visible );
-
- vik_layers_panel_emit_update ( vlp );
}
static void layers_item_edited (VikLayersPanel *vlp, GtkTreeIter *iter, const gchar *new_text)
VikLayer *vl = VIK_LAYER(vik_treeview_item_get_parent ( vlp->vt, &iter ));
replace_iter = &(vl->iter);
g_assert ( vl->realized );
- addtoagg = VIK_AGGREGATE_LAYER(vik_treeview_item_get_parent ( vlp->vt, &(vl->iter) ) );
+ VikLayer *grandpa = (vik_treeview_item_get_parent ( vlp->vt, &(vl->iter) ) );
+ if (IS_VIK_AGGREGATE_LAYER(grandpa))
+ addtoagg = VIK_AGGREGATE_LAYER(grandpa);
+ else {
+ addtoagg = vlp->toplayer;
+ replace_iter = &grandpa->iter;
+ }
}
if ( replace_iter )
vik_aggregate_layer_insert_layer ( addtoagg, l, replace_iter );
{
if ( vik_treeview_item_get_data ( vlp->vt, &iter ) == VIK_LAYER_AGGREGATE )
a_dialog_info_msg ( VIK_GTK_WINDOW_FROM_WIDGET(vlp), "Aggregate Layers have no settable properties." );
- vik_layer_properties ( VIK_LAYER( vik_treeview_item_get_pointer ( vlp->vt, &iter ) ), VIK_GTK_WINDOW_FROM_WIDGET(vlp->vt) );
+ vik_layer_properties ( VIK_LAYER( vik_treeview_item_get_pointer ( vlp->vt, &iter ) ), vlp->vvp );
return TRUE;
}
else
if ( type == VIK_TREEVIEW_TYPE_LAYER )
{
VikAggregateLayer *parent = vik_treeview_item_get_parent ( vlp->vt, &iter );
+
if ( parent )
{
- a_clipboard_copy ( vlp );
+
+ /* reset trigger if trigger deleted */
+ if ( vik_layers_panel_get_selected ( vlp ) == vik_viewport_get_trigger ( vlp->vvp ) )
+ vik_viewport_set_trigger ( vlp->vvp, NULL );
+
+ a_clipboard_copy_selected ( vlp );
if ( vik_aggregate_layer_delete ( parent, &iter ) )
vik_layers_panel_emit_update ( vlp );
}
type = vik_treeview_item_get_type ( vlp->vt, &iter );
if ( type == VIK_TREEVIEW_TYPE_LAYER ) {
- a_clipboard_copy ( vlp );
+ a_clipboard_copy_selected ( vlp );
}
}
void vik_layers_panel_paste_selected ( VikLayersPanel *vlp )
{
- gint type;
GtkTreeIter iter;
g_return_if_fail ( vik_treeview_get_selected_iter ( vlp->vt, &iter ) );
a_clipboard_paste ( vlp );
VikAggregateLayer *parent = vik_treeview_item_get_parent ( vlp->vt, &iter );
if ( parent )
{
+ /* reset trigger if trigger deleted */
+ if ( vik_layers_panel_get_selected ( vlp ) == vik_viewport_get_trigger ( vlp->vvp ) )
+ vik_viewport_set_trigger ( vlp->vvp, NULL );
+
if (IS_VIK_AGGREGATE_LAYER(parent)) {
if ( vik_aggregate_layer_delete ( parent, &iter ) )
vik_layers_panel_emit_update ( vlp );
else if (type == VIK_TREEVIEW_TYPE_SUBLAYER) {
VikLayer *sel = vik_layers_panel_get_selected ( vlp );
if ( vik_layer_get_interface(sel->type)->delete_item ) {
- vik_layer_get_interface(sel->type)->delete_item ( sel, type, vik_treeview_item_get_pointer(sel->vt, &iter) );
+ gint subtype = vik_treeview_item_get_data( vlp->vt, &iter);
+ vik_layer_get_interface(sel->type)->delete_item ( sel, subtype, vik_treeview_item_get_pointer(sel->vt, &iter) );
}
}
}
return rv;
}
+GList *vik_layers_panel_get_all_layers_of_type(VikLayersPanel *vlp, gint type)
+{
+ GList *layers = NULL;
+
+ return (vik_aggregate_layer_get_all_layers_of_type ( vlp->toplayer, layers, type ));
+}
+
VikAggregateLayer *vik_layers_panel_get_top_layer ( VikLayersPanel *vlp )
{
return vlp->toplayer;