Re: Activate threeview row using keyboard
- From: "Padraig O'Briain" <Padraig Obriain Sun COM>
- To: otaylor redhat com
- Cc: gtk-devel-list gnome org
- Subject: Re: Activate threeview row using keyboard
- Date: Mon, 21 Jan 2002 08:44:16 +0000 (GMT)
> To: "Padraig O'Briain" <Padraig Obriain sun com>
> Cc: gtk-devel-list gnome org
> Subject: Re: Activate threeview row using keyboard
> User-Agent: Gnus/5.0807 (Gnus v5.8.7) Emacs/21.1
> MIME-Version: 1.0
>
>
> "Padraig O'Briain" <Padraig Obriain Sun COM> writes:
>
> > While running the gtk-demo program I realized that I could not activate a
row in
> > the GtkTreeView which contains the demo programs using the keyboard; I could
> > double click on a row to activate it.
> >
> > I attach a patch to allow activation from the keyboard.
> >
> > Permission to commit?
>
> Hmmm, there is already a "select_cursor_row" signal, that works fine
> when you can focus individual cells... I think there is
> just some bug when there is no focusable columns.
>
> Regards,
> Owen
>
I do not think that the part about no focusable columns is correct as the patch
requires that tree_view->priv->focus_column be non-NULL.
Should the "select_cursor_row" signal activate the cell in the focus_column?
Padraig
> > Index: gtktreeview.c
> > ===================================================================
> > RCS file: /cvs/gnome/gtk+/gtk/gtktreeview.c,v
> > retrieving revision 1.196
> > diff -u -p -r1.196 gtktreeview.c
> > --- gtktreeview.c 2002/01/18 00:23:25 1.196
> > +++ gtktreeview.c 2002/01/19 12:24:52
> > @@ -105,6 +105,7 @@ enum
> > EXPAND_COLLAPSE_CURSOR_ROW,
> > SELECT_CURSOR_PARENT,
> > START_INTERACTIVE_SEARCH,
> > + ACTIVATE_SELECTION,
> > LAST_SIGNAL
> > };
> >
> > @@ -387,6 +388,7 @@ static void gtk_tree_view_real_start_edi
> > static void gtk_tree_view_stop_editing (GtkTreeView
*tree_view,
> > gboolean
cancel_editing);
> > static void gtk_tree_view_real_start_interactive_search (GtkTreeView
*tree_view);
> > +static void gtk_tree_view_real_activate_selection (GtkTreeView
*tree_view);
> >
> >
> > static GtkContainerClass *parent_class = NULL;
> > @@ -486,6 +488,7 @@ gtk_tree_view_class_init (GtkTreeViewCla
> > class->expand_collapse_cursor_row =
gtk_tree_view_real_expand_collapse_cursor_row;
> > class->select_cursor_parent = gtk_tree_view_real_select_cursor_parent;
> > class->start_interactive_search =
gtk_tree_view_real_start_interactive_search;
> > + class->activate_selection = gtk_tree_view_real_activate_selection;
> >
> > /* Properties */
> >
> > @@ -762,6 +765,16 @@ gtk_tree_view_class_init (GtkTreeViewCla
> > _gtk_marshal_NONE__NONE,
> > GTK_TYPE_NONE, 0);
> >
> > + tree_view_signals[ACTIVATE_SELECTION] =
> > + g_signal_new ("activate_selection",
> > + G_TYPE_FROM_CLASS (object_class),
> > + G_SIGNAL_RUN_LAST | GTK_RUN_ACTION,
> > + G_STRUCT_OFFSET (GtkTreeViewClass, activate_selection),
> > + NULL, NULL,
> > + _gtk_marshal_NONE__NONE,
> > + GTK_TYPE_NONE, 0);
> > + widget_class->activate_signal = tree_view_signals[ACTIVATE_SELECTION];
> > +
> > /* Key bindings */
> > gtk_tree_view_add_move_binding (binding_set, GDK_Up, 0,
> > GTK_MOVEMENT_DISPLAY_LINES, -1);
> > @@ -6460,6 +6473,44 @@ gtk_tree_view_real_start_interactive_sea
> >
> > /* search first matching iter */
> > gtk_tree_view_search_init (entry, tree_view);
> > +}
> > +
> > +static void
> > +gtk_tree_view_real_activate_selection (GtkTreeView *tree_view)
> > +{
> > + GtkSelectionMode mode;
> > + GtkTreeModel *model;
> > + GtkTreeIter iter;
> > + GtkTreePath *path = NULL;
> > + GtkTreeViewColumn *column = NULL;
> > +
> > + if (tree_view->priv->selection == NULL)
> > + return;
> > +
> > + mode = gtk_tree_selection_get_mode (tree_view->priv->selection);
> > +
> > + switch (mode)
> > + {
> > + case GTK_SELECTION_SINGLE:
> > + case GTK_SELECTION_BROWSE:
> > +
> > + if (gtk_tree_selection_get_selected (tree_view->priv->selection,
&model, &iter))
> > + path = gtk_tree_model_get_path (model, &iter);
> > + break;
> > + default:
> > + break;
> > + }
> > +
> > + if (path)
> > + {
> > + if (tree_view->priv->focus_column)
> > + column = tree_view->priv->focus_column;
> > +
> > + if (column)
> > + gtk_tree_view_row_activated (tree_view, path, column);
> > +
> > + gtk_tree_path_free (path);
> > + }
> > }
> >
> > /* this function returns the new width of the column being resized given
> > Index: gtktreeview.h
> > ===================================================================
> > RCS file: /cvs/gnome/gtk+/gtk/gtktreeview.h,v
> > retrieving revision 1.49
> > diff -u -p -r1.49 gtktreeview.h
> > --- gtktreeview.h 2001/12/12 23:04:12 1.49
> > +++ gtktreeview.h 2002/01/19 12:24:52
> > @@ -85,6 +85,7 @@ struct _GtkTreeViewClass
> > GtkTreePath *path);
> > void (* columns_changed) (GtkTreeView *tree_view);
> > void (* cursor_changed) (GtkTreeView *tree_view);
> > + void (* activate_selection) (GtkTreeView *tree_view);
> >
> > /* Key Binding signals */
> > void (* move_cursor) (GtkTreeView *tree_view,
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]