diff options
Diffstat (limited to 'libdocument')
| -rw-r--r-- | libdocument/ev-document-misc.c | 23 | 
1 files changed, 23 insertions, 0 deletions
| diff --git a/libdocument/ev-document-misc.c b/libdocument/ev-document-misc.c index e7398dee..a695c050 100644 --- a/libdocument/ev-document-misc.c +++ b/libdocument/ev-document-misc.c @@ -140,10 +140,29 @@ ev_document_misc_paint_one_page (cairo_t      *cr,  				 gboolean      highlight,  				 gboolean      inverted_colors)  { +#if GTK_CHECK_VERSION (3, 0, 0) +	GtkStyleContext *context = gtk_widget_get_style_context (widget); +	GtkStateFlags state = gtk_widget_get_state_flags (widget); +        GdkRGBA fg, bg, shade_bg; +        GtkSymbolicColor *c1, *c2; + +        gtk_style_context_get_background_color (context, state, &bg); +        gtk_style_context_get_color (context, state, &fg); + +        // FIXME: should we cache the shade_bg? +        c1 = gtk_symbolic_color_new_literal (&bg); +        c2 = gtk_symbolic_color_new_shade (c1, 0.7); +        gtk_symbolic_color_resolve (c2, NULL, &shade_bg); +        gtk_symbolic_color_unref (c1); +        gtk_symbolic_color_unref (c2); + +	gdk_cairo_set_source_rgba (cr, highlight ? &fg : &shade_bg); +#else  	GtkStyle    *style = gtk_widget_get_style (widget);  	GtkStateType state = gtk_widget_get_state (widget);  	gdk_cairo_set_source_color (cr, highlight ? &style->text[state] : &style->dark[state]); +#endif  	gdk_cairo_rectangle (cr, area);  	cairo_fill (cr); @@ -158,7 +177,11 @@ ev_document_misc_paint_one_page (cairo_t      *cr,  			 area->height - (border->top + border->bottom));  	cairo_fill (cr); +#if GTK_CHECK_VERSION (3, 0, 0) +	gdk_cairo_set_source_rgba (cr, &bg); +#else  	gdk_cairo_set_source_color (cr, &style->mid[state]); +#endif  	cairo_rectangle (cr,  			 area->x,  			 area->y + area->height - (border->bottom - border->top), | 
