]> www.fi.muni.cz Git - evince.git/blobdiff - libdocument/ev-document-misc.c
[dualscreen] fix crash on ctrl+w and fix control window closing
[evince.git] / libdocument / ev-document-misc.c
index d597127f69251a426600798e1b76e60b1d09445d..01676b5306c2faca791858266e9cc6e379c4bb6f 100644 (file)
@@ -56,7 +56,7 @@ create_thumbnail_frame (int        width,
        }
 
        /* make sure no one is passing us garbage */
-       g_assert (width_r >= 0 && height_r >= 0);
+       g_return_val_if_fail (width_r >= 0 && height_r >= 0, NULL);
 
        retval = gdk_pixbuf_new (GDK_COLORSPACE_RGB,
                                 TRUE, 8,
@@ -140,10 +140,22 @@ ev_document_misc_paint_one_page (cairo_t      *cr,
                                 gboolean      highlight,
                                 gboolean      inverted_colors)
 {
-       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]);
+       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);
        gdk_cairo_rectangle (cr, area);
        cairo_fill (cr);
 
@@ -158,7 +170,7 @@ ev_document_misc_paint_one_page (cairo_t      *cr,
                         area->height - (border->top + border->bottom));
        cairo_fill (cr);
 
-       gdk_cairo_set_source_color (cr, &style->mid[state]);
+       gdk_cairo_set_source_rgba (cr, &bg);
        cairo_rectangle (cr,
                         area->x,
                         area->y + area->height - (border->bottom - border->top),
@@ -180,6 +192,8 @@ ev_document_misc_surface_from_pixbuf (GdkPixbuf *pixbuf)
        cairo_surface_t *surface;
        cairo_t         *cr;
 
+       g_return_val_if_fail (GDK_IS_PIXBUF (pixbuf), NULL);
+
        surface = cairo_image_surface_create (gdk_pixbuf_get_has_alpha (pixbuf) ?
                                              CAIRO_FORMAT_ARGB32 : CAIRO_FORMAT_RGB24,
                                              gdk_pixbuf_get_width (pixbuf),
@@ -195,68 +209,12 @@ ev_document_misc_surface_from_pixbuf (GdkPixbuf *pixbuf)
 GdkPixbuf *
 ev_document_misc_pixbuf_from_surface (cairo_surface_t *surface)
 {
-       GdkPixbuf       *pixbuf;
-       cairo_surface_t *image;
-       cairo_t         *cr;
-       gboolean         has_alpha;
-       gint             width, height;
-       cairo_format_t   surface_format;
-       gint             pixbuf_n_channels;
-       gint             pixbuf_rowstride;
-       guchar          *pixbuf_pixels;
-       gint             x, y;
-
-       width = cairo_image_surface_get_width (surface);
-       height = cairo_image_surface_get_height (surface);
-       
-       surface_format = cairo_image_surface_get_format (surface);
-       has_alpha = (surface_format == CAIRO_FORMAT_ARGB32);
-
-       pixbuf = gdk_pixbuf_new (GDK_COLORSPACE_RGB,
-                                TRUE, 8,
-                                width, height);
-       pixbuf_n_channels = gdk_pixbuf_get_n_channels (pixbuf);
-       pixbuf_rowstride = gdk_pixbuf_get_rowstride (pixbuf);
-       pixbuf_pixels = gdk_pixbuf_get_pixels (pixbuf);
-
-       image = cairo_image_surface_create_for_data (pixbuf_pixels,
-                                                    surface_format,
-                                                    width, height,
-                                                    pixbuf_rowstride);
-       cr = cairo_create (image);
-       cairo_set_source_surface (cr, surface, 0, 0);
-
-       if (has_alpha)
-               cairo_mask_surface (cr, surface, 0, 0);
-       else
-               cairo_paint (cr);
-
-       cairo_destroy (cr);
-       cairo_surface_destroy (image);
-
-       for (y = 0; y < height; y++) {
-               guchar *p = pixbuf_pixels + y * pixbuf_rowstride;
-
-               for (x = 0; x < width; x++) {
-                       guchar tmp;
-                       
-#if G_BYTE_ORDER == G_LITTLE_ENDIAN
-                       tmp = p[0];
-                       p[0] = p[2];
-                       p[2] = tmp;
-                       p[3] = (has_alpha) ? p[3] : 0xff;
-#else
-                       tmp = p[0];
-                       p[0] = p[1];
-                       p[1] = p[2];
-                       p[2] = p[3];
-                       p[3] = (has_alpha) ? tmp : 0xff;
-#endif                 
-                       p += pixbuf_n_channels;
-               }
-       }
+       g_return_val_if_fail (surface, NULL);   
 
-       return pixbuf;
+        return gdk_pixbuf_get_from_surface (surface,
+                                            0, 0,
+                                            cairo_image_surface_get_width (surface),
+                                            cairo_image_surface_get_height (surface));
 }
 
 cairo_surface_t *