1Gtk2::CellRenderer(3) User Contributed Perl DocumentationGtk2::CellRenderer(3)
2
3
4
6 Gtk2::CellRenderer - An object that renders a single cell onto a
7 Gtk2::Gdk::Drawable
8
10 The Gtk2::CellRenderer is the base class for objects which render cells
11 onto drawables. These objects are used primarily by the
12 Gtk2::TreeView, though they aren't tied to them in any specific way.
13
14 Typically, one cell renderer is used to draw many cells onto the
15 screen. Thus, the cell renderer doesn't keep state; instead, any state
16 is set immediately prior to use through the object property system.
17 The cell is measured with "get_size", and then renderered with
18 "render".
19
21 Glib::Object
22 +----Glib::InitiallyUnowned
23 +----Gtk2::Object
24 +----Gtk2::CellRenderer
25
27 boolean = $cell->activate ($event, $widget, $path, $background_area,
28 $cell_area, $flags)
29 · $event (Gtk2::Gdk::Event)
30
31 · $widget (Gtk2::Widget)
32
33 · $path (string)
34
35 · $background_area (Gtk2::Gdk::Rectangle)
36
37 · $cell_area (Gtk2::Gdk::Rectangle)
38
39 · $flags (Gtk2::CellRendererState)
40
41 (xalign, yalign) = $cell->get_alignment
42 Since: gtk+ 2.18
43
44 $cell->set_alignment ($xalign, $yalign)
45 · $xalign (double)
46
47 · $yalign (double)
48
49 Since: gtk+ 2.18
50
51 $cell->editing_canceled
52 Since: gtk+ 2.4
53
54 (width, height) = $cell->get_fixed_size
55 Fetch the fixed size if $cell. Values of -1 mean "this dimension is
56 not fixed."
57
58 $cell->set_fixed_size ($width, $height)
59 · $width (integer)
60
61 · $height (integer)
62
63 Set the renderer's size explicitly, independent of object properties.
64 A value of -1 means "don't use a fixed size for this dimension."
65
66 (xpad, ypad) = $cell->get_padding
67 Since: gtk+ 2.18
68
69 $cell->set_padding ($xpad, $ypad)
70 · $xpad (integer)
71
72 · $ypad (integer)
73
74 Since: gtk+ 2.18
75
76 $cell->render ($drawable, $widget, $background_area, $cell_area,
77 $expose_area, $flags)
78 · $drawable (Gtk2::Gdk::Drawable)
79
80 · $widget (Gtk2::Widget)
81
82 · $background_area (Gtk2::Gdk::Rectangle)
83
84 · $cell_area (Gtk2::Gdk::Rectangle)
85
86 · $expose_area (Gtk2::Gdk::Rectangle)
87
88 · $flags (Gtk2::CellRendererState)
89
90 boolean = $cell->get_sensitive
91 Since: gtk+ 2.18
92
93 $cell->set_sensitive ($sensitive)
94 · $sensitive (boolean)
95
96 Since: gtk+ 2.18
97
98 (x_offset, y_offset, width, height) = $cell->get_size ($widget, $cell_area)
99 · $widget (Gtk2::Widget)
100
101 · $cell_area (Gtk2::Gdk::Rectangle or undef)
102
103 celleditable or undef = $cell->start_editing ($event, $widget, $path,
104 $background_area, $cell_area, $flags)
105 · $event (Gtk2::Gdk::Event)
106
107 · $widget (Gtk2::Widget)
108
109 · $path (string)
110
111 · $background_area (Gtk2::Gdk::Rectangle)
112
113 · $cell_area (Gtk2::Gdk::Rectangle)
114
115 · $flags (Gtk2::CellRendererState)
116
117 $cell->stop_editing ($canceled)
118 · $canceled (boolean)
119
120 Since: gtk+ 2.6
121
122 boolean = $cell->get_visible
123 Since: gtk+ 2.18
124
125 $cell->set_visible ($visible)
126 · $visible (boolean)
127
128 Since: gtk+ 2.18
129
131 'cell-background' (string : default undef : writable / private)
132 Cell background color as a string
133
134 'cell-background-gdk' (Gtk2::Gdk::Color : default undef : readable /
135 writable / private)
136 Cell background color as a GdkColor
137
138 'cell-background-set' (boolean : default false : readable / writable /
139 private)
140 Whether this tag affects the cell background color
141
142 'editing' (boolean : default false : readable / private)
143 Whether the cell renderer is currently in editing mode
144
145 'height' (integer : default -1 : readable / writable / private)
146 The fixed height
147
148 'is-expanded' (boolean : default false : readable / writable / private)
149 Row is an expander row, and is expanded
150
151 'is-expander' (boolean : default false : readable / writable / private)
152 Row has children
153
154 'mode' (Gtk2::CellRendererMode : default "inert" : readable / writable
155 / private)
156 Editable mode of the CellRenderer
157
158 'sensitive' (boolean : default true : readable / writable / private)
159 Display the cell sensitive
160
161 'visible' (boolean : default true : readable / writable / private)
162 Display the cell
163
164 'width' (integer : default -1 : readable / writable / private)
165 The fixed width
166
167 'xalign' (float : default 0.5 : readable / writable / private)
168 The x-align
169
170 'xpad' (Glib::UInt : default 0 : readable / writable / private)
171 The xpad
172
173 'yalign' (float : default 0.5 : readable / writable / private)
174 The y-align
175
176 'ypad' (Glib::UInt : default 0 : readable / writable / private)
177 The ypad
178
180 editing-canceled (Gtk2::CellRenderer)
181 editing-started (Gtk2::CellRenderer, Gtk2::CellEditable, string)
182
184 enum Gtk2::CellRendererMode
185 · 'inert' / 'GTK_CELL_RENDERER_MODE_INERT'
186
187 · 'activatable' / 'GTK_CELL_RENDERER_MODE_ACTIVATABLE'
188
189 · 'editable' / 'GTK_CELL_RENDERER_MODE_EDITABLE'
190
191 flags Gtk2::CellRendererState
192 · 'selected' / 'GTK_CELL_RENDERER_SELECTED'
193
194 · 'prelit' / 'GTK_CELL_RENDERER_PRELIT'
195
196 · 'insensitive' / 'GTK_CELL_RENDERER_INSENSITIVE'
197
198 · 'sorted' / 'GTK_CELL_RENDERER_SORTED'
199
200 · 'focused' / 'GTK_CELL_RENDERER_FOCUSED'
201
203 Gtk+ provides three cell renderers: Gtk2::CellRendererText,
204 Gtk2::CellRendererToggle, and Gtk2::CellRendererPixbuf. You may derive
205 a new renderer from any of these, or directly from Gtk2::CellRenderer
206 itself.
207
208 There are a number of rules that must be followed when writing a new
209 cell renderer. First and foremost, it's important that a certain set
210 of properties always yields a cell of the same size, barring a
211 Gtk2::Style change. The cell renderer also has a number of generic
212 properties that are expected to be honored by all children.
213
214 The new renderer must be a GObject, so you must follow the normal
215 procedure for creating a new Glib::Object (i.e., either
216 Glib::Object::Subclass or Glib::Type::register_object). The new
217 subclass can customize the object's behavior by providing new
218 implementations of these four methods:
219
220 (x_offset, y_offset, width, height) = GET_SIZE ($cell, $widget,
221 $cell_area)
222 o $cell (Gtk2::CellRenderer)
223 o $widget (Gtk2::Widget) widget to which $cell is rendering
224 o $cell_area (Gtk2::Gdk::Rectangle or undef) The area a cell will
225 be allocated, or undef.
226
227 Return Values:
228
229 - x_offset - x offset of cell relative to $cell_area
230 - y_offset - y offset of cell relative to $cell_area
231 - width - width needed to render cell
232 - height - height needed to render cell
233
234 This is called to calculate the size of the cell for display,
235 taking into account the padding and alignment properties of the
236 parent. This one will be called very often. If you need to know
237 your cell's data, then get it from the appropriate object
238 properties, which will be set accordingly before this method is
239 called.
240
241 RENDER ($cell, $drawable, $widget, $background_area, $cell_area,
242 $expose_area, $flags)
243 o $cell (Gtk2::CellRenderer)
244 o $drawable (Gtk2::Gdk::Drawable) window on which to draw
245 o $widget (Gtk2::Widget) widget owning $drawable
246 o $background_area (Gtk2::Gdk::Rectangle) entire cell area
247 (including tree expanders and maybe padding on the sides)
248 o $cell_area (Gtk2::Gdk::Rectangle) area normally rendered by a
249 cell renderer
250 o $expose_area (Gtk2::Gdk::Rectangle) area that actually needs
251 updating
252 o $flags (Gtk2::CellRendererState) flags that affect rendering
253
254 This is called to render the cell onto the screen. As with
255 GET_SIZE, the data for the cell comes from object properties. In
256 general, you'll want to make use of Gtk2::Style methods for drawing
257 anything fancy.
258
259 The three passed-in rectangles are areas of $drawable. Most
260 renderers draw within $cell_area; the xalign, yalign, xpad, and
261 ypad fields of the cell renderer should be honored with respect to
262 $cell_area. $background_area includes the blank space around the
263 cell, and also the area containing the tree expander; so the
264 $background_area rectangles for all cells cover the entire
265 $drawable. $expose_area is a clip rectangle.
266
267 boolean = ACTIVATE ($cell, $event, $widget, $path, $background_area,
268 $cell_area, $flags)
269 o $cell (Gtk2::CellRenderer)
270 o $event (Gtk2::Gdk::Event)
271 o $widget (Gtk2::Widget) widget that received the event
272 o $path (string) widget-dependent string representation of the
273 event location; e.g. for a Gtk2::TreeView, a string representation
274 of a Gtk2::TreePath.
275 o $background_area (Gtk2::Gdk::Rectangle) background area as passed
276 to "RENDER".
277 o $cell_area (Gtk2::Gdk::Rectangle) cell area as passed to
278 "RENDER".
279 o $flags (Gtk2::CellRendererState) render flags
280
281 This method is called when an event occurs on a cell. Implementing
282 it is not mandatory. The return value should be TRUE if the event
283 was consumed/handled.
284
285 celleditable or undef = START_EDITING ($cell, $event, $widget, $path,
286 $background_area, $cell_area, $flags)
287 o $cell (Gtk2::CellRenderer)
288 o $event (Gtk2::Gdk::Event)
289 o $widget (Gtk2::Widget) widget that received the event
290 o $path (string) widget-dependent string representation of the
291 event location; e.g. for a Gtk2::TreeView, a string representation
292 of a Gtk2::TreePath.
293 o $background_area (Gtk2::Gdk::Rectangle) background area as passed
294 to "RENDER".
295 o $cell_area (Gtk2::Gdk::Rectangle) cell area as passed to
296 "RENDER".
297 o $flags (Gtk2::CellRendererState) render flags
298
299 For cells that are editable, this is called to put the cell into
300 editing mode. If the return value is an object is a
301 Gtk2::CellEditable, that widget will be used to edit the value; the
302 calling code takes care of sizing, placing, and showing the
303 editable, you just need to return it. If the return value is
304 undef, the editing is aborted.
305
306 Note: for backward compatibility, the bizarre and non-standard scheme
307 used for this in 1.02x is still supported, but is deprecated and should
308 not be used in new code, and since i don't want people to use it any
309 more i will not document it here.
310
312 Gtk2, Glib::Object, Glib::InitiallyUnowned, Gtk2::Object
313
315 Copyright (C) 2003-2011 by the gtk2-perl team.
316
317 This software is licensed under the LGPL. See Gtk2 for a full notice.
318
319
320
321perl v5.30.0 2019-07-26 Gtk2::CellRenderer(3)