diff options
author | Timm Bäder <mail@baedert.org> | 2020-12-21 12:44:01 +0100 |
---|---|---|
committer | Timm Bäder <mail@baedert.org> | 2020-12-21 12:44:01 +0100 |
commit | e7a326e230b763ee97798c49d7a03af2f9ab93ae (patch) | |
tree | 597337244fd51dfc6f360b07eda4f4d945d1bd14 /gtk/gtklabel.c | |
parent | 9eaeaa8452b578ddceb4f464b507f1ab1a265246 (diff) | |
download | gtk+-e7a326e230b763ee97798c49d7a03af2f9ab93ae.tar.gz |
label: Refactor get_layout_location()
Rename a few local variables to be clearer about whether they belong to
the widget or to the layout.
Remove a workaround for an old bug that is no longer valid. We don't
underallocate the layout anymore. Aways center vertically, with respect
to the yalign.
Diffstat (limited to 'gtk/gtklabel.c')
-rw-r--r-- | gtk/gtklabel.c | 37 |
1 files changed, 9 insertions, 28 deletions
diff --git a/gtk/gtklabel.c b/gtk/gtklabel.c index b27995df58..19b0386c05 100644 --- a/gtk/gtklabel.c +++ b/gtk/gtklabel.c @@ -3199,12 +3199,11 @@ get_layout_location (GtkLabel *self, int *yp) { GtkWidget *widget = GTK_WIDGET (self); - int req_width, x, y; - int req_height; + int layout_width, layout_height, x, y; float xalign, yalign; PangoRectangle logical; int baseline, layout_baseline, baseline_offset; - int label_width, label_height; + int widget_width, widget_height; xalign = self->xalign; yalign = self->yalign; @@ -3212,19 +3211,17 @@ get_layout_location (GtkLabel *self, if (_gtk_widget_get_direction (widget) != GTK_TEXT_DIR_LTR) xalign = 1.0 - xalign; - pango_layout_get_extents (self->layout, NULL, &logical); + pango_layout_get_pixel_extents (self->layout, NULL, &logical); - pango_extents_to_pixels (&logical, NULL); + layout_width = logical.width; + layout_height = logical.height; - req_width = logical.width; - req_height = logical.height; - - label_width = gtk_widget_get_width (widget); - label_height = gtk_widget_get_height (widget); + widget_width = gtk_widget_get_width (widget); + widget_height = gtk_widget_get_height (widget); baseline = gtk_widget_get_allocated_baseline (widget); - x = floor ((xalign * (label_width - req_width)) - logical.x); + x = floor ((xalign * (widget_width - layout_width)) - logical.x); baseline_offset = 0; if (baseline != -1) @@ -3234,23 +3231,7 @@ get_layout_location (GtkLabel *self, yalign = 0.0; /* Can't support yalign while baseline aligning */ } - /* bgo#315462 - For single-line labels, *do* align the requisition with - * respect to the allocation, even if we are under-allocated. For multi-line - * labels, always show the top of the text when they are under-allocated. The - * rationale is this: - * - * - Single-line labels appear in GtkButtons, and it is very easy to get them - * to be smaller than their requisition. The button may clip the label, but - * the label will still be able to show most of itself and the focus - * rectangle. Also, it is fairly easy to read a single line of clipped text. - * - * - Multi-line labels should not be clipped to showing "something in the - * middle". You want to read the first line, at least, to get some context. - */ - if (pango_layout_get_line_count (self->layout) == 1) - y = floor ((label_height - req_height) * yalign) + baseline_offset; - else - y = floor (MAX ((label_height - req_height) * yalign, 0)) + baseline_offset; + y = floor ((widget_height - layout_height) * yalign) + baseline_offset; if (xp) *xp = x; |