summaryrefslogtreecommitdiff
path: root/docs/reference/gtk/tmpl/gtktooltip.sgml
blob: 71edd3584e6b424b03311bc15047d48ee9f30270 (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
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
<!-- ##### SECTION Title ##### -->
GtkTooltip

<!-- ##### SECTION Short_Description ##### -->
Add tips to your widgets

<!-- ##### SECTION Long_Description ##### -->
<para>
#GtkTooltip belongs to the new tooltips API that was
introduced in GTK+ 2.12 and which deprecates the old
#GtkTooltips API. 
</para>
<para>
Basic tooltips can be realized simply by using gtk_widget_set_tooltip_text()
or gtk_widget_set_tooltip_markup() without any explicit tooltip object. 
</para>

<para>
When you need a tooltip with a little more fancy contents, like
adding an image, or you want the tooltip to have different contents
per GtkTreeView row or cell, you will have to do a little more work:
<itemizedlist>

<listitem><para>
Set the #GtkWidget:has-tooltip property to %TRUE, this will
make GTK+ monitor the widget for motion and related events
which are needed to determine when and where to show a tooltip.
</para></listitem>

<listitem><para>
Connect to the #GtkWidget::query-tooltip signal.  This signal
will be emitted when a tooltip is supposed to be shown. One
of the arguments passed to the signal handler is a #GtkTooltip
object. This is the object that we are about to display as a 
tooltip, and can be manipulated in your callback using functions
like gtk_tooltip_set_icon(). There are functions for setting
the tooltip's markup, setting an image from a stock icon, or
even putting in a custom widget.
</para></listitem>

<listitem><para>
Return %TRUE from your query-tooltip handler. This causes
the tooltip to be show. If you return %FALSE, it will not be shown. 
</para></listitem>
</itemizedlist>
</para>

<para>
In the probably rare case where you want to have even more control
over the tooltip that is about to be shown, you can set your own
#GtkWindow which will be used as tooltip window.  This works as
follows:
<itemizedlist>

<listitem><para>
Set #GtkWidget:has-tooltip and connect to #GtkWidget::query-tooltip as 
before.
</para></listitem>

<listitem><para>
Use gtk_widget_set_tooltip_window() to set a #GtkWindow created
by you as tooltip window.
</para></listitem>

<listitem><para>
In the ::query-tooltip callback you can access your window
using gtk_widget_get_tooltip_window() and manipulate as you
wish. The semantics of the return value are exactly as before,
return %TRUE to show the window, %FALSE to not show it.
</para></listitem>
</itemizedlist>
</para>

<!-- ##### SECTION See_Also ##### -->
<para>

</para>

<!-- ##### SECTION Stability_Level ##### -->


<!-- ##### STRUCT GtkTooltip ##### -->
<para>

</para>


<!-- ##### FUNCTION gtk_tooltip_set_markup ##### -->
<para>

</para>

@tooltip: 
@markup: 


<!-- ##### FUNCTION gtk_tooltip_set_text ##### -->
<para>

</para>

@tooltip: 
@text: 


<!-- ##### FUNCTION gtk_tooltip_set_icon ##### -->
<para>

</para>

@tooltip: 
@pixbuf: 


<!-- ##### FUNCTION gtk_tooltip_set_icon_from_stock ##### -->
<para>

</para>

@tooltip: 
@stock_id: 
@size: 


<!-- ##### FUNCTION gtk_tooltip_set_icon_from_icon_name ##### -->
<para>

</para>

@tooltip: 
@icon_name: 
@size: 


<!-- ##### FUNCTION gtk_tooltip_set_icon_from_gicon ##### -->
<para>

</para>

@tooltip: 
@gicon: 
@size: 


<!-- ##### FUNCTION gtk_tooltip_set_custom ##### -->
<para>

</para>

@tooltip: 
@custom_widget: 


<!-- ##### FUNCTION gtk_tooltip_trigger_tooltip_query ##### -->
<para>

</para>

@display: 


<!-- ##### FUNCTION gtk_tooltip_set_tip_area ##### -->
<para>

</para>

@tooltip: 
@rect: