|  |  | 

The View can show all of the model's columns, or just some, and it can show them in various ways. You must provide the TreeModel in the constructor, or with set_model().
Add View columns with append_column(), append_column_editable(), insert_column(), or insert_column_editable().
You can manipulate the selection by obtaining the Gtk::TreeView::Selection from get_selection().
| Public Types | |
| typedef TreeViewColumn | Column | 
| A visible column in a Gtk::TreeView widget. | |
| typedef TreeSelection | Selection | 
| A selection object for Gtk::TreeView. | |
| typedef TreeViewColumn::SlotCellData | SlotCellData | 
| typedef sigc::slot< bool, TreeView*, TreeViewColumn*, TreeViewColumn*, TreeViewColumn* > | SlotColumnDrop | 
| For instance, bool on_column_drop(TreeView*, tree_view, TreeViewColumn* column, TreeViewColumn* prev_column, TreeViewColumn* next_column). | |
| typedef sigc::slot< void, TreeView*, const TreeModel::Path& > | SlotMapping | 
| For example, void on_map_expanded_rows(TreeView* tree_view, const TreeModel::Path& path);. | |
| typedef sigc::slot< bool, const Glib::RefPtr<TreeModel>&, const TreeModel::iterator& > | SlotRowSeparator | 
| For instance, void on_row_separator(const Gtk::TreeModel& model, const Gtk::TreeModel::iterator& iter);. | |
| typedef sigc::slot< bool, const Glib::RefPtr<TreeModel>&, int, const Glib::ustring &, const TreeModel::iterator& > | SlotSearchEqual | 
| void on_search_equal(const Glib::RefPtr<TreeModel>& model, int column, const Glib::ustring& key, const TreeModel::iterator& iter) | |
| typedef sigc::slot< void, Gtk::Widget* > | SlotSearchPosition | 
| void on_search_position(Gtk::Widget* search_dialog) | |
| Public Member Functions | |
| Glib::RefPtr<Gtk::TreeModel> | _get_base_model () | 
| Get the treeview's model, but actually get the child model if it's a TreeModelFilter. | |
| int | append_column (const Glib::ustring& title, CellRenderer& cell) | 
| Creates a View column containing the CellRenderer, and appends it. | |
| template<class ColumnType> | |
| int | append_column (const Glib::ustring& title, const TreeModelColumn<ColumnType>& model_column) | 
| Appends a View column with the appropriate CellRenderer for the Model column. | |
| int | append_column (TreeViewColumn& column) | 
| Appends column to the list of columns. | |
| template<class ColumnType> | |
| int | append_column_editable (const Glib::ustring& title, const TreeModelColumn<ColumnType>& model_column) | 
| Appends a View column with the appropriate CellRenderer for the Model column. | |
| template<class ColumnType> | |
| int | append_column_numeric (const Glib::ustring& title, const TreeModelColumn<ColumnType>& model_column, const Glib::ustring& format) | 
| Like append_column(), but only for numeric types, which will be displayed in the specified format. | |
| template<class ColumnType> | |
| int | append_column_numeric_editable (const Glib::ustring& title, const TreeModelColumn<ColumnType>& model_column, const Glib::ustring& format) | 
| Like append_column_editable(), but only for numeric types, which will be displayed in the specified format. | |
| void | collapse_all () | 
| Recursively collapses all visible, expanded nodes in tree_view . | |
| bool | collapse_row (const TreeModel::Path& path) | 
| Collapses a row (hides its child rows, if they exist). | |
| void | columns_autosize () | 
| Resizes all columns to their optimal width. | |
| Glib::RefPtr<Gdk::Pixmap> | create_row_drag_icon (const TreeModel::Path& path) | 
| Creates a Gdk::Pixmap representation of the row at path . | |
| void | enable_model_drag_dest (Gdk::DragAction actions=Gdk::ACTION_COPY|Gdk::ACTION_MOVE) | 
| Turns the TreeView into a drop destination for automatic DND. | |
| void | enable_model_drag_dest (const ArrayHandle_TargetEntry& targets, Gdk::DragAction actions=Gdk::ACTION_COPY|Gdk::ACTION_MOVE) | 
| Turns the TreeView into a drop destination for automatic DND. | |
| void | enable_model_drag_source (Gdk::ModifierType start_button_mask=Gdk::MODIFIER_MASK, Gdk::DragAction actions=Gdk::ACTION_COPY|Gdk::ACTION_MOVE) | 
| Turns the TreeView into a drag source for automatic DND. | |
| void | enable_model_drag_source (const ArrayHandle_TargetEntry& targets, Gdk::ModifierType start_button_mask=Gdk::MODIFIER_MASK, Gdk::DragAction actions=Gdk::ACTION_COPY|Gdk::ACTION_MOVE) | 
| Turns the TreeView into a drag source for automatic DND. | |
| void | expand_all () | 
| Recursively expands all nodes in the tree_view . | |
| bool | expand_row (const TreeModel::Path& path, bool open_all) | 
| Opens the row so its children are visible. | |
| void | expand_to_path (const TreeModel::Path& path) | 
| Expands the row at path . | |
| void | get_background_area (const TreeModel::Path& path, TreeViewColumn& column, Gdk::Rectangle& rect) const | 
| Fills the bounding rectangle in tree window coordinates for the cell at the row specified by path and the column specified by column . | |
| void | get_background_area (const TreeModel::Path& path, TreeViewColumn& column, Gdk::Rectangle& rect) | 
| Fills the bounding rectangle in tree window coordinates for the cell at the row specified by path and the column specified by column . | |
| Glib::RefPtr<const Gdk::Window> | get_bin_window () const | 
| Returns the window that tree_view renders to. | |
| Glib::RefPtr<Gdk::Window> | get_bin_window () | 
| Returns the window that tree_view renders to. | |
| void | get_cell_area (const TreeModel::Path& path, TreeViewColumn& column, Gdk::Rectangle& rect) const | 
| Fills the bounding rectangle in tree window coordinates for the cell at the row specified by path and the column specified by column . | |
| void | get_cell_area (const TreeModel::Path& path, TreeViewColumn& column, Gdk::Rectangle& rect) | 
| Fills the bounding rectangle in tree window coordinates for the cell at the row specified by path and the column specified by column . | |
| const TreeViewColumn* | get_column (int n) const | 
| Gets the Gtk::TreeViewColumn at the given position in the tree_view. | |
| TreeViewColumn* | get_column (int n) | 
| Gets the Gtk::TreeViewColumn at the given position in the tree_view. | |
| const CellRenderer* | get_column_cell_renderer (int n) const | 
| Gets the CellRenderer for that column. | |
| CellRenderer* | get_column_cell_renderer (int n) | 
| Gets the CellRenderer for that column. | |
| Glib::ListHandle<const TreeViewColumn*> | get_columns () const | 
| Returns a list of all the Gtk::TreeViewColumn s currently in tree_view . | |
| Glib::ListHandle<TreeViewColumn*> | get_columns () | 
| Returns a list of all the Gtk::TreeViewColumn s currently in tree_view . | |
| void | get_cursor (TreeModel::Path& path, TreeViewColumn*& focus_column) | 
| Fills in path and focus_column with the current path and focus column. | |
| bool | get_dest_row_at_pos (int drag_x, int drag_y, TreeModel::Path& path, TreeViewDropPosition& pos) const | 
| Determines the destination row for a given position. | |
| void | get_drag_dest_row (TreeModel::Path& path, TreeViewDropPosition& pos) const | 
| Gets information about the row that is highlighted for feedback. | |
| bool | get_enable_search () const | 
| Returns whether or not the tree allows to start interactive searching by typing in text. | |
| const TreeViewColumn* | get_expander_column () const | 
| Returns the column that is the current expander column. | |
| TreeViewColumn* | get_expander_column () | 
| Returns the column that is the current expander column. | |
| bool | get_fixed_height_mode () const | 
| Returns whether fixed height mode is turned on for tree_view . | |
| const Adjustment* | get_hadjustment () const | 
| Gets the Gtk::Adjustment currently being used for the horizontal aspect. | |
| Adjustment* | get_hadjustment () | 
| Gets the Gtk::Adjustment currently being used for the horizontal aspect. | |
| bool | get_headers_clickable () const | 
| bool | get_headers_visible () const | 
| Returns trueif the headers on the tree_view are visible. | |
| bool | get_hover_expand () const | 
| Returns whether hover expansion mode is turned on for tree_view . | |
| bool | get_hover_selection () const | 
| Returns whether hover selection mode is turned on for tree_view . | |
| Glib::RefPtr<const TreeModel> | get_model () const | 
| Returns the model the Gtk::TreeView is based on. | |
| Glib::RefPtr<TreeModel> | get_model () | 
| Returns the model the Gtk::TreeView is based on. | |
| bool | get_path_at_pos (int x, int y, TreeModel::Path& path, TreeViewColumn*& column, int& cell_x, int& cell_y) const | 
| Finds the path at the point (x, y), relative to widget coordinates. | |
| bool | get_path_at_pos (int x, int y, TreeModel::Path& path, TreeViewColumn*& column, int& cell_x, int& cell_y) | 
| bool | get_reorderable () const | 
| Retrieves whether the user can reorder the tree via drag-and-drop. | |
| bool | get_rules_hint () const | 
| Gets the setting set by set_rules_hint(). | |
| int | get_search_column () const | 
| Gets the column searched on by the interactive search code. | |
| const Entry* | get_search_entry () const | 
| Entry* | get_search_entry () | 
| Glib::RefPtr<const TreeSelection> | get_selection () const | 
| Gets the Gtk::TreeSelection associated with tree_view . | |
| Glib::RefPtr<TreeSelection> | get_selection () | 
| Gets the Gtk::TreeSelection associated with tree_view . | |
| const Adjustment* | get_vadjustment () const | 
| Gets the Gtk::Adjustment currently being used for the vertical aspect. | |
| Adjustment* | get_vadjustment () | 
| Gets the Gtk::Adjustment currently being used for the vertical aspect. | |
| bool | get_visible_range (TreeModel::Path& start_path, TreeModel::Path& end_path) const | 
| void | get_visible_rect (Gdk::Rectangle& visible_rect) const | 
| Fills visible_rect with the currently-visible region of the buffer, in tree coordinates. | |
| void | get_visible_rect (Gdk::Rectangle& visible_rect) | 
| Fills visible_rect with the currently-visible region of the buffer, in tree coordinates. | |
| const GtkTreeView* | gobj () const | 
| Provides access to the underlying C GtkObject. | |
| GtkTreeView* | gobj () | 
| Provides access to the underlying C GtkObject. | |
| template<class ColumnType> | |
| int | insert_column (const Glib::ustring& title, const TreeModelColumn<ColumnType>& model_column, int position) | 
| Inserts a View column with the appropriate CellRenderer for the Model column. | |
| int | insert_column (const Glib::ustring& title, CellRenderer& cell, int position) | 
| Creates a View column containing the CellRenderer, and inserts it. | |
| int | insert_column (TreeViewColumn& column, int position) | 
| This inserts the column into the tree_view at position . | |
| template<class ColumnType> | |
| int | insert_column_editable (const Glib::ustring& title, const TreeModelColumn<ColumnType>& model_column, int position) | 
| Inserts a View column with the appropriate CellRenderer for the Model column. | |
| int | insert_column_with_data_func (int position, const Glib::ustring& title, CellRenderer& cell, const SlotCellData& slot) | 
| Inserts a new column into the TreeView with the given cell renderer and a SlotCellData to set cell renderer attributes (normally using data from the model). | |
| void | map_expanded_rows (const SlotMapping& slot) | 
| Calls the callback slot on all expanded rows. | |
| void | move_column_after (TreeViewColumn& column, TreeViewColumn& base_column) | 
| Moves column to be after to base_column . | |
| void | move_column_to_start (TreeViewColumn& column) | 
| This method moves column to the first position in the view. | |
| Glib::PropertyProxy_ReadOnly< bool > | property_enable_search () const | 
| View allows user to search through columns interactively. | |
| Glib::PropertyProxy<bool> | property_enable_search () | 
| View allows user to search through columns interactively. | |
| Glib::PropertyProxy_ReadOnly< TreeViewColumn* > | property_expander_column () const | 
| Set the column for the expander column. | |
| Glib::PropertyProxy<TreeViewColumn*> | property_expander_column () | 
| Set the column for the expander column. | |
| Glib::PropertyProxy_ReadOnly< bool > | property_fixed_height_mode () const | 
| Speeds up GtkTreeView by assuming that all rows have the same height. | |
| Glib::PropertyProxy<bool> | property_fixed_height_mode () | 
| Speeds up GtkTreeView by assuming that all rows have the same height. | |
| Glib::PropertyProxy_ReadOnly< Adjustment* > | property_hadjustment () const | 
| Horizontal Adjustment for the widget. | |
| Glib::PropertyProxy<Adjustment*> | property_hadjustment () | 
| Horizontal Adjustment for the widget. | |
| Glib::PropertyProxy_ReadOnly< bool > | property_headers_clickable () const | 
| Column headers respond to click events. | |
| Glib::PropertyProxy<bool> | property_headers_clickable () | 
| Column headers respond to click events. | |
| Glib::PropertyProxy_ReadOnly< bool > | property_headers_visible () const | 
| Show the column header buttons. | |
| Glib::PropertyProxy<bool> | property_headers_visible () | 
| Show the column header buttons. | |
| Glib::PropertyProxy_ReadOnly< bool > | property_hover_expand () const | 
| Whether rows should be expanded/collapsed when the pointer moves over them. | |
| Glib::PropertyProxy<bool> | property_hover_expand () | 
| Whether rows should be expanded/collapsed when the pointer moves over them. | |
| Glib::PropertyProxy_ReadOnly< bool > | property_hover_selection () const | 
| Whether the selection should follow the pointer. | |
| Glib::PropertyProxy<bool> | property_hover_selection () | 
| Whether the selection should follow the pointer. | |
| Glib::PropertyProxy_ReadOnly< Glib::RefPtr<TreeModel >> | property_model () const | 
| The model for the tree view. | |
| Glib::PropertyProxy< Glib::RefPtr< TreeModel > > | property_model () | 
| The model for the tree view. | |
| Glib::PropertyProxy_ReadOnly< bool > | property_reorderable () const | 
| View is reorderable. | |
| Glib::PropertyProxy<bool> | property_reorderable () | 
| View is reorderable. | |
| Glib::PropertyProxy_ReadOnly< bool > | property_rules_hint () const | 
| Set a hint to the theme engine to draw rows in alternating colors. | |
| Glib::PropertyProxy<bool> | property_rules_hint () | 
| Set a hint to the theme engine to draw rows in alternating colors. | |
| Glib::PropertyProxy_ReadOnly< int > | property_search_column () const | 
| Model column to search through when searching through code. | |
| Glib::PropertyProxy<int> | property_search_column () | 
| Model column to search through when searching through code. | |
| Glib::PropertyProxy_ReadOnly< Adjustment* > | property_vadjustment () const | 
| Vertical Adjustment for the widget. | |
| Glib::PropertyProxy<Adjustment*> | property_vadjustment () | 
| Vertical Adjustment for the widget. | |
| void | remove_all_columns () | 
| Removes all View columns. | |
| int | remove_column (TreeViewColumn& column) | 
| Removes column from tree_view . | |
| void | reset_expander_column () | 
| This method resets the expander arrow to the default - the first visible column. | |
| void | row_activated (const TreeModel::Path& path, TreeViewColumn& column) | 
| Activates the cell determined by path and column . | |
| bool | row_expanded (const TreeModel::Path& path) | 
| Returns trueif the node pointed to by path is expanded in tree_view . | |
| void | scroll_to_cell (const TreeModel::Path& path, TreeViewColumn& column) | 
| Moves the alignments of tree view to the position specified by column and path. | |
| void | scroll_to_cell (const TreeModel::Path& path, TreeViewColumn& column, float row_align, float col_align) | 
| Moves the alignments of tree view to the position specified by column and path. | |
| void | scroll_to_column (TreeViewColumn& column) | 
| Moves the alignments of tree view to the position specified by column. | |
| void | scroll_to_column (TreeViewColumn& column, float col_align) | 
| Moves the alignments of tree view to the position specified by column. | |
| void | scroll_to_point (int tree_x, int tree_y) | 
| Scrolls the tree view such that the top-left corner of the visible area is tree_x , tree_y , where tree_x and tree_y are specified in tree window coordinates. | |
| void | scroll_to_row (const TreeModel::Path& path) | 
| Moves the alignments of tree view to the position specified by path. | |
| void | scroll_to_row (const TreeModel::Path& path, float row_align) | 
| Moves the alignments of tree view to the position specified by path. | |
| void | set_column_drag_function (const SlotColumnDrop& slot) | 
| Sets a callback slot for determining where a column may be dropped when dragged. | |
| void | set_cursor (const TreeModel::Path& path) | 
| Sets the current keyboard focus to be at path , and selects it. | |
| void | set_cursor (const TreeModel::Path& path, TreeViewColumn& focus_column, CellRenderer& focus_cell, bool start_editing=false) | 
| Sets the current keyboard focus to be at path , and selects it. | |
| void | set_cursor (const TreeModel::Path& path, TreeViewColumn& focus_column, bool start_editing=false) | 
| Sets the current keyboard focus to be at path , and selects it. | |
| void | set_drag_dest_row (const TreeModel::Path& path, TreeViewDropPosition pos) | 
| Sets the row that is highlighted for feedback. | |
| void | set_enable_search (bool enable_search=true) | 
| If enable_search is set, then the user can type in text to search through the tree interactively (this is sometimes called "typeahead find"). | |
| void | set_expander_column (TreeViewColumn& column) | 
| Sets the column to draw the expander arrow at. | |
| void | set_fixed_height_mode (bool enable=true) | 
| Enables or disables the fixed height mode of tree_view . | |
| void | set_hadjustment (Adjustment& adjustment) | 
| Sets the Gtk::Adjustment for the current horizontal aspect. | |
| void | set_headers_clickable (bool setting=true) | 
| Allow the column title buttons to be clicked. | |
| void | set_headers_visible (bool headers_visible) | 
| Sets the visibility state of the headers. | |
| void | set_hover_expand (bool expand=true) | 
| Enables of disables the hover expansion mode of tree_view . | |
| void | set_hover_selection (bool hover=true) | 
| Enables of disables the hover selection mode of tree_view . | |
| void | set_model (const Glib::RefPtr<TreeModel>& model) | 
| Sets the model for a Gtk::TreeView. | |
| void | set_reorderable (bool reorderable=true) | 
| This function is a convenience function to allow you to reorder models that support the Gtk::DragSourceIface and the Gtk::DragDestIface. | |
| void | set_row_separator_func (const SlotRowSeparator& slot) | 
| void | set_rules_hint (bool setting=true) | 
| This function tells GTK+ that the user interface for your application requires users to read across tree rows and associate cells with one another. | |
| void | set_search_column (int column) | 
| Sets column as the column where the interactive search code should search in. | |
| void | set_search_column (const TreeModelColumnBase& column) | 
| Sets column as the column where the interactive search code should search in. | |
| void | set_search_entry (Entry& entry) | 
| void | set_search_equal_func (const SlotSearchEqual& slot) | 
| Sets the compare function for the interactive search capabilities. | |
| void | set_search_position_func (const SlotSearchPosition& slot) | 
| void | set_vadjustment (Adjustment& adjustment) | 
| Sets the Gtk::Adjustment for the current vertical aspect. | |
| Glib::SignalProxy0<void> | signal_columns_changed () | 
| Glib::SignalProxy0<void> | signal_cursor_changed () | 
| Glib::SignalProxy2< void, const TreeModel::Path&, TreeViewColumn* > | signal_row_activated () | 
| Glib::SignalProxy2< void, const TreeModel::iterator&, const TreeModel::Path& > | signal_row_collapsed () | 
| Glib::SignalProxy2< void, const TreeModel::iterator&, const TreeModel::Path& > | signal_row_expanded () | 
| Glib::SignalProxy2< void, Adjustment*, Adjustment* > | signal_set_scroll_adjustments () | 
| Glib::SignalProxy2< bool, const TreeModel::iterator&, const TreeModel::Path& > | signal_test_collapse_row () | 
| Glib::SignalProxy2< bool, const TreeModel::iterator&, const TreeModel::Path& > | signal_test_expand_row () | 
| void | tree_to_widget_coords (int tx, int ty, int& wx, int& wy) const | 
| Converts tree coordinates (coordinates in full scrollable area of the tree) to widget coordinates. | |
| void | tree_to_widget_coords (int tx, int ty, int& wx, int& wy) | 
| Converts tree coordinates (coordinates in full scrollable area of the tree) to widget coordinates. | |
| TreeView (const Glib::RefPtr<TreeModel>& model) | |
| Constructor that binds to a TreeModel. | |
| TreeView () | |
| Default constructor. | |
| void | unset_column_drag_function () | 
| See set_column_drag_function(). | |
| void | unset_hadjustment () | 
| This method removes the hadjustment. | |
| void | unset_model () | 
| Remove the model from the TreeView. | |
| void | unset_rows_drag_dest () | 
| Undoes the effect of enable_model_drag_dest(). | |
| void | unset_rows_drag_source () | 
| Undoes the effect of enable_model_drag_source(). | |
| void | unset_vadjustment () | 
| This method removes the vadjustment. | |
| void | widget_to_tree_coords (int wx, int wy, int& tx, int& ty) const | 
| Converts widget coordinates to coordinates for the tree window (the full scrollable area of the tree). | |
| void | widget_to_tree_coords (int wx, int wy, int& tx, int& ty) | 
| Converts widget coordinates to coordinates for the tree window (the full scrollable area of the tree). | |
| virtual | ~TreeView () | 
| Protected Member Functions | |
| virtual void | on_columns_changed () | 
| virtual void | on_cursor_changed () | 
| virtual void | on_row_activated (const TreeModel::Path& path, TreeViewColumn* column) | 
| virtual void | on_row_collapsed (const TreeModel::iterator& iter, const TreeModel::Path& path) | 
| virtual void | on_row_expanded (const TreeModel::iterator& iter, const TreeModel::Path& path) | 
| virtual void | on_set_scroll_adjustments (Adjustment* hadjustment, Adjustment* vadjustment) | 
| virtual bool | on_test_collapse_row (const TreeModel::iterator& iter, const TreeModel::Path& path) | 
| virtual bool | on_test_expand_row (const TreeModel::iterator& iter, const TreeModel::Path& path) | 
| Related Functions | |
| (Note that these are not member functions.) | |
| Gtk::TreeView* | wrap (GtkTreeView* object, bool take_copy=false) | 
| 
 | 
| A visible column in a Gtk::TreeView widget. 
 | 
| 
 | 
| A selection object for Gtk::TreeView. 
 | 
| 
 | 
| 
 | 
| 
 | 
| For instance, bool on_column_drop(TreeView*, tree_view, TreeViewColumn* column, TreeViewColumn* prev_column, TreeViewColumn* next_column). This function is called on every column pair in turn at the beginning of a column drag to determine where a drop can take place. The arguments passed to the function are: the tree_view, the view Column being dragged, and the two view Columns determining the drop spot. If either of the view Column arguments for the drop spot are 0, then they indicate an edge. | 
| 
 | 
| For example, void on_map_expanded_rows(TreeView* tree_view, const TreeModel::Path& path);. 
 | 
| 
 | 
| For instance, void on_row_separator(const Gtk::TreeModel& model, const Gtk::TreeModel::iterator& iter);. 
 | 
| 
 | 
| void on_search_equal(const Glib::RefPtr<TreeModel>& model, int column, const Glib::ustring& key, const TreeModel::iterator& iter) 
 | 
| 
 | 
| void on_search_position(Gtk::Widget* search_dialog) 
 | 
| 
 | 
| 
 | 
| 
 | 
| Default constructor. 
 | 
| 
 | 
| Constructor that binds to a TreeModel. 
 | 
| 
 | 
| Get the treeview's model, but actually get the child model if it's a TreeModelFilter. 
 | 
| 
 | ||||||||||||
| Creates a View column containing the CellRenderer, and appends it. 
 | 
| 
 | ||||||||||||||||
| Appends a View column with the appropriate CellRenderer for the Model column. The CellRenderer can only be created automatically for some basic column types, such as Glib::ustring, int, double, bool, and Gdk::Pixbuf. If the type is not supported then the following warning will be shown: GLib-GObject-WARNING**: unable to set property `text' of type `gchararray' from value of type `glibmm__CustomBoxed_t'. If the default formatting is not sufficient, or the numeric type is not supported, then you could use append_column_numeric(). Or you could create the TreeView::Column and/or CellRenderer manually and use TreeViewColumn::set_cell_data_func() to provide a callback that converts the model value into a string representation with . 
 
 
 | 
| 
 | 
| Appends column to the list of columns. If tree_view has "fixed_height" mode enabled, then column must have its "sizing" property set to be GTK_TREE_VIEW_COLUMN_FIXED. 
 
 | 
| 
 | ||||||||||||||||
| Appends a View column with the appropriate CellRenderer for the Model column. The compiler will attempt to instantiate appropriate template code to automatically store user changes in the model. To intercept the user's change and implement non-default logic, or if the compiler can't instantiate appropriate code for your model type, you could use append_column() and connect a signal handler to the CellRenderer. 
 
 
 
 | 
| 
 | ||||||||||||||||||||
| Like append_column(), but only for numeric types, which will be displayed in the specified format. This convenience template uses TreeView::Column::set_cell_data_func(), so the numeric formatting will be deactivated if you specify your own cell_data callback by calling set_cell_data_func() again. 
 
 
 | 
| 
 | ||||||||||||||||||||
| Like append_column_editable(), but only for numeric types, which will be displayed in the specified format. This convenience template uses TreeView::Column::set_cell_data_func(), so the numeric formatting will be deactivated if you specify your own cell_data callback by calling set_cell_data_func() again. Note that the user's input will be interpreted as decimal (base 10), regardless of the format. 
 
 
 | 
| 
 | 
| Recursively collapses all visible, expanded nodes in tree_view . 
 | 
| 
 | 
| Collapses a row (hides its child rows, if they exist). 
 
 
 | 
| 
 | 
| Resizes all columns to their optimal width. Only works after the treeview has been realized. | 
| 
 | 
| Creates a Gdk::Pixmap representation of the row at path . This image is used for a drag icon. 
 
 | 
| 
 | 
| Turns the TreeView into a drop destination for automatic DND. This uses the default "GTK_TREE_MODEL_ROW" target, which the TreeView can handle automatically. 
 
 | 
| 
 | ||||||||||||
| Turns the TreeView into a drop destination for automatic DND. 
 
 | 
| 
 | ||||||||||||
| Turns the TreeView into a drag source for automatic DND. 
 
 | 
| 
 | ||||||||||||||||
| Turns the TreeView into a drag source for automatic DND. 
 
 | 
| 
 | 
| Recursively expands all nodes in the tree_view . 
 | 
| 
 | ||||||||||||
| Opens the row so its children are visible. 
 
 
 | 
| 
 | 
| Expands the row at path . This will also expand all parent rows of path as necessary. 
 
 | 
| 
 | ||||||||||||||||
| Fills the bounding rectangle in tree window coordinates for the cell at the row specified by path and the column specified by column . The returned rectangle is equivalent to the background_area passed to Gtk::CellRenderer::render(). These background areas tile to cover the entire tree window (except for the area used for header buttons). Contrast with the cell_area , returned by get_cell_area(), which returns only the cell itself, excluding surrounding borders and the tree expander area. 
 | 
| 
 | ||||||||||||||||
| Fills the bounding rectangle in tree window coordinates for the cell at the row specified by path and the column specified by column . The returned rectangle is equivalent to the background_area passed to Gtk::CellRenderer::render(). These background areas tile to cover the entire tree window (except for the area used for header buttons). Contrast with the cell_area , returned by get_cell_area(), which returns only the cell itself, excluding surrounding borders and the tree expander area. 
 
 | 
| 
 | 
| Returns the window that tree_view renders to. 
This is used primarily to compare to  
 | 
| 
 | 
| Returns the window that tree_view renders to. 
This is used primarily to compare to  
 | 
| 
 | ||||||||||||||||
| Fills the bounding rectangle in tree window coordinates for the cell at the row specified by path and the column specified by column . If path points to a path not currently displayed, the y and height fields of the rectangle will be filled with 0. The sum of all cell rects does not cover the entire tree; there are extra pixels in between rows, for example. The returned rectangle is equivalent to the cell_area passed to Gtk::CellRenderer::render(). This function is only valid if tree_view is realized. 
 | 
| 
 | ||||||||||||||||
| Fills the bounding rectangle in tree window coordinates for the cell at the row specified by path and the column specified by column . If path points to a path not currently displayed, the y and height fields of the rectangle will be filled with 0. The sum of all cell rects does not cover the entire tree; there are extra pixels in between rows, for example. The returned rectangle is equivalent to the cell_area passed to Gtk::CellRenderer::render(). This function is only valid if tree_view is realized. 
 
 | 
| 
 | 
| Gets the Gtk::TreeViewColumn at the given position in the tree_view. 
 
 
 | 
| 
 | 
| Gets the Gtk::TreeViewColumn at the given position in the tree_view. 
 
 
 | 
| 
 | 
| Gets the CellRenderer for that column. You should dynamic_cast<> to the expected derived CellRenderer type. This assumes that the TreeViewColumn contains only one CellRenderer. 
 
 
 | 
| 
 | 
| Gets the CellRenderer for that column. You should dynamic_cast<> to the expected derived CellRenderer type. This assumes that the TreeViewColumn contains only one CellRenderer. 
 
 
 | 
| 
 | 
| Returns a list of all the Gtk::TreeViewColumn s currently in tree_view . 
 
 | 
| 
 | 
| Returns a list of all the Gtk::TreeViewColumn s currently in tree_view . 
 
 | 
| 
 | ||||||||||||
| Fills in path and focus_column with the current path and focus column. 
 
 | 
| 
 | ||||||||||||||||||||
| Determines the destination row for a given position. 
 
 | 
| 
 | ||||||||||||
| Gets information about the row that is highlighted for feedback. 
 
 | 
| 
 | 
| Returns whether or not the tree allows to start interactive searching by typing in text. 
 
 | 
| 
 | 
| Returns the column that is the current expander column. This column has the expander arrow drawn next to it. 
 | 
| 
 | 
| Returns the column that is the current expander column. This column has the expander arrow drawn next to it. 
 | 
| 
 | 
| Returns whether fixed height mode is turned on for tree_view . 
 
 | 
| 
 | 
| Gets the Gtk::Adjustment currently being used for the horizontal aspect. 
 
 | 
| 
 | 
| Gets the Gtk::Adjustment currently being used for the horizontal aspect. 
 
 | 
| 
 | 
| 
 | 
| 
 | 
| 
Returns  
 
 | 
| 
 | 
| Returns whether hover expansion mode is turned on for tree_view . 
 
 | 
| 
 | 
| Returns whether hover selection mode is turned on for tree_view . 
 
 | 
| 
 | 
| Returns the model the Gtk::TreeView is based on. 
Returns  
 | 
| 
 | 
| Returns the model the Gtk::TreeView is based on. 
Returns  
 | 
| 
 | ||||||||||||||||||||||||||||
| Finds the path at the point (x, y), relative to widget coordinates. It is primarily for things like popup menus. 
 
 
 | 
| 
 | ||||||||||||||||||||||||||||
| 
 
 | 
| 
 | 
| Retrieves whether the user can reorder the tree via drag-and-drop. See set_reorderable(). 
 | 
| 
 | 
| Gets the setting set by set_rules_hint(). 
 
 | 
| 
 | 
| Gets the column searched on by the interactive search code. 
 
 | 
| 
 | 
| 
 | 
| 
 | 
| 
 | 
| 
 | 
| Gets the Gtk::TreeSelection associated with tree_view . 
 
 | 
| 
 | 
| Gets the Gtk::TreeSelection associated with tree_view . 
 
 | 
| 
 | 
| Gets the Gtk::Adjustment currently being used for the vertical aspect. 
 
 | 
| 
 | 
| Gets the Gtk::Adjustment currently being used for the vertical aspect. 
 
 | 
| 
 | ||||||||||||
| 
 | 
| 
 | 
| Fills visible_rect with the currently-visible region of the buffer, in tree coordinates. Convert to widget coordinates with tree_to_widget_coords(). Tree coordinates start at 0,0 for row 0 of the tree, and cover the entire scrollable area of the tree. 
 | 
| 
 | 
| Fills visible_rect with the currently-visible region of the buffer, in tree coordinates. Convert to widget coordinates with tree_to_widget_coords(). Tree coordinates start at 0,0 for row 0 of the tree, and cover the entire scrollable area of the tree. 
 
 | 
| 
 | 
| Provides access to the underlying C GtkObject. 
 Reimplemented from Gtk::Container. | 
| 
 | 
| Provides access to the underlying C GtkObject. 
 Reimplemented from Gtk::Container. | 
| 
 | ||||||||||||||||||||
| Inserts a View column with the appropriate CellRenderer for the Model column. 
 
 
 | 
| 
 | ||||||||||||||||
| Creates a View column containing the CellRenderer, and inserts it. 
 
 
 | 
| 
 | ||||||||||||
| This inserts the column into the tree_view at position . If position is -1, then the column is inserted at the end. If tree_view has "fixed_height" mode enabled, then column must have its "sizing" property set to be GTK_TREE_VIEW_COLUMN_FIXED. 
 
 | 
| 
 | ||||||||||||||||||||
| Inserts a View column with the appropriate CellRenderer for the Model column. The compiler will attempt to instantiate appropriate template code to automatically store user changes in the model. To intercept the user's change and implement non-default logic, or if the compiler can't instantiate appropriate code for your model type, you should use append_column() and connect a signal handler to the CellRenderer. 
 
 
 | 
| 
 | ||||||||||||||||||||
| Inserts a new column into the TreeView with the given cell renderer and a SlotCellData to set cell renderer attributes (normally using data from the model). 
 
 
 | 
| 
 | 
| Calls the callback slot on all expanded rows. 
 
 | 
| 
 | ||||||||||||
| Moves column to be after to base_column . See also move_column_to_start(). 
 | 
| 
 | 
| This method moves column to the first position in the view. 
 
 | 
| 
 | 
| 
 | 
| 
 | 
| 
 | 
| 
 | ||||||||||||
| 
 | 
| 
 | ||||||||||||
| 
 | 
| 
 | ||||||||||||
| 
 | 
| 
 | ||||||||||||
| 
 | 
| 
 | ||||||||||||
| 
 | 
| 
 | ||||||||||||
| 
 | 
| 
 | 
| View allows user to search through columns interactively. You rarely need to use properties because there are get_ and set_ methods for almost all of them. 
 | 
| 
 | 
| View allows user to search through columns interactively. You rarely need to use properties because there are get_ and set_ methods for almost all of them. 
 | 
| 
 | 
| Set the column for the expander column. You rarely need to use properties because there are get_ and set_ methods for almost all of them. 
 | 
| 
 | 
| Set the column for the expander column. You rarely need to use properties because there are get_ and set_ methods for almost all of them. 
 | 
| 
 | 
| Speeds up GtkTreeView by assuming that all rows have the same height. You rarely need to use properties because there are get_ and set_ methods for almost all of them. 
 | 
| 
 | 
| Speeds up GtkTreeView by assuming that all rows have the same height. You rarely need to use properties because there are get_ and set_ methods for almost all of them. 
 | 
| 
 | 
| Horizontal Adjustment for the widget. You rarely need to use properties because there are get_ and set_ methods for almost all of them. 
 | 
| 
 | 
| Horizontal Adjustment for the widget. You rarely need to use properties because there are get_ and set_ methods for almost all of them. 
 | 
| 
 | 
| Column headers respond to click events. You rarely need to use properties because there are get_ and set_ methods for almost all of them. 
 | 
| 
 | 
| Column headers respond to click events. You rarely need to use properties because there are get_ and set_ methods for almost all of them. 
 | 
| 
 | 
| Show the column header buttons. You rarely need to use properties because there are get_ and set_ methods for almost all of them. 
 | 
| 
 | 
| Show the column header buttons. You rarely need to use properties because there are get_ and set_ methods for almost all of them. 
 | 
| 
 | 
| Whether rows should be expanded/collapsed when the pointer moves over them. You rarely need to use properties because there are get_ and set_ methods for almost all of them. 
 | 
| 
 | 
| Whether rows should be expanded/collapsed when the pointer moves over them. You rarely need to use properties because there are get_ and set_ methods for almost all of them. 
 | 
| 
 | 
| Whether the selection should follow the pointer. You rarely need to use properties because there are get_ and set_ methods for almost all of them. 
 | 
| 
 | 
| Whether the selection should follow the pointer. You rarely need to use properties because there are get_ and set_ methods for almost all of them. 
 | 
| 
 | 
| The model for the tree view. You rarely need to use properties because there are get_ and set_ methods for almost all of them. 
 | 
| 
 | 
| The model for the tree view. You rarely need to use properties because there are get_ and set_ methods for almost all of them. 
 | 
| 
 | 
| View is reorderable. You rarely need to use properties because there are get_ and set_ methods for almost all of them. 
 | 
| 
 | 
| View is reorderable. You rarely need to use properties because there are get_ and set_ methods for almost all of them. 
 | 
| 
 | 
| Set a hint to the theme engine to draw rows in alternating colors. You rarely need to use properties because there are get_ and set_ methods for almost all of them. 
 | 
| 
 | 
| Set a hint to the theme engine to draw rows in alternating colors. You rarely need to use properties because there are get_ and set_ methods for almost all of them. 
 | 
| 
 | 
| Model column to search through when searching through code. You rarely need to use properties because there are get_ and set_ methods for almost all of them. 
 | 
| 
 | 
| Model column to search through when searching through code. You rarely need to use properties because there are get_ and set_ methods for almost all of them. 
 | 
| 
 | 
| Vertical Adjustment for the widget. You rarely need to use properties because there are get_ and set_ methods for almost all of them. 
 | 
| 
 | 
| Vertical Adjustment for the widget. You rarely need to use properties because there are get_ and set_ methods for almost all of them. 
 | 
| 
 | 
| Removes all View columns. 
 | 
| 
 | 
| Removes column from tree_view . 
 
 
 | 
| 
 | 
| This method resets the expander arrow to the default - the first visible column. 
 
 | 
| 
 | ||||||||||||
| Activates the cell determined by path and column . 
 
 | 
| 
 | 
| 
Returns  
 
 
 | 
| 
 | ||||||||||||
| Moves the alignments of tree view to the position specified by column and path. The tree does the minimum amount of work to scroll the cell onto the screen. This means that the cell will be scrolled to the edge closest to it's current position. If the cell is currently visible on the screen, nothing is done. This function only works if the model is set, and path is a valid row on the model. If the model changes before the tree_view is realized, the centered path will be modified to reflect this change. 
 
 | 
| 
 | ||||||||||||||||||||
| Moves the alignments of tree view to the position specified by column and path. row_align determines where the row is placed, and col_align determines where column is placed. Both are expected to be between 0.0 and 1.0. 0.0 means left/top alignment, 1.0 means right/bottom alignment, 0.5 means center. This function only works if the model is set, and path is a valid row on the model. If the model changes before the tree view is realized, the centered path will be modified to reflect this change. 
 
 | 
| 
 | 
| Moves the alignments of tree view to the position specified by column. The tree does the minimum amount of work to scroll the column onto the screen. This means that the column will be scrolled to the edge closest to it's current position. If the column is currently visible on the screen, nothing is done. This function only works if the model is set. If the model changes before the tree view is realized, the centered path will be modified to reflect this change. 
 
 | 
| 
 | ||||||||||||
| Moves the alignments of tree view to the position specified by column. col_align determines where the column is placed, and is expected to be between 0.0 and 1.0. 0.0 means left alignment, 1.0 means right alignment, 0.5 means center. This function only works if the model is set. If the model changes before the tree view is realized, the centered path will be modified to reflect this change. 
 
 | 
| 
 | ||||||||||||
| Scrolls the tree view such that the top-left corner of the visible area is tree_x , tree_y , where tree_x and tree_y are specified in tree window coordinates. The tree_view must be realized before this function is called. If it isn't, you probably want to be using scroll_to_cell(). If either tree_x or tree_y are -1, then that direction isn't scrolled. 
 | 
| 
 | 
| Moves the alignments of tree view to the position specified by path. The tree does the minimum amount of work to scroll the row onto the screen. This means that the row will be scrolled to the edge closest to it's current position. If the row is currently visible on the screen, nothing is done. This function only works if the model is set, and path is a valid row on the model. If the model changes before the tree view is realized, the centered path will be modified to reflect this change. 
 
 | 
| 
 | ||||||||||||
| Moves the alignments of tree view to the position specified by path. row_align determines where the row is placed, and is expected to be between 0.0 and 1.0. 0.0 means top alignment, 1.0 means bottom alignment, 0.5 means center. This function only works if the model is set, and path is a valid row on the model. If the model changes before the tree view is realized, the centered path will be modified to reflect this change. 
 
 | 
| 
 | 
| Sets a callback slot for determining where a column may be dropped when dragged. This function is called on every column pair in turn at the beginning of a column drag to determine where a drop can take place. The arguments passed to the function are: the tree_view, the view Column being dragged, and the two view Columns determining the drop spot. If either of the view Column arguments for the drop spot are 0, then they indicate an edge. See unset_column_drag_function(). 
 
 | 
| 
 | 
| Sets the current keyboard focus to be at path , and selects it. This is useful when you want to focus the user's attention on a particular row. This function is often followed by Gtk::widget::grab_focus(tree_view) in order to give keyboard focus to the widget. 
 
 | 
| 
 | ||||||||||||||||||||
| Sets the current keyboard focus to be at path , and selects it. 
This is useful when you want to focus the user's attention on a particular row. If focus_column is not  
 
 | 
| 
 | ||||||||||||||||
| Sets the current keyboard focus to be at path , and selects it. 
This is useful when you want to focus the user's attention on a particular row. Focus is given to the column specified. Additionally, if start_editing is  
 | 
| 
 | ||||||||||||
| Sets the row that is highlighted for feedback. 
 
 | 
| 
 | 
| If enable_search is set, then the user can type in text to search through the tree interactively (this is sometimes called "typeahead find"). 
Note that even if this is  
 | 
| 
 | 
| Sets the column to draw the expander arrow at. It must be in the TreeView. See also reset_expander_column(). 
 | 
| 
 | 
| Enables or disables the fixed height mode of tree_view . Fixed height mode speeds up Gtk::TreeView by assuming that all rows have the same height. Only enable this option if all rows are the same height and all columns are of type Gtk::TREE_VIEW_COLUMN_FIXED. 
 
 | 
| 
 | 
| Sets the Gtk::Adjustment for the current horizontal aspect. See also unset_hadjustment(). 
 | 
| 
 | 
| Allow the column title buttons to be clicked. 
 
 | 
| 
 | 
| Sets the visibility state of the headers. 
 
 | 
| 
 | 
| Enables of disables the hover expansion mode of tree_view . Hover expansion makes rows expand or collaps if the pointer moves over them. 
 
 | 
| 
 | 
| Enables of disables the hover selection mode of tree_view . Hover selection makes the selected row follow the pointer. Currently, this works only for the selection modes Gtk::SELECTION_SINGLE and Gtk::SELECTION_BROWSE. 
 
 | 
| 
 | 
| Sets the model for a Gtk::TreeView. 
If the tree_view already has a model set, it will remove it before setting the new model. If model is  
 | 
| 
 | 
| This function is a convenience function to allow you to reorder models that support the Gtk::DragSourceIface and the Gtk::DragDestIface. 
Both Gtk::TreeStore and Gtk::ListStore support these. If reorderable is  This function does not give you any degree of control over the order -- any reordering is allowed. If more control is needed, you should probably handle drag and drop manually. 
 | 
| 
 | 
| 
 | 
| 
 | 
| This function tells GTK+ that the user interface for your application requires users to read across tree rows and associate cells with one another. By default, GTK+ will then render the tree with alternating row colors. Do not use it just because you prefer the appearance of the ruled tree; that's a question for the theme. Some themes will draw tree rows in alternating colors even when rules are turned off, and users who prefer that appearance all the time can choose those themes. You should call this function only as a semantic hint to the theme engine that your tree makes alternating colors useful from a functional standpoint (since it has lots of columns, generally). 
 | 
| 
 | 
| Sets column as the column where the interactive search code should search in. If the sort column is set, users can use the "start-interactive-search" key binding to bring up search popup. The enable-search property controls whether simply typing text will also start an interactive search. Note that column refers to a column of the model. 
 | 
| 
 | 
| Sets column as the column where the interactive search code should search in. If the sort column is set, users can use the "start-interactive-search" key binding to bring up search popup. The enable-search property controls whether simply typing text will also start an interactive search. Note that column refers to a column of the model. 
 | 
| 
 | 
| 
 | 
| 
 | 
| Sets the compare function for the interactive search capabilities. 
 
 | 
| 
 | 
| 
 | 
| 
 | 
| Sets the Gtk::Adjustment for the current vertical aspect. See also unset_vadjustment(). 
 | 
| 
 | 
| 
 | 
| 
 | 
| 
 | 
| 
 | 
| 
 | 
| 
 | 
| 
 | 
| 
 | 
| 
 | 
| 
 | 
| 
 | 
| 
 | 
| 
 | 
| 
 | 
| 
 | 
| 
 | ||||||||||||||||||||
| Converts tree coordinates (coordinates in full scrollable area of the tree) to widget coordinates. 
 
 | 
| 
 | ||||||||||||||||||||
| Converts tree coordinates (coordinates in full scrollable area of the tree) to widget coordinates. 
 
 
 | 
| 
 | 
| See set_column_drag_function(). After this method has been called, the TreeView reverts to the default behavior of allowing all columns to be dropped everywhere. | 
| 
 | 
| This method removes the hadjustment. 
 
 | 
| 
 | 
| Remove the model from the TreeView. 
 | 
| 
 | 
| Undoes the effect of enable_model_drag_dest(). 
 | 
| 
 | 
| Undoes the effect of enable_model_drag_source(). 
 | 
| 
 | 
| This method removes the vadjustment. 
 
 | 
| 
 | ||||||||||||||||||||
| Converts widget coordinates to coordinates for the tree window (the full scrollable area of the tree). 
 | 
| 
 | ||||||||||||||||||||
| Converts widget coordinates to coordinates for the tree window (the full scrollable area of the tree). 
 
 | 
| 
 | ||||||||||||
| 
 
 
 |