diff options
author | Suman Manjunath <msuman@src.gnome.org> | 2008-07-07 16:50:34 +0800 |
---|---|---|
committer | Suman Manjunath <msuman@src.gnome.org> | 2008-07-07 16:50:34 +0800 |
commit | 1fe74f379d97c06001ba47c782f736b8ff42146f (patch) | |
tree | fc76805202382e5b535eaedbbfcbcc733264c4a4 | |
parent | d9bf503861934651c02ee0932ae0f0d3e58308e0 (diff) | |
download | gsoc2013-evolution-1fe74f379d97c06001ba47c782f736b8ff42146f.tar.gz gsoc2013-evolution-1fe74f379d97c06001ba47c782f736b8ff42146f.tar.zst gsoc2013-evolution-1fe74f379d97c06001ba47c782f736b8ff42146f.zip |
Fix for bug #370731 (bugzilla.novell.com): Use MAX (<max width of day-names>, (2 * <max width of a digit>)) to determine the minimal size for each cell. This prevents the numbers and day-names from getting fuzzy when using large font-sizes.
svn path=/trunk/; revision=35731
-rw-r--r-- | widgets/misc/ChangeLog | 12 | ||||
-rw-r--r-- | widgets/misc/e-calendar-item.c | 17 | ||||
-rw-r--r-- | widgets/misc/e-calendar-item.h | 2 |
3 files changed, 25 insertions, 6 deletions
diff --git a/widgets/misc/ChangeLog b/widgets/misc/ChangeLog index 64aaad5152..83bc08112c 100644 --- a/widgets/misc/ChangeLog +++ b/widgets/misc/ChangeLog @@ -1,3 +1,15 @@ +2008-07-07 Suman Manjunath <msuman@novell.com> + + ** Fix for bug #370731 (bugzilla.novell.com) + + * e-calendar-item.c (e_calendar_item_update), + (e_calendar_item_draw_month), (e_calendar_item_draw_day_numbers), + (e_calendar_item_recalc_sizes): + * e-calendar-item.h: + Use MAX (<max width of day-names>, (2 * <max width of a digit>)) + to determine the minimal size for each cell. This prevents the numbers + and day-names from getting fuzzy when using large font-sizes. + 2008-06-30 Srinivasa Ragavan <sragavan@novell.com> ** Fix for bug #519536 diff --git a/widgets/misc/e-calendar-item.c b/widgets/misc/e-calendar-item.c index 64e2002d96..2d7a78a5eb 100644 --- a/widgets/misc/e-calendar-item.c +++ b/widgets/misc/e-calendar-item.c @@ -974,7 +974,7 @@ e_calendar_item_update (GnomeCanvasItem *item, calitem->month_width = calitem->min_month_width; calitem->month_height = calitem->min_month_height; - calitem->cell_width = calitem->max_digit_width * 2 + calitem->cell_width = MAX (calitem->max_day_width, (calitem->max_digit_width * 2)) + E_CALENDAR_ITEM_MIN_CELL_XPAD; calitem->cell_height = char_height + E_CALENDAR_ITEM_MIN_CELL_YPAD; @@ -1305,7 +1305,7 @@ e_calendar_item_draw_month (ECalendarItem *calitem, gdk_gc_set_clip_rectangle (fg_gc, &clip_rect); /* Draw the day initials across the top of the month. */ - min_cell_width = calitem->max_digit_width * 2 + min_cell_width = MAX (calitem->max_day_width, (calitem->max_digit_width * 2)) + E_CALENDAR_ITEM_MIN_CELL_XPAD; cells_x = month_x + E_CALENDAR_ITEM_XPAD_BEFORE_WEEK_NUMBERS + calitem->month_lpad @@ -1431,7 +1431,7 @@ e_calendar_item_draw_day_numbers (ECalendarItem *calitem, PANGO_PIXELS (pango_font_metrics_get_ascent (font_metrics)) + PANGO_PIXELS (pango_font_metrics_get_descent (font_metrics)); - min_cell_width = calitem->max_digit_width * 2 + min_cell_width = MAX (calitem->max_day_width, (calitem->max_digit_width * 2)) + E_CALENDAR_ITEM_MIN_CELL_XPAD; min_cell_height = char_height + E_CALENDAR_ITEM_MIN_CELL_YPAD; @@ -1920,7 +1920,7 @@ e_calendar_item_recalc_sizes (ECalendarItem *calitem) GnomeCanvasItem *canvas_item; GtkStyle *style; gchar *digits = "0123456789"; - gint day, digit, max_digit_width, max_week_number_digit_width; + gint day, max_day_width, digit, max_digit_width, max_week_number_digit_width; gint char_height, width, min_cell_width, min_cell_height; PangoFontDescription *font_desc, *wkfont_desc; PangoContext *pango_context; @@ -1949,10 +1949,15 @@ e_calendar_item_recalc_sizes (ECalendarItem *calitem) PANGO_PIXELS (pango_font_metrics_get_ascent (font_metrics)) + PANGO_PIXELS (pango_font_metrics_get_descent (font_metrics)); + max_day_width = 0; for (day = 0; day < 7; day++) { layout_set_day_text (calitem, layout, day); - pango_layout_get_pixel_size (layout, &calitem->day_widths [day], NULL); + pango_layout_get_pixel_size (layout, &width, NULL); + + calitem->day_widths[day] = width; + max_day_width = MAX (max_day_width, width); } + calitem->max_day_width = max_day_width; max_digit_width = 0; max_week_number_digit_width = 0; @@ -1983,7 +1988,7 @@ e_calendar_item_recalc_sizes (ECalendarItem *calitem) calitem->max_digit_width = max_digit_width; calitem->max_week_number_digit_width = max_week_number_digit_width; - min_cell_width = calitem->max_digit_width * 2 + min_cell_width = MAX (calitem->max_day_width, (calitem->max_digit_width * 2)) + E_CALENDAR_ITEM_MIN_CELL_XPAD; min_cell_height = char_height + E_CALENDAR_ITEM_MIN_CELL_YPAD; diff --git a/widgets/misc/e-calendar-item.h b/widgets/misc/e-calendar-item.h index 843d531c05..42efd5358f 100644 --- a/widgets/misc/e-calendar-item.h +++ b/widgets/misc/e-calendar-item.h @@ -218,10 +218,12 @@ struct _ECalendarItem /* Widths of the day characters. */ gint day_widths[7]; + gint max_day_width; /* Widths of the digits, '0' .. '9'. */ gint digit_widths[10]; gint max_digit_width; + gint week_number_digit_widths[10]; gint max_week_number_digit_width; |