[gtk+] iconview: Respect the fixed item width when adjusting the wrap width
- From: Benjamin Otte <otte src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+] iconview: Respect the fixed item width when adjusting the wrap width
- Date: Mon, 26 Aug 2013 16:24:49 +0000 (UTC)
commit 247ebbd17c70d2fe82b48d857549ceeeaad500ff
Author: Carlos Garcia Campos <carlosgc gnome org>
Date: Sun Sep 30 13:09:53 2012 +0200
iconview: Respect the fixed item width when adjusting the wrap width
Restore the code the way it was in GTK2.
https://bugzilla.gnome.org/show_bug.cgi?id=680953
gtk/gtkiconview.c | 40 +++++++++++++++++++++++++++++++++-------
1 files changed, 33 insertions(+), 7 deletions(-)
---
diff --git a/gtk/gtkiconview.c b/gtk/gtkiconview.c
index 070378a..20e6175 100644
--- a/gtk/gtkiconview.c
+++ b/gtk/gtkiconview.c
@@ -1390,16 +1390,42 @@ adjust_wrap_width (GtkIconView *icon_view)
{
if (icon_view->priv->text_cell)
{
- gint wrap_width = 50;
+ gint pixbuf_width, wrap_width;
+
+ if (icon_view->priv->items && icon_view->priv->pixbuf_cell)
+ {
+ gtk_cell_renderer_get_preferred_width (icon_view->priv->pixbuf_cell,
+ GTK_WIDGET (icon_view),
+ &pixbuf_width, NULL);
+ }
+ else
+ {
+ pixbuf_width = 0;
+ }
+
+ if (icon_view->priv->item_width >= 0)
+ {
+ if (icon_view->priv->item_orientation == GTK_ORIENTATION_VERTICAL)
+ {
+ wrap_width = icon_view->priv->item_width;
+ }
+ else
+ {
+ wrap_width = icon_view->priv->item_width - pixbuf_width;
+ }
+
+ wrap_width -= 2 * icon_view->priv->item_padding * 2;
+ }
+ else
+ {
+ wrap_width = MAX (pixbuf_width * 2, 50);
+ }
- /* Here we go with the same old guess, try the icon size and set double
- * the size of the first icon found in the list, naive but works much
- * of the time */
if (icon_view->priv->items && icon_view->priv->pixbuf_cell)
{
- gtk_cell_renderer_get_preferred_width (icon_view->priv->pixbuf_cell,
- GTK_WIDGET (icon_view),
- &wrap_width, NULL);
+ /* Here we go with the same old guess, try the icon size and set double
+ * the size of the first icon found in the list, naive but works much
+ * of the time */
wrap_width = MAX (wrap_width * 2, 50);
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]