[gtk+/popovers: 34/42] Implement wfh functions
- From: Carlos Garnacho <carlosg src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+/popovers: 34/42] Implement wfh functions
- Date: Wed, 15 Jan 2014 12:44:12 +0000 (UTC)
commit 4b5476686d152b978f00eb2df59ab983212bb30d
Author: Matthias Clasen <mclasen redhat com>
Date: Fri Jan 10 17:43:42 2014 -0500
Implement wfh functions
With only get_preferred_width and get_preferred_height implemented,
we end up calling the GtkBin height_for_width implmementation, which
knows nothing about the margins and paddings that GtkPopover needs.
As a result, a listbox added to a popover was getting cut off
at the bottom.
gtk/gtkpopover.c | 90 +++++++++++++++++++++++++++++++++++++++++++++++++++++-
1 files changed, 89 insertions(+), 1 deletions(-)
---
diff --git a/gtk/gtkpopover.c b/gtk/gtkpopover.c
index c5cdf77..6420881 100644
--- a/gtk/gtkpopover.c
+++ b/gtk/gtkpopover.c
@@ -730,6 +730,50 @@ gtk_popover_get_preferred_width (GtkWidget *widget,
}
static void
+gtk_popover_get_preferred_width_for_height (GtkWidget *widget,
+ gint height,
+ gint *minimum_width,
+ gint *natural_width)
+{
+ GtkPopoverPrivate *priv;
+ GtkWidget *child;
+ gint min, nat;
+ gint child_height;
+ GtkBorder border;
+
+ priv = GTK_POPOVER (widget)->priv;
+ child = gtk_bin_get_child (GTK_BIN (widget));
+ min = nat = 0;
+
+ child_height = height;
+
+ if (POS_IS_VERTICAL (priv->preferred_position))
+ child_height -= TAIL_HEIGHT;
+
+ get_padding_and_border (widget, &border);
+ child_height -= border.top + border.bottom;
+
+ if (child)
+ gtk_widget_get_preferred_width_for_height (child, child_height, &min, &nat);
+
+ get_padding_and_border (widget, &border);
+ min += border.left + border.right;
+ nat += border.left + border.right;
+
+ if (!POS_IS_VERTICAL (priv->preferred_position))
+ {
+ min += TAIL_HEIGHT;
+ nat += TAIL_HEIGHT;
+ }
+
+ if (minimum_width)
+ *minimum_width = MAX (min, TAIL_GAP_WIDTH);
+
+ if (natural_width)
+ *natural_width = MAX (nat, TAIL_GAP_WIDTH);
+}
+
+static void
gtk_popover_get_preferred_height (GtkWidget *widget,
gint *minimum_height,
gint *natural_height)
@@ -764,6 +808,49 @@ gtk_popover_get_preferred_height (GtkWidget *widget,
}
static void
+gtk_popover_get_preferred_height_for_width (GtkWidget *widget,
+ gint width,
+ gint *minimum_height,
+ gint *natural_height)
+{
+ GtkPopoverPrivate *priv;
+ GtkWidget *child;
+ gint min, nat;
+ gint child_width;
+ GtkBorder border;
+
+ priv = GTK_POPOVER (widget)->priv;
+ child = gtk_bin_get_child (GTK_BIN (widget));
+ min = nat = 0;
+
+ child_width = width;
+
+ if (!POS_IS_VERTICAL (priv->preferred_position))
+ child_width -= TAIL_HEIGHT;
+
+ get_padding_and_border (widget, &border);
+ child_width -= border.left + border.right;
+
+ if (child)
+ gtk_widget_get_preferred_height_for_width (child, child_width, &min, &nat);
+
+ min += border.top + border.bottom;
+ nat += border.top + border.bottom;
+
+ if (POS_IS_VERTICAL (priv->preferred_position))
+ {
+ min += TAIL_HEIGHT;
+ nat += TAIL_HEIGHT;
+ }
+
+ if (minimum_height)
+ *minimum_height = MAX (min, TAIL_GAP_WIDTH);
+
+ if (natural_height)
+ *natural_height = MAX (nat, TAIL_GAP_WIDTH);
+}
+
+static void
gtk_popover_size_allocate (GtkWidget *widget,
GtkAllocation *allocation)
{
@@ -771,7 +858,6 @@ gtk_popover_size_allocate (GtkWidget *widget,
gtk_widget_set_allocation (widget, allocation);
child = gtk_bin_get_child (GTK_BIN (widget));
-
if (child)
{
GtkAllocation child_alloc;
@@ -892,6 +978,8 @@ gtk_popover_class_init (GtkPopoverClass *klass)
widget_class->unmap = gtk_popover_unmap;
widget_class->get_preferred_width = gtk_popover_get_preferred_width;
widget_class->get_preferred_height = gtk_popover_get_preferred_height;
+ widget_class->get_preferred_width_for_height = gtk_popover_get_preferred_width_for_height;
+ widget_class->get_preferred_height_for_width = gtk_popover_get_preferred_height_for_width;
widget_class->size_allocate = gtk_popover_size_allocate;
widget_class->draw = gtk_popover_draw;
widget_class->button_press_event = gtk_popover_button_press;
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]