2 * Copyright (C) 2002, 2003 Kristian Rietveld <kris@gtk.org>
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.
22 #include "gtkcellview.h"
23 #include "gtkcelllayout.h"
25 #include "gtksignal.h"
26 #include "gtkcellrenderertext.h"
27 #include "gtkcellrendererpixbuf.h"
28 #include <gobject/gmarshal.h>
30 typedef struct _GtkCellViewCellInfo GtkCellViewCellInfo;
31 struct _GtkCellViewCellInfo
33 GtkCellRenderer *cell;
42 GtkCellLayoutDataFunc func;
44 GDestroyNotify destroy;
47 struct _GtkCellViewPrivate
50 GtkTreeRowReference *displayed_row;
55 gboolean background_set;
59 static void gtk_cell_view_class_init (GtkCellViewClass *klass);
60 static void gtk_cell_view_cell_layout_init (GtkCellLayoutIface *iface);
61 static void gtk_cell_view_get_property (GObject *object,
65 static void gtk_cell_view_set_property (GObject *object,
69 static void gtk_cell_view_init (GtkCellView *cellview);
70 static void gtk_cell_view_finalize (GObject *object);
71 static void gtk_cell_view_style_set (GtkWidget *widget,
72 GtkStyle *previous_style);
73 static void gtk_cell_view_size_request (GtkWidget *widget,
74 GtkRequisition *requisition);
75 static void gtk_cell_view_size_allocate (GtkWidget *widget,
76 GtkAllocation *allocation);
77 static gboolean gtk_cell_view_expose (GtkWidget *widget,
78 GdkEventExpose *event);
79 static void gtk_cell_view_set_valuesv (GtkCellView *cellview,
80 GtkCellRenderer *renderer,
82 static GtkCellViewCellInfo *gtk_cell_view_get_cell_info (GtkCellView *cellview,
83 GtkCellRenderer *renderer);
84 static void gtk_cell_view_set_cell_data (GtkCellView *cell_view);
87 static void gtk_cell_view_cell_layout_pack_start (GtkCellLayout *layout,
88 GtkCellRenderer *renderer,
90 static void gtk_cell_view_cell_layout_pack_end (GtkCellLayout *layout,
91 GtkCellRenderer *renderer,
93 static void gtk_cell_view_cell_layout_add_attribute (GtkCellLayout *layout,
94 GtkCellRenderer *renderer,
95 const gchar *attribute,
97 static void gtk_cell_view_cell_layout_clear (GtkCellLayout *layout);
98 static void gtk_cell_view_cell_layout_clear_attributes (GtkCellLayout *layout,
99 GtkCellRenderer *renderer);
100 static void gtk_cell_view_cell_layout_set_cell_data_func (GtkCellLayout *layout,
101 GtkCellRenderer *cell,
102 GtkCellLayoutDataFunc func,
104 GDestroyNotify destroy);
105 static void gtk_cell_view_cell_layout_reorder (GtkCellLayout *layout,
106 GtkCellRenderer *cell,
110 #define GTK_CELL_VIEW_GET_PRIVATE(obj) (G_TYPE_INSTANCE_GET_PRIVATE ((obj), GTK_TYPE_CELL_VIEW, GtkCellViewPrivate))
120 static GtkObjectClass *parent_class = NULL;
124 gtk_cell_view_get_type (void)
126 static GType cell_view_type = 0;
130 static const GTypeInfo cell_view_info =
132 sizeof (GtkCellViewClass),
133 NULL, /* base_init */
134 NULL, /* base_finalize */
135 (GClassInitFunc) gtk_cell_view_class_init,
136 NULL, /* class_finalize */
137 NULL, /* class_data */
138 sizeof (GtkCellView),
140 (GInstanceInitFunc) gtk_cell_view_init
143 static const GInterfaceInfo cell_layout_info =
145 (GInterfaceInitFunc) gtk_cell_view_cell_layout_init,
150 cell_view_type = g_type_register_static (GTK_TYPE_WIDGET, "GtkCellView",
153 g_type_add_interface_static (cell_view_type, GTK_TYPE_CELL_LAYOUT,
157 return cell_view_type;
161 gtk_cell_view_class_init (GtkCellViewClass *klass)
163 GObjectClass *gobject_class = G_OBJECT_CLASS (klass);
164 GtkWidgetClass *widget_class = GTK_WIDGET_CLASS (klass);
166 parent_class = g_type_class_peek_parent (klass);
168 gobject_class->get_property = gtk_cell_view_get_property;
169 gobject_class->set_property = gtk_cell_view_set_property;
170 gobject_class->finalize = gtk_cell_view_finalize;
172 widget_class->expose_event = gtk_cell_view_expose;
173 widget_class->size_allocate = gtk_cell_view_size_allocate;
174 widget_class->size_request = gtk_cell_view_size_request;
175 widget_class->style_set = gtk_cell_view_style_set;
178 g_object_class_install_property (gobject_class,
180 g_param_spec_string ("background",
181 P_("Background color name"),
182 P_("Background color as a string"),
185 g_object_class_install_property (gobject_class,
187 g_param_spec_boxed ("background_gdk",
188 P_("Background color"),
189 P_("Background color as a GdkColor"),
191 G_PARAM_READABLE | G_PARAM_WRITABLE));
193 #define ADD_SET_PROP(propname, propval, nick, blurb) g_object_class_install_property (gobject_class, propval, g_param_spec_boolean (propname, nick, blurb, FALSE, G_PARAM_READABLE | G_PARAM_WRITABLE))
195 ADD_SET_PROP ("background_set", PROP_BACKGROUND_SET,
196 P_("Background set"),
197 P_("Whether this tag affects the background color"));
199 g_type_class_add_private (gobject_class, sizeof (GtkCellViewPrivate));
203 gtk_cell_view_cell_layout_init (GtkCellLayoutIface *iface)
205 iface->pack_start = gtk_cell_view_cell_layout_pack_start;
206 iface->pack_end = gtk_cell_view_cell_layout_pack_end;
207 iface->clear = gtk_cell_view_cell_layout_clear;
208 iface->add_attribute = gtk_cell_view_cell_layout_add_attribute;
209 iface->set_cell_data_func = gtk_cell_view_cell_layout_set_cell_data_func;
210 iface->clear_attributes = gtk_cell_view_cell_layout_clear_attributes;
211 iface->reorder = gtk_cell_view_cell_layout_reorder;
215 gtk_cell_view_get_property (GObject *object,
220 GtkCellView *view = GTK_CELL_VIEW (object);
224 case PROP_BACKGROUND_GDK:
228 color = view->priv->background;
230 g_value_set_boxed (value, &color);
233 case PROP_BACKGROUND_SET:
234 g_value_set_boolean (value, view->priv->background_set);
237 G_OBJECT_WARN_INVALID_PROPERTY_ID (object, param_id, pspec);
243 gtk_cell_view_set_property (GObject *object,
248 GtkCellView *view = GTK_CELL_VIEW (object);
252 case PROP_BACKGROUND:
256 if (!g_value_get_string (value))
257 gtk_cell_view_set_background_color (view, NULL);
258 else if (gdk_color_parse (g_value_get_string (value), &color))
259 gtk_cell_view_set_background_color (view, &color);
261 g_warning ("Don't know color `%s'", g_value_get_string (value));
263 g_object_notify (object, "background_gdk");
266 case PROP_BACKGROUND_GDK:
267 gtk_cell_view_set_background_color (view, g_value_get_boxed (value));
269 case PROP_BACKGROUND_SET:
270 view->priv->background_set = g_value_get_boolean (value);
273 G_OBJECT_WARN_INVALID_PROPERTY_ID (object, param_id, pspec);
279 gtk_cell_view_init (GtkCellView *cellview)
281 GTK_WIDGET_SET_FLAGS (cellview, GTK_NO_WINDOW);
283 cellview->priv = GTK_CELL_VIEW_GET_PRIVATE (cellview);
287 gtk_cell_view_style_set (GtkWidget *widget,
288 GtkStyle *previous_style)
290 if (previous_style && GTK_WIDGET_REALIZED (widget))
291 gdk_window_set_background (widget->window,
292 &widget->style->base[GTK_WIDGET_STATE (widget)]);
296 gtk_cell_view_finalize (GObject *object)
298 GtkCellView *cellview = GTK_CELL_VIEW (object);
300 gtk_cell_view_cell_layout_clear (GTK_CELL_LAYOUT (cellview));
302 if (cellview->priv->model)
303 g_object_unref (cellview->priv->model);
305 if (cellview->priv->displayed_row)
306 gtk_tree_row_reference_free (cellview->priv->displayed_row);
308 (* G_OBJECT_CLASS (parent_class)->finalize) (object);
312 gtk_cell_view_size_request (GtkWidget *widget,
313 GtkRequisition *requisition)
316 gboolean first_cell = TRUE;
317 GtkCellView *cellview;
319 cellview = GTK_CELL_VIEW (widget);
321 requisition->width = 0;
322 requisition->height = 0;
324 if (cellview->priv->displayed_row)
325 gtk_cell_view_set_cell_data (cellview);
327 for (i = cellview->priv->cell_list; i; i = i->next)
330 GtkCellViewCellInfo *info = (GtkCellViewCellInfo *)i->data;
332 if (!info->cell->visible)
336 requisition->width += cellview->priv->spacing;
338 gtk_cell_renderer_get_size (info->cell, widget, NULL, NULL, NULL,
341 info->requested_width = width;
342 requisition->width += width;
343 requisition->height = MAX (requisition->height, height);
350 gtk_cell_view_size_allocate (GtkWidget *widget,
351 GtkAllocation *allocation)
354 gint expand_cell_count = 0;
355 gint full_requested_width = 0;
357 GtkCellView *cellview;
359 widget->allocation = *allocation;
361 cellview = GTK_CELL_VIEW (widget);
363 /* checking how much extra space we have */
364 for (i = cellview->priv->cell_list; i; i = i->next)
366 GtkCellViewCellInfo *info = (GtkCellViewCellInfo *)i->data;
368 if (!info->cell->visible)
374 full_requested_width += info->requested_width;
377 extra_space = widget->allocation.width - full_requested_width;
380 else if (extra_space > 0 && expand_cell_count > 0)
381 extra_space /= expand_cell_count;
383 /* iterate list for PACK_START cells */
384 for (i = cellview->priv->cell_list; i; i = i->next)
386 GtkCellViewCellInfo *info = (GtkCellViewCellInfo *)i->data;
388 if (info->pack == GTK_PACK_END)
391 if (!info->cell->visible)
394 info->real_width = info->requested_width + (info->expand?extra_space:0);
397 /* iterate list for PACK_END cells */
398 for (i = cellview->priv->cell_list; i; i = i->next)
400 GtkCellViewCellInfo *info = (GtkCellViewCellInfo *)i->data;
402 if (info->pack == GTK_PACK_START)
405 if (!info->cell->visible)
408 info->real_width = info->requested_width + (info->expand?extra_space:0);
413 gtk_cell_view_expose (GtkWidget *widget,
414 GdkEventExpose *event)
417 GtkCellView *cellview;
419 GtkCellRendererState state;
420 gboolean rtl = (gtk_widget_get_direction(widget) == GTK_TEXT_DIR_RTL);
422 cellview = GTK_CELL_VIEW (widget);
424 if (! GTK_WIDGET_DRAWABLE (widget))
427 /* "blank" background */
428 if (cellview->priv->background_set)
432 gc = gdk_gc_new (GTK_WIDGET (cellview)->window);
433 gdk_gc_set_rgb_fg_color (gc, &cellview->priv->background);
435 gdk_draw_rectangle (GTK_WIDGET (cellview)->window,
440 widget->allocation.x,
441 widget->allocation.y,
443 widget->allocation.width,
444 widget->allocation.height);
449 /* set cell data (if available) */
450 if (cellview->priv->displayed_row)
451 gtk_cell_view_set_cell_data (cellview);
452 else if (cellview->priv->model)
456 area = widget->allocation;
458 /* we draw on our very own window, initialize x and y to zero */
459 area.x = widget->allocation.x + (rtl ? widget->allocation.width : 0);
460 area.y = widget->allocation.y;
462 if (GTK_WIDGET_STATE (widget) == GTK_STATE_PRELIGHT)
463 state = GTK_CELL_RENDERER_PRELIT;
468 for (i = cellview->priv->cell_list; i; i = i->next)
470 GtkCellViewCellInfo *info = (GtkCellViewCellInfo *)i->data;
472 if (info->pack == GTK_PACK_END)
475 if (!info->cell->visible)
478 area.width = info->real_width;
480 area.x -= area.width;
482 gtk_cell_renderer_render (info->cell,
486 &area, &area, &event->area, state);
489 area.x += info->real_width;
492 area.x = rtl ? widget->allocation.x : (widget->allocation.x + widget->allocation.width);
495 for (i = cellview->priv->cell_list; i; i = i->next)
497 GtkCellViewCellInfo *info = (GtkCellViewCellInfo *)i->data;
499 if (info->pack == GTK_PACK_START)
502 if (!info->cell->visible)
505 area.width = info->real_width;
507 area.x -= area.width;
509 gtk_cell_renderer_render (info->cell,
513 &area, &area, &event->area, state);
515 area.x += info->real_width;
521 static GtkCellViewCellInfo *
522 gtk_cell_view_get_cell_info (GtkCellView *cellview,
523 GtkCellRenderer *renderer)
527 for (i = cellview->priv->cell_list; i; i = i->next)
529 GtkCellViewCellInfo *info = (GtkCellViewCellInfo *)i->data;
531 if (info->cell == renderer)
539 gtk_cell_view_set_cell_data (GtkCellView *cell_view)
545 g_return_if_fail (cell_view->priv->displayed_row != NULL);
547 path = gtk_tree_row_reference_get_path (cell_view->priv->displayed_row);
551 gtk_tree_model_get_iter (cell_view->priv->model, &iter, path);
552 gtk_tree_path_free (path);
554 for (i = cell_view->priv->cell_list; i; i = i->next)
557 GtkCellViewCellInfo *info = i->data;
559 g_object_freeze_notify (G_OBJECT (info->cell));
561 for (j = info->attributes; j && j->next; j = j->next->next)
563 gchar *property = j->data;
564 gint column = GPOINTER_TO_INT (j->next->data);
565 GValue value = {0, };
567 gtk_tree_model_get_value (cell_view->priv->model, &iter,
569 g_object_set_property (G_OBJECT (info->cell),
571 g_value_unset (&value);
575 (* info->func) (GTK_CELL_LAYOUT (cell_view),
577 cell_view->priv->model,
581 g_object_thaw_notify (G_OBJECT (info->cell));
585 /* GtkCellLayout implementation */
587 gtk_cell_view_cell_layout_pack_start (GtkCellLayout *layout,
588 GtkCellRenderer *renderer,
591 GtkCellViewCellInfo *info;
592 GtkCellView *cellview = GTK_CELL_VIEW (layout);
594 g_return_if_fail (GTK_IS_CELL_VIEW (cellview));
595 g_return_if_fail (GTK_IS_CELL_RENDERER (renderer));
596 g_return_if_fail (!gtk_cell_view_get_cell_info (cellview, renderer));
598 g_object_ref (renderer);
599 gtk_object_sink (GTK_OBJECT (renderer));
601 info = g_new0 (GtkCellViewCellInfo, 1);
602 info->cell = renderer;
603 info->expand = expand ? TRUE : FALSE;
604 info->pack = GTK_PACK_START;
606 cellview->priv->cell_list = g_list_append (cellview->priv->cell_list, info);
610 gtk_cell_view_cell_layout_pack_end (GtkCellLayout *layout,
611 GtkCellRenderer *renderer,
614 GtkCellViewCellInfo *info;
615 GtkCellView *cellview = GTK_CELL_VIEW (layout);
617 g_return_if_fail (GTK_IS_CELL_VIEW (cellview));
618 g_return_if_fail (GTK_IS_CELL_RENDERER (renderer));
619 g_return_if_fail (!gtk_cell_view_get_cell_info (cellview, renderer));
621 g_object_ref (renderer);
622 gtk_object_sink (GTK_OBJECT (renderer));
624 info = g_new0 (GtkCellViewCellInfo, 1);
625 info->cell = renderer;
626 info->expand = expand ? TRUE : FALSE;
627 info->pack = GTK_PACK_END;
629 cellview->priv->cell_list = g_list_append (cellview->priv->cell_list, info);
633 gtk_cell_view_cell_layout_add_attribute (GtkCellLayout *layout,
634 GtkCellRenderer *renderer,
635 const gchar *attribute,
638 GtkCellViewCellInfo *info;
639 GtkCellView *cellview = GTK_CELL_VIEW (layout);
641 g_return_if_fail (GTK_IS_CELL_VIEW (cellview));
642 info = gtk_cell_view_get_cell_info (cellview, renderer);
643 g_return_if_fail (info != NULL);
645 info->attributes = g_slist_prepend (info->attributes,
646 GINT_TO_POINTER (column));
647 info->attributes = g_slist_prepend (info->attributes,
648 g_strdup (attribute));
652 gtk_cell_view_cell_layout_clear (GtkCellLayout *layout)
654 GtkCellView *cellview = GTK_CELL_VIEW (layout);
656 g_return_if_fail (GTK_IS_CELL_VIEW (cellview));
658 while (cellview->priv->cell_list)
660 GtkCellViewCellInfo *info = (GtkCellViewCellInfo *)cellview->priv->cell_list->data;
662 gtk_cell_view_cell_layout_clear_attributes (layout, info->cell);
663 g_object_unref (info->cell);
665 cellview->priv->cell_list = g_list_delete_link (cellview->priv->cell_list,
666 cellview->priv->cell_list);
671 gtk_cell_view_cell_layout_set_cell_data_func (GtkCellLayout *layout,
672 GtkCellRenderer *cell,
673 GtkCellLayoutDataFunc func,
675 GDestroyNotify destroy)
677 GtkCellView *cellview = GTK_CELL_VIEW (layout);
678 GtkCellViewCellInfo *info;
680 g_return_if_fail (GTK_IS_CELL_VIEW (cellview));
682 info = gtk_cell_view_get_cell_info (cellview, cell);
683 g_return_if_fail (info != NULL);
687 GDestroyNotify d = info->destroy;
689 info->destroy = NULL;
694 info->func_data = func_data;
695 info->destroy = destroy;
699 gtk_cell_view_cell_layout_clear_attributes (GtkCellLayout *layout,
700 GtkCellRenderer *renderer)
702 GtkCellViewCellInfo *info;
703 GtkCellView *cellview = GTK_CELL_VIEW (layout);
706 g_return_if_fail (GTK_IS_CELL_VIEW (cellview));
707 g_return_if_fail (GTK_IS_CELL_RENDERER (renderer));
709 info = gtk_cell_view_get_cell_info (cellview, renderer);
712 list = info->attributes;
713 while (list && list->next)
716 list = list->next->next;
719 g_slist_free (info->attributes);
720 info->attributes = NULL;
725 gtk_cell_view_cell_layout_reorder (GtkCellLayout *layout,
726 GtkCellRenderer *cell,
730 GtkCellViewCellInfo *info;
731 GtkCellView *cellview = GTK_CELL_VIEW (layout);
733 g_return_if_fail (GTK_IS_CELL_VIEW (cellview));
734 g_return_if_fail (GTK_IS_CELL_RENDERER (cell));
736 info = gtk_cell_view_get_cell_info (cellview, cell);
738 g_return_if_fail (info != NULL);
739 g_return_if_fail (position >= 0);
741 link = g_list_find (cellview->priv->cell_list, info);
743 g_return_if_fail (link != NULL);
745 cellview->priv->cell_list = g_list_remove_link (cellview->priv->cell_list,
747 cellview->priv->cell_list = g_list_insert (cellview->priv->cell_list,
750 gtk_widget_queue_draw (GTK_WIDGET (cellview));
756 * Creates a new #GtkCellView widget.
758 * Return value: A newly created #GtkCellView widget.
763 gtk_cell_view_new (void)
765 GtkCellView *cellview;
767 cellview = g_object_new (gtk_cell_view_get_type (), NULL);
769 return GTK_WIDGET (cellview);
773 * gtk_cell_view_new_with_text:
774 * @text: the text to display in the cell view
776 * Creates a new #GtkCellView widget, adds a #GtkCellRendererText
777 * to it, and makes its show @text.
779 * Return value: A newly created #GtkCellView widget.
784 gtk_cell_view_new_with_text (const gchar *text)
786 GtkCellView *cellview;
787 GtkCellRenderer *renderer;
788 GValue value = {0, };
790 cellview = GTK_CELL_VIEW (gtk_cell_view_new ());
792 renderer = gtk_cell_renderer_text_new ();
793 gtk_cell_view_cell_layout_pack_start (GTK_CELL_LAYOUT (cellview),
796 g_value_init (&value, G_TYPE_STRING);
797 g_value_set_string (&value, text);
798 gtk_cell_view_set_values (cellview, renderer, "text", &value, NULL);
799 g_value_unset (&value);
801 return GTK_WIDGET (cellview);
805 * gtk_cell_view_new_with_markup:
806 * @markup: the text to display in the cell view
808 * Creates a new #GtkCellView widget, adds a #GtkCellRendererText
809 * to it, and makes its show @markup. The text can text can be
810 * marked up with the <link linkend="PangoMarkupFormat">Pango text
811 * markup language</link>.
813 * Return value: A newly created #GtkCellView widget.
818 gtk_cell_view_new_with_markup (const gchar *markup)
820 GtkCellView *cellview;
821 GtkCellRenderer *renderer;
822 GValue value = {0, };
824 cellview = GTK_CELL_VIEW (gtk_cell_view_new ());
826 renderer = gtk_cell_renderer_text_new ();
827 gtk_cell_view_cell_layout_pack_start (GTK_CELL_LAYOUT (cellview),
830 g_value_init (&value, G_TYPE_STRING);
831 g_value_set_string (&value, markup);
832 gtk_cell_view_set_values (cellview, renderer, "markup", &value, NULL);
833 g_value_unset (&value);
835 return GTK_WIDGET (cellview);
839 * gtk_cell_view_new_with_pixbuf:
840 * @pixbuf: the image to display in the cell view
842 * Creates a new #GtkCellView widget, adds a #GtkCellRendererPixbuf
843 * to it, and makes its show @pixbuf.
845 * Return value: A newly created #GtkCellView widget.
850 gtk_cell_view_new_with_pixbuf (GdkPixbuf *pixbuf)
852 GtkCellView *cellview;
853 GtkCellRenderer *renderer;
854 GValue value = {0, };
856 cellview = GTK_CELL_VIEW (gtk_cell_view_new ());
858 renderer = gtk_cell_renderer_pixbuf_new ();
859 gtk_cell_view_cell_layout_pack_start (GTK_CELL_LAYOUT (cellview),
862 g_value_init (&value, GDK_TYPE_PIXBUF);
863 g_value_set_object (&value, pixbuf);
864 gtk_cell_view_set_values (cellview, renderer, "pixbuf", &value, NULL);
865 g_value_unset (&value);
867 return GTK_WIDGET (cellview);
871 * gtk_cell_view_set_value:
872 * @cell_view: a #GtkCellView widget
873 * @renderer: one of the renderers of @cell_view
874 * @property: the name of the property of @renderer to set
875 * @value: the new value to set the property to
877 * Sets a property of a cell renderer of @cell_view, and
878 * makes sure the display of @cell_view is updated.
883 gtk_cell_view_set_value (GtkCellView *cell_view,
884 GtkCellRenderer *renderer,
888 g_return_if_fail (GTK_IS_CELL_VIEW (cell_view));
889 g_return_if_fail (GTK_IS_CELL_RENDERER (renderer));
891 g_object_set_property (G_OBJECT (renderer), property, value);
893 /* force resize and redraw */
894 gtk_widget_queue_resize (GTK_WIDGET (cell_view));
895 gtk_widget_queue_draw (GTK_WIDGET (cell_view));
899 gtk_cell_view_set_valuesv (GtkCellView *cell_view,
900 GtkCellRenderer *renderer,
906 attribute = va_arg (args, gchar *);
910 value = va_arg (args, GValue *);
911 gtk_cell_view_set_value (cell_view, renderer, attribute, value);
912 attribute = va_arg (args, gchar *);
917 * gtk_cell_view_set_values:
918 * @cell_view: a #GtkCellView widget
919 * @renderer: one of the renderers of @cell_view
920 * @Varargs: a list of pairs of property names and #GValue<!-- -->s,
923 * Sets multiple properties of a cell renderer of @cell_view, and
924 * makes sure the display of @cell_view is updated.
929 gtk_cell_view_set_values (GtkCellView *cell_view,
930 GtkCellRenderer *renderer,
935 g_return_if_fail (GTK_IS_CELL_VIEW (cell_view));
936 g_return_if_fail (GTK_IS_CELL_RENDERER (renderer));
937 g_return_if_fail (gtk_cell_view_get_cell_info (cell_view, renderer));
939 va_start (args, renderer);
940 gtk_cell_view_set_valuesv (cell_view, renderer, args);
945 * gtk_cell_view_set_model:
946 * @cell_view: a #GtkCellView
947 * @model: a #GtkTreeModel
949 * Sets the model for @cell_view. If @cell_view already has a model
950 * set, it will remove it before setting the new model. If @model is
951 * %NULL, then it will unset the old model.
956 gtk_cell_view_set_model (GtkCellView *cell_view,
959 g_return_if_fail (GTK_IS_CELL_VIEW (cell_view));
960 g_return_if_fail (GTK_IS_TREE_MODEL (model));
962 if (cell_view->priv->model)
964 if (cell_view->priv->displayed_row)
965 gtk_tree_row_reference_free (cell_view->priv->displayed_row);
966 cell_view->priv->displayed_row = NULL;
968 g_object_unref (cell_view->priv->model);
969 cell_view->priv->model = NULL;
972 cell_view->priv->model = model;
974 if (cell_view->priv->model)
975 g_object_ref (cell_view->priv->model);
979 * gtk_cell_view_set_displayed_row:
980 * @cell_view: a #GtkCellView
981 * @path: a #GtkTreePath or %NULL to unset.
983 * Sets the row of the model that is currently displayed
984 * by the #GtkCellView. If the path is unset, then the
985 * contents of the cellview "stick" at their last value;
986 * this is not normally a desired result, but may be
987 * a needed intermediate state if say, the model for
988 * the #GtkCellView becomes temporarily empty.
993 gtk_cell_view_set_displayed_row (GtkCellView *cell_view,
996 g_return_if_fail (GTK_IS_CELL_VIEW (cell_view));
997 g_return_if_fail (GTK_IS_TREE_MODEL (cell_view->priv->model));
999 if (cell_view->priv->displayed_row)
1000 gtk_tree_row_reference_free (cell_view->priv->displayed_row);
1004 cell_view->priv->displayed_row =
1005 gtk_tree_row_reference_new (cell_view->priv->model, path);
1008 cell_view->priv->displayed_row = NULL;
1010 /* force resize and redraw */
1011 gtk_widget_queue_resize (GTK_WIDGET (cell_view));
1012 gtk_widget_queue_draw (GTK_WIDGET (cell_view));
1016 gtk_cell_view_get_displayed_row (GtkCellView *cell_view)
1018 g_return_val_if_fail (GTK_IS_CELL_VIEW (cell_view), NULL);
1020 if (!cell_view->priv->displayed_row)
1023 return gtk_tree_row_reference_get_path (cell_view->priv->displayed_row);
1027 * gtk_cell_view_get_size_of_row:
1028 * @cell_view: a #GtkCellView
1029 * @path: a #GtkTreePath
1030 * @requisition: return location for the size
1032 * Sets @requisition to the size needed by @cell_view to display
1033 * the model row pointed to by @path.
1035 * Return value: %TRUE
1040 gtk_cell_view_get_size_of_row (GtkCellView *cell_view,
1042 GtkRequisition *requisition)
1044 GtkTreeRowReference *tmp;
1047 g_return_val_if_fail (GTK_IS_CELL_VIEW (cell_view), FALSE);
1048 g_return_val_if_fail (path != NULL, FALSE);
1049 g_return_val_if_fail (requisition != NULL, FALSE);
1051 tmp = cell_view->priv->displayed_row;
1052 cell_view->priv->displayed_row =
1053 gtk_tree_row_reference_new (cell_view->priv->model, path);
1055 gtk_cell_view_size_request (GTK_WIDGET (cell_view), requisition);
1057 gtk_tree_row_reference_free (cell_view->priv->displayed_row);
1058 cell_view->priv->displayed_row = tmp;
1060 /* restore actual size info */
1061 gtk_cell_view_size_request (GTK_WIDGET (cell_view), &req);
1067 * gtk_cell_view_set_background_color:
1068 * @cell_view: a #GtkCellView
1069 * @color: the new background color
1071 * Sets the background color of @view.
1076 gtk_cell_view_set_background_color (GtkCellView *cell_view,
1077 const GdkColor *color)
1079 g_return_if_fail (GTK_IS_CELL_VIEW (cell_view));
1083 if (!cell_view->priv->background_set)
1085 cell_view->priv->background_set = TRUE;
1086 g_object_notify (G_OBJECT (cell_view), "background_set");
1089 cell_view->priv->background = *color;
1093 if (cell_view->priv->background_set)
1095 cell_view->priv->background_set = FALSE;
1096 g_object_notify (G_OBJECT (cell_view), "background_set");
1100 gtk_widget_queue_draw (GTK_WIDGET (cell_view));
1104 * gtk_cell_view_get_cell_renderers:
1105 * @cell_view: a #GtkCellView
1107 * Returns the cell renderers which have been added to @cell_view.
1109 * Return value: a list of cell renderers. The list, but not the
1110 * renderers has been newly allocated and should be freed with
1111 * g_list_free() when no longer needed.
1116 gtk_cell_view_get_cell_renderers (GtkCellView *cell_view)
1118 GList *retval = NULL, *list;
1120 g_return_val_if_fail (cell_view != NULL, NULL);
1122 gtk_cell_view_set_cell_data (cell_view);
1124 for (list = cell_view->priv->cell_list; list; list = list->next)
1126 GtkCellViewCellInfo *info = (GtkCellViewCellInfo *)list->data;
1128 retval = g_list_prepend (retval, info->cell);
1131 return g_list_reverse (retval);