2 * Copyright (C) 2000 Red Hat, Inc., Jonathan Blandford <jrb@redhat.com>
4 * This library is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU Library General Public
6 * License as published by the Free Software Foundation; either
7 * version 2 of the License, or (at your option) any later version.
9 * This library is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * Library General Public License for more details.
14 * You should have received a copy of the GNU Library General Public
15 * License along with this library; if not, write to the
16 * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
17 * Boston, MA 02111-1307, USA.
19 #ifndef __GTK_TREE_VIEW_H__
20 #define __GTK_TREE_VIEW_H__
22 #include <gtk/gtkcontainer.h>
23 #include <gtk/gtktreemodel.h>
24 #include <gtk/gtktreeviewcolumn.h>
25 #include <gtk/gtkdnd.h>
29 #endif /* __cplusplus */
33 /* drop before/after this row */
34 GTK_TREE_VIEW_DROP_BEFORE,
35 GTK_TREE_VIEW_DROP_AFTER,
36 /* drop as a child of this row (with fallback to before or after
37 * if into is not possible)
39 GTK_TREE_VIEW_DROP_INTO_OR_BEFORE,
40 GTK_TREE_VIEW_DROP_INTO_OR_AFTER
41 } GtkTreeViewDropPosition;
43 #define GTK_TYPE_TREE_VIEW (gtk_tree_view_get_type ())
44 #define GTK_TREE_VIEW(obj) (GTK_CHECK_CAST ((obj), GTK_TYPE_TREE_VIEW, GtkTreeView))
45 #define GTK_TREE_VIEW_CLASS(klass) (GTK_CHECK_CLASS_CAST ((klass), GTK_TYPE_TREE_VIEW, GtkTreeViewClass))
46 #define GTK_IS_TREE_VIEW(obj) (GTK_CHECK_TYPE ((obj), GTK_TYPE_TREE_VIEW))
47 #define GTK_IS_TREE_VIEW_CLASS(klass) (GTK_CHECK_CLASS_TYPE ((obj), GTK_TYPE_TREE_VIEW))
48 #define GTK_TREE_VIEW_GET_CLASS(obj) (GTK_CHECK_GET_CLASS ((obj), GTK_TYPE_TREE_VIEW, GtkTreeViewClass))
50 typedef struct _GtkTreeView GtkTreeView;
51 typedef struct _GtkTreeViewClass GtkTreeViewClass;
52 typedef struct _GtkTreeViewPrivate GtkTreeViewPrivate;
53 typedef struct _GtkTreeSelection GtkTreeSelection;
54 typedef struct _GtkTreeSelectionClass GtkTreeSelectionClass;
60 GtkTreeViewPrivate *priv;
63 struct _GtkTreeViewClass
65 GtkContainerClass parent_class;
67 void (* set_scroll_adjustments) (GtkTreeView *tree_view,
68 GtkAdjustment *hadjustment,
69 GtkAdjustment *vadjustment);
70 void (* row_activated) (GtkTreeView *tree_view,
72 GtkTreeViewColumn *column);
73 gboolean (* test_expand_row) (GtkTreeView *tree_view,
76 gboolean (* test_collapse_row) (GtkTreeView *tree_view,
79 void (* row_expanded) (GtkTreeView *tree_view,
82 void (* row_collapsed) (GtkTreeView *tree_view,
85 void (* columns_changed) (GtkTreeView *tree_view);
87 /* Key Binding signals */
88 void (* begin_extended_selection) (GtkTreeView *tree_view);
89 void (* end_extended_selection) (GtkTreeView *tree_view);
90 void (* begin_free_motion) (GtkTreeView *tree_view);
91 void (* end_free_motion) (GtkTreeView *tree_view);
92 void (* move_cursor) (GtkTreeView *tree_view,
95 void (* select_cursor_row) (GtkTreeView *tree_view);
96 void (* toggle_cursor_row) (GtkTreeView *tree_view);
97 void (* expand_collapse_cursor_row) (GtkTreeView *tree_view,
101 void (* select_cursor_parent) (GtkTreeView *tree_view);
105 typedef gboolean (* GtkTreeViewColumnDropFunc) (GtkTreeView *tree_view,
106 GtkTreeViewColumn *column,
107 GtkTreeViewColumn *prev_column,
108 GtkTreeViewColumn *next_column,
110 typedef gboolean (* GtkTreeViewDraggableFunc) (GtkTreeView *tree_view,
111 GdkDragContext *context,
114 typedef void (* GtkTreeViewMappingFunc) (GtkTreeView *tree_view,
117 typedef gboolean (* GtkTreeViewDroppableFunc) (GtkTreeView *tree_view,
118 GdkDragContext *context,
120 GtkTreeViewDropPosition *pos,
125 GtkType gtk_tree_view_get_type (void);
126 GtkWidget *gtk_tree_view_new (void);
127 GtkWidget *gtk_tree_view_new_with_model (GtkTreeModel *model);
130 GtkTreeModel *gtk_tree_view_get_model (GtkTreeView *tree_view);
131 void gtk_tree_view_set_model (GtkTreeView *tree_view,
132 GtkTreeModel *model);
133 GtkTreeSelection *gtk_tree_view_get_selection (GtkTreeView *tree_view);
134 GtkAdjustment *gtk_tree_view_get_hadjustment (GtkTreeView *tree_view);
135 void gtk_tree_view_set_hadjustment (GtkTreeView *tree_view,
136 GtkAdjustment *adjustment);
137 GtkAdjustment *gtk_tree_view_get_vadjustment (GtkTreeView *tree_view);
138 void gtk_tree_view_set_vadjustment (GtkTreeView *tree_view,
139 GtkAdjustment *adjustment);
140 gboolean gtk_tree_view_get_headers_visible (GtkTreeView *tree_view);
141 void gtk_tree_view_set_headers_visible (GtkTreeView *tree_view,
142 gboolean headers_visible);
143 void gtk_tree_view_columns_autosize (GtkTreeView *tree_view);
144 void gtk_tree_view_set_headers_clickable (GtkTreeView *tree_view,
146 void gtk_tree_view_set_rules_hint (GtkTreeView *tree_view,
148 gboolean gtk_tree_view_get_rules_hint (GtkTreeView *tree_view);
150 /* Column funtions */
151 gint gtk_tree_view_append_column (GtkTreeView *tree_view,
152 GtkTreeViewColumn *column);
153 gint gtk_tree_view_remove_column (GtkTreeView *tree_view,
154 GtkTreeViewColumn *column);
155 gint gtk_tree_view_insert_column (GtkTreeView *tree_view,
156 GtkTreeViewColumn *column,
158 gint gtk_tree_view_insert_column_with_attributes (GtkTreeView *tree_view,
161 GtkCellRenderer *cell,
163 gint gtk_tree_view_insert_column_with_data_func (GtkTreeView *tree_view,
166 GtkCellRenderer *cell,
167 GtkTreeCellDataFunc func,
169 GDestroyNotify dnotify);
170 GtkTreeViewColumn *gtk_tree_view_get_column (GtkTreeView *tree_view,
172 GList *gtk_tree_view_get_columns (GtkTreeView *tree_view);
173 void gtk_tree_view_move_column_after (GtkTreeView *tree_view,
174 GtkTreeViewColumn *column,
175 GtkTreeViewColumn *base_column);
176 void gtk_tree_view_set_expander_column (GtkTreeView *tree_view,
178 gint gtk_tree_view_get_expander_column (GtkTreeView *tree_view);
179 void gtk_tree_view_set_column_drag_function (GtkTreeView *tree_view,
180 GtkTreeViewColumnDropFunc func,
182 GtkDestroyNotify destroy);
185 void gtk_tree_view_scroll_to_point (GtkTreeView *tree_view,
188 void gtk_tree_view_scroll_to_cell (GtkTreeView *tree_view,
190 GtkTreeViewColumn *column,
193 void gtk_tree_view_row_activated (GtkTreeView *tree_view,
195 GtkTreeViewColumn *column);
196 void gtk_tree_view_expand_all (GtkTreeView *tree_view);
197 void gtk_tree_view_collapse_all (GtkTreeView *tree_view);
198 gboolean gtk_tree_view_expand_row (GtkTreeView *tree_view,
201 gboolean gtk_tree_view_collapse_row (GtkTreeView *tree_view,
203 void gtk_tree_view_map_expanded_rows (GtkTreeView *tree_view,
204 GtkTreeViewMappingFunc func,
206 gboolean gtk_tree_view_row_expanded (GtkTreeView *tree_view,
208 void gtk_tree_view_set_reorderable (GtkTreeView *tree_view,
209 gboolean reorderable);
210 gboolean gtk_tree_view_get_reorderable (GtkTreeView *tree_view);
211 void gtk_tree_view_set_cursor (GtkTreeView *tree_view,
215 /* Layout information */
216 gboolean gtk_tree_view_get_path_at_pos (GtkTreeView *tree_view,
221 GtkTreeViewColumn **column,
224 void gtk_tree_view_get_cell_area (GtkTreeView *tree_view,
226 GtkTreeViewColumn *column,
228 void gtk_tree_view_get_background_area (GtkTreeView *tree_view,
230 GtkTreeViewColumn *column,
232 void gtk_tree_view_get_visible_rect (GtkTreeView *tree_view,
233 GdkRectangle *visible_rect);
234 void gtk_tree_view_widget_to_tree_coords (GtkTreeView *tree_view,
239 void gtk_tree_view_tree_to_widget_coords (GtkTreeView *tree_view,
245 /* Drag-and-Drop support */
246 void gtk_tree_view_set_rows_drag_source (GtkTreeView *tree_view,
247 GdkModifierType start_button_mask,
248 const GtkTargetEntry *targets,
250 GdkDragAction actions,
251 GtkTreeViewDraggableFunc row_draggable_func,
253 void gtk_tree_view_set_rows_drag_dest (GtkTreeView *tree_view,
254 const GtkTargetEntry *targets,
256 GdkDragAction actions,
257 GtkTreeViewDroppableFunc location_droppable_func,
259 void gtk_tree_view_unset_rows_drag_source (GtkTreeView *tree_view);
260 void gtk_tree_view_unset_rows_drag_dest (GtkTreeView *tree_view);
263 /* These are useful to implement your own custom stuff. */
264 void gtk_tree_view_set_drag_dest_row (GtkTreeView *tree_view,
266 GtkTreeViewDropPosition pos);
267 void gtk_tree_view_get_drag_dest_row (GtkTreeView *tree_view,
269 GtkTreeViewDropPosition *pos);
270 gboolean gtk_tree_view_get_dest_row_at_pos (GtkTreeView *tree_view,
274 GtkTreeViewDropPosition *pos);
275 GdkPixmap *gtk_tree_view_create_row_drag_icon (GtkTreeView *tree_view,
279 /* This function should really never be used. It is just for use by ATK.
281 typedef void (* GtkTreeDestroyCountFunc) (GtkTreeView *tree_view,
285 void gtk_tree_view_set_destroy_count_func (GtkTreeView *tree_view,
286 GtkTreeDestroyCountFunc func,
288 GtkDestroyNotify destroy);
295 #endif /* __cplusplus */
298 #endif /* __GTK_TREE_VIEW_H__ */