summaryrefslogtreecommitdiff
path: root/src/gtk/treeview_cell_tooltips.h
blob: f83b9ce9787f8f52ba563414a59385d8be843650 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
// treeview_cell_tooltips.h    -*-c++-*-
//
//  Copyright 2008 Daniel Burrows
//
//  This program is free software; you can redistribute it and/or modify
//  it under the terms of the GNU General Public License as published by
//  the Free Software Foundation; either version 2 of the License, or
//  (at your option) any later version.
//
//  This program is distributed in the hope that it will be useful,
//  but WITHOUT ANY WARRANTY; without even the implied warranty of
//  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
//  GNU General Public License for more details.
//
//  You should have received a copy of the GNU General Public License
//  along with this program; see the file COPYING.  If not, write to
//  the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
//  Boston, MA 02111-1307, USA.

#ifndef TREEVIEW_CELL_TOOLTIPS_H
#define TREEVIEW_CELL_TOOLTIPS_H

#include <gtkmm.h>

/** \file treeview_cell_tooltips.h
 *
 *  Code to display tooltips for individual cells in a TreeView.
 *
 *  The tooltips are attached to TreeViewColumns, and the text/markup
 *  to display in a tooltip is taken from a TreeModelColumn.  The
 *  first time that a tooltip is attached to a TreeView, a connection
 *  to signal_query_tooltip() is created to actually display the tooltips.
 */

namespace gui
{
  /** \brief Start displaying tooltips on columns for the given tree-view if they
   *  aren't already being displayed.
   *
   *  \param treeview    The TreeView on which to start displaying tooltips.
   */
  void enable_column_tooltips(Gtk::TreeView *treeview);

  /** \brief Stop displaying tooltips on columns for the given tree-view if they
   *  aren't already being displayed.
   *
   *  \param treeview    The TreeView on which to stop displaying tooltips.
   */
  void disable_column_tooltips(Gtk::TreeView *treeview);

  /** \brief Attach a textual tooltip to the given column.
   *
   *  Column tooltips will be enabled on the tree-view if they aren't already.
   *
   *  \param treeview     The tree-view in which the column exists.
   *  \param view_column  The column to set a tooltip on.
   *  \param model_column The column of the model that supplies the tooltip text.
   */
  void set_text_tooltip(Gtk::TreeView *treeview,
			Gtk::TreeViewColumn *view_column,
			const Gtk::TreeModelColumn<Glib::ustring> &model_column);

  /** \brief Attach a textual tooltip to the given column.
   *
   *  Column tooltips will be enabled on the tree-view if they aren't already.
   *
   *  \param treeview     The tree-view in which the column exists.
   *  \param view_column  The column to set a tooltip on.
   *  \param model_column The column of the model that supplies the tooltip text.
   */
  void set_markup_tooltip(Gtk::TreeView *treeview,
			  Gtk::TreeViewColumn *view_column,
			  const Gtk::TreeModelColumn<Glib::ustring> &model_column);
};

#endif // TREEVIEW_CELL_TOOLTIPS_H