diff options
author | Diego Escalante Urrelo <diegoe@igalia.com> | 2012-03-28 05:43:32 +0800 |
---|---|---|
committer | Diego Escalante Urrelo <diegoe@igalia.com> | 2012-03-31 03:58:55 +0800 |
commit | 5f99eda5841d20f01c5ba887c67a68ab0e175c24 (patch) | |
tree | 9b86809a7977f338d41e3517aa3709d7d6a2ef90 | |
parent | 0b9943bc68e6d64c52f365a8d8253c6e074576c6 (diff) | |
download | gsoc2013-epiphany-5f99eda5841d20f01c5ba887c67a68ab0e175c24.tar gsoc2013-epiphany-5f99eda5841d20f01c5ba887c67a68ab0e175c24.tar.gz gsoc2013-epiphany-5f99eda5841d20f01c5ba887c67a68ab0e175c24.tar.bz2 gsoc2013-epiphany-5f99eda5841d20f01c5ba887c67a68ab0e175c24.tar.lz gsoc2013-epiphany-5f99eda5841d20f01c5ba887c67a68ab0e175c24.tar.xz gsoc2013-epiphany-5f99eda5841d20f01c5ba887c67a68ab0e175c24.tar.zst gsoc2013-epiphany-5f99eda5841d20f01c5ba887c67a68ab0e175c24.zip |
e-location-entry: make aligment pixel-perfect
Align the elements of the GtkEntryCompletion popup with those in the
location entry. The code comes with a detailed comment and a scheme of
how the aligment is done now.
Because of the unhandled pixels of GtkEntryCompletion, this code might
need an update if anything in GTK+ or Adwaita changes.
https://bugzilla.gnome.org/show_bug.cgi?id=672927
-rw-r--r-- | lib/widgets/ephy-location-entry.c | 59 |
1 files changed, 59 insertions, 0 deletions
diff --git a/lib/widgets/ephy-location-entry.c b/lib/widgets/ephy-location-entry.c index d0d2b0d6e..ad36fe125 100644 --- a/lib/widgets/ephy-location-entry.c +++ b/lib/widgets/ephy-location-entry.c @@ -1033,12 +1033,66 @@ ephy_location_entry_set_completion (EphyLocationEntry *entry, gtk_cell_layout_add_attribute (GTK_CELL_LAYOUT (completion), cell, "pixbuf", favicon_col); + /* Pixel-perfect aligment with the location entry favicon + * (16x16). Consider that this /might/ depend on the theme. + * + * The GtkEntryCompletion can not be themed so we work-around + * that with padding and fixed sizes. + * For the first cell, this is: + * + * ___+++++iiiiiiiiiiiiiiii++__ttt...bbb++++++__ + * + * _ = widget spacing, can not be handled (3 px) + * + = padding (5 px) (ICON_PADDING_LEFT) + * i = the icon (16 px) (ICON_CONTENT_WIDTH) + * + = padding (2 px) (ICON_PADDING_RIGHT) (cut by the fixed_size) + * _ = spacing between cells, can not be handled (2 px) + * t = the text (expands) + * b = bookmark icon (16 px) + * + = padding (6 px) (BKMK_PADDING_RIGHT) + * _ = widget spacing, can not be handled (2 px) + * + * Each character is a pixel. + * + * The text cell and the bookmark icon cell are much more + * flexible in its aligment, because they do not have to align + * with anything in the entry. + */ + +#define ROW_PADDING_VERT 2 + +#define ICON_PADDING_LEFT 5 +#define ICON_CONTENT_WIDTH 16 +#define ICON_PADDING_RIGHT 2 + +#define ICON_CONTENT_HEIGHT 16 + +#define TEXT_PADDING_LEFT 0 + +#define BKMK_PADDING_RIGHT 6 + + gtk_cell_renderer_set_padding + (cell, ICON_PADDING_LEFT, ROW_PADDING_VERT); + gtk_cell_renderer_set_fixed_size + (cell, + (ICON_PADDING_LEFT + ICON_CONTENT_WIDTH + ICON_PADDING_RIGHT), + ICON_CONTENT_HEIGHT); + gtk_cell_renderer_set_alignment (cell, 0.0, 0.5); + cell = gtk_cell_renderer_text_new (); g_object_set (cell, "ellipsize", PANGO_ELLIPSIZE_END, NULL); gtk_cell_layout_pack_start (GTK_CELL_LAYOUT (completion), cell, TRUE); gtk_cell_layout_add_attribute (GTK_CELL_LAYOUT (completion), cell, "text", text_col); + + /* Pixel-perfect aligment with the text in the location entry. + * See above. + */ + gtk_cell_renderer_set_padding + (cell, TEXT_PADDING_LEFT, ROW_PADDING_VERT); + gtk_cell_renderer_set_alignment (cell, 0.0, 0.5); + /* * As the width of the entry completion is known in advance * (as big as the entry you are completing on), we can set @@ -1064,6 +1118,11 @@ ephy_location_entry_set_completion (EphyLocationEntry *entry, entry, NULL); + /* Pixel-perfect aligment. This just keeps the same margin from + * the border than the favicon on the other side. See above. */ + gtk_cell_renderer_set_padding + (cell, BKMK_PADDING_RIGHT, ROW_PADDING_VERT); + g_object_set (completion, "inline-selection", TRUE, NULL); g_signal_connect (completion, "cursor-on-match", G_CALLBACK (cursor_on_match_cb), entry); |