summaryrefslogtreecommitdiff
path: root/gtk/gtkcalendar.c
diff options
context:
space:
mode:
authorBenjamin Otte <otte@redhat.com>2010-09-04 19:07:39 +0200
committerBenjamin Otte <otte@redhat.com>2010-09-26 15:11:35 +0200
commit02572cdf7ef27ec514f605c7518ea3187ca6d658 (patch)
tree09ed4eb166e743716754e1deb5f5a760b4a11802 /gtk/gtkcalendar.c
parented996bcd682fa2b78bb3a97f3df4487bdaa86630 (diff)
downloadgtk+-02572cdf7ef27ec514f605c7518ea3187ca6d658.tar.gz
calendar: Create one cairo_t per expose event and pass it around
Diffstat (limited to 'gtk/gtkcalendar.c')
-rw-r--r--gtk/gtkcalendar.c88
1 files changed, 39 insertions, 49 deletions
diff --git a/gtk/gtkcalendar.c b/gtk/gtkcalendar.c
index bb7894d8b9..7f214e12b4 100644
--- a/gtk/gtkcalendar.c
+++ b/gtk/gtkcalendar.c
@@ -2308,13 +2308,12 @@ gtk_calendar_size_allocate (GtkWidget *widget,
****************************************/
static void
-calendar_paint_header (GtkCalendar *calendar)
+calendar_paint_header (GtkCalendar *calendar, cairo_t *cr)
{
GtkWidget *widget = GTK_WIDGET (calendar);
GtkCalendarPrivate *priv = GTK_CALENDAR_GET_PRIVATE (calendar);
GtkAllocation allocation;
GtkStyle *style;
- cairo_t *cr;
char buffer[255];
int x, y;
gint header_width;
@@ -2332,8 +2331,6 @@ calendar_paint_header (GtkCalendar *calendar)
else
year_left = !priv->year_before;
- cr = gdk_cairo_create (priv->header_win);
-
gtk_widget_get_allocation (widget, &allocation);
style = gtk_widget_get_style (widget);
@@ -2342,9 +2339,9 @@ calendar_paint_header (GtkCalendar *calendar)
max_month_width = priv->max_month_width;
max_year_width = priv->max_year_width;
- gtk_paint_shadow (style, priv->header_win,
+ gtk_cairo_paint_shadow (style, cr,
GTK_STATE_NORMAL, GTK_SHADOW_OUT,
- NULL, widget, "calendar",
+ widget, "calendar",
0, 0, header_width, priv->header_h);
tmp_time = 1; /* Jan 1 1970, 00:00:01 UTC */
@@ -2413,16 +2410,15 @@ calendar_paint_header (GtkCalendar *calendar)
pango_cairo_show_layout (cr, layout);
g_object_unref (layout);
- cairo_destroy (cr);
}
static void
-calendar_paint_day_names (GtkCalendar *calendar)
+calendar_paint_day_names (GtkCalendar *calendar,
+ cairo_t *cr)
{
GtkWidget *widget = GTK_WIDGET (calendar);
GtkCalendarPrivate *priv = GTK_CALENDAR_GET_PRIVATE (calendar);
GtkAllocation allocation;
- cairo_t *cr;
char buffer[255];
int day,i;
int day_width, cal_width;
@@ -2434,8 +2430,6 @@ calendar_paint_day_names (GtkCalendar *calendar)
gint calendar_ysep = calendar_get_ysep (calendar);
gint calendar_xsep = calendar_get_xsep (calendar);
- cr = gdk_cairo_create (priv->day_name_win);
-
gtk_widget_style_get (GTK_WIDGET (widget),
"focus-line-width", &focus_width,
"focus-padding", &focus_padding,
@@ -2499,15 +2493,14 @@ calendar_paint_day_names (GtkCalendar *calendar)
}
g_object_unref (layout);
- cairo_destroy (cr);
}
static void
-calendar_paint_week_numbers (GtkCalendar *calendar)
+calendar_paint_week_numbers (GtkCalendar *calendar,
+ cairo_t *cr)
{
GtkWidget *widget = GTK_WIDGET (calendar);
GtkCalendarPrivate *priv = GTK_CALENDAR_GET_PRIVATE (calendar);
- cairo_t *cr;
guint week = 0, year;
gint row, x_loc, y_loc;
@@ -2519,8 +2512,6 @@ calendar_paint_week_numbers (GtkCalendar *calendar)
gint focus_width;
gint calendar_xsep = calendar_get_xsep (calendar);
- cr = gdk_cairo_create (priv->week_win);
-
gtk_widget_style_get (GTK_WIDGET (widget),
"focus-line-width", &focus_width,
"focus-padding", &focus_padding,
@@ -2591,7 +2582,6 @@ calendar_paint_week_numbers (GtkCalendar *calendar)
}
g_object_unref (layout);
- cairo_destroy (cr);
}
static void
@@ -2644,13 +2634,13 @@ is_color_attribute (PangoAttribute *attribute,
static void
calendar_paint_day (GtkCalendar *calendar,
- gint row,
- gint col)
+ cairo_t *cr,
+ gint row,
+ gint col)
{
GtkWidget *widget = GTK_WIDGET (calendar);
GtkCalendarPrivate *priv = GTK_CALENDAR_GET_PRIVATE (calendar);
GtkStyle *style;
- cairo_t *cr;
GdkColor *text_color;
gchar *detail;
gchar buffer[32];
@@ -2668,8 +2658,6 @@ calendar_paint_day (GtkCalendar *calendar,
style = gtk_widget_get_style (widget);
- cr = gdk_cairo_create (priv->main_win);
-
day = priv->day[row][col];
show_details = (priv->display_flags & GTK_CALENDAR_SHOW_DETAILS);
@@ -2807,10 +2795,8 @@ calendar_paint_day (GtkCalendar *calendar,
else
state = GTK_STATE_NORMAL;
- gtk_paint_focus (style,
- priv->main_win,
- state,
- NULL, widget, "calendar-day",
+ gtk_cairo_paint_focus (style, cr,
+ state, widget, "calendar-day",
day_rect.x, day_rect.y,
day_rect.width, day_rect.height);
}
@@ -2821,18 +2807,18 @@ calendar_paint_day (GtkCalendar *calendar,
priv->detail_overflow[row] &= ~(1 << col);
g_object_unref (layout);
- cairo_destroy (cr);
g_free (detail);
}
static void
-calendar_paint_main (GtkCalendar *calendar)
+calendar_paint_main (GtkCalendar *calendar,
+ cairo_t *cr)
{
gint row, col;
for (col = 0; col < 7; col++)
for (row = 0; row < 6; row++)
- calendar_paint_day (calendar, row, col);
+ calendar_paint_day (calendar, cr, row, col);
}
static void
@@ -2849,7 +2835,8 @@ calendar_invalidate_arrow (GtkCalendar *calendar,
static void
calendar_paint_arrow (GtkCalendar *calendar,
- guint arrow)
+ cairo_t *cr,
+ guint arrow)
{
GtkWidget *widget = GTK_WIDGET (calendar);
GtkCalendarPrivate *priv = GTK_CALENDAR_GET_PRIVATE (widget);
@@ -2859,7 +2846,6 @@ calendar_paint_arrow (GtkCalendar *calendar,
if (window)
{
GtkStyle *style;
- cairo_t *cr = gdk_cairo_create (window);
gint width, height;
gint state;
@@ -2868,17 +2854,16 @@ calendar_paint_arrow (GtkCalendar *calendar,
gdk_cairo_set_source_color (cr, &style->bg[state]);
cairo_paint (cr);
- cairo_destroy (cr);
gdk_drawable_get_size (window, &width, &height);
if (arrow == ARROW_MONTH_LEFT || arrow == ARROW_YEAR_LEFT)
- gtk_paint_arrow (style, window, state,
- GTK_SHADOW_OUT, NULL, widget, "calendar",
+ gtk_cairo_paint_arrow (style, cr, state,
+ GTK_SHADOW_OUT, widget, "calendar",
GTK_ARROW_LEFT, TRUE,
width/2 - 3, height/2 - 4, 8, 8);
else
- gtk_paint_arrow (style, window, state,
- GTK_SHADOW_OUT, NULL, widget, "calendar",
+ gtk_cairo_paint_arrow (style, cr, state,
+ GTK_SHADOW_OUT, widget, "calendar",
GTK_ARROW_RIGHT, TRUE,
width/2 - 4, height/2 - 4, 8, 8);
}
@@ -2890,40 +2875,45 @@ gtk_calendar_expose (GtkWidget *widget,
{
GtkCalendar *calendar = GTK_CALENDAR (widget);
GtkCalendarPrivate *priv = GTK_CALENDAR_GET_PRIVATE (widget);
+ cairo_t *cr;
int i;
if (gtk_widget_is_drawable (widget))
{
GdkWindow *window;
+ cr = gdk_cairo_create (event->window);
+ gdk_cairo_region (cr, event->region);
+ cairo_clip (cr);
+
if (event->window == priv->main_win)
- calendar_paint_main (calendar);
+ calendar_paint_main (calendar, cr);
if (event->window == priv->header_win)
- calendar_paint_header (calendar);
+ calendar_paint_header (calendar, cr);
for (i = 0; i < 4; i++)
if (event->window == priv->arrow_win[i])
- calendar_paint_arrow (calendar, i);
+ calendar_paint_arrow (calendar, cr, i);
if (event->window == priv->day_name_win)
- calendar_paint_day_names (calendar);
+ calendar_paint_day_names (calendar, cr);
if (event->window == priv->week_win)
- calendar_paint_week_numbers (calendar);
+ calendar_paint_week_numbers (calendar, cr);
window = gtk_widget_get_window (widget);
if (event->window == window)
{
- GtkAllocation allocation;
-
- gtk_widget_get_allocation (widget, &allocation);
- gtk_paint_shadow (gtk_widget_get_style (widget),
- window,
- gtk_widget_get_state (widget),
- GTK_SHADOW_IN, NULL, widget, "calendar",
- 0, 0, allocation.width, allocation.height);
+ gtk_cairo_paint_shadow (gtk_widget_get_style (widget), cr,
+ gtk_widget_get_state (widget), GTK_SHADOW_IN,
+ widget, "calendar",
+ 0, 0,
+ gtk_widget_get_allocated_width (widget),
+ gtk_widget_get_allocated_height (widget));
}
+
+ cairo_destroy (cr);
}
return FALSE;