]> www.fi.muni.cz Git - evince.git/blobdiff - libview/ev-transition-animation.c
[dualscreen] fix crash on ctrl+w and fix control window closing
[evince.git] / libview / ev-transition-animation.c
index 9a1213753da3525ada902d4a8ab918dbeebae420..49d77f79ebf1df70108fbb08b51507b8ec00711c 100644 (file)
@@ -15,8 +15,8 @@
  *
  * You should have received a copy of the GNU Library General Public
  * License along with this library; if not, write to the
- * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
- * Boston, MA 02111-1307, USA.
+ * Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, 
+ * Boston, MA 02110-1301, USA.
  */
 
 #include <cairo.h>
@@ -192,10 +192,11 @@ paint_surface (cairo_t         *cr,
        cairo_save (cr);
 
        gdk_cairo_rectangle (cr, &page_area);
+       cairo_clip (cr);
        cairo_surface_set_device_offset (surface, x_offset, y_offset);
        cairo_set_source_surface (cr, surface, 0, 0);
 
-       if (alpha == 0.)
+       if (alpha == 1.)
                cairo_paint (cr);
        else
                cairo_paint_with_alpha (cr, alpha);
@@ -226,7 +227,7 @@ ev_transition_animation_split (cairo_t               *cr,
                      NULL);
 
        if (direction == EV_TRANSITION_DIRECTION_INWARD) {
-               paint_surface (cr, priv->dest_surface, 0, 0, 0, page_area);
+               paint_surface (cr, priv->dest_surface, 0, 0, 1., page_area);
 
                if (alignment == EV_TRANSITION_ALIGNMENT_HORIZONTAL) {
                        cairo_rectangle (cr,
@@ -244,9 +245,9 @@ ev_transition_animation_split (cairo_t               *cr,
 
                cairo_clip (cr);
 
-               paint_surface (cr, priv->origin_surface, 0, 0, 0, page_area);
+               paint_surface (cr, priv->origin_surface, 0, 0, 1., page_area);
        } else {
-               paint_surface (cr, priv->origin_surface, 0, 0, 0, page_area);
+               paint_surface (cr, priv->origin_surface, 0, 0, 1., page_area);
 
                if (alignment == EV_TRANSITION_ALIGNMENT_HORIZONTAL) {
                        cairo_rectangle (cr,
@@ -264,7 +265,7 @@ ev_transition_animation_split (cairo_t               *cr,
 
                cairo_clip (cr);
 
-               paint_surface (cr, priv->dest_surface, 0, 0, 0, page_area);
+               paint_surface (cr, priv->dest_surface, 0, 0, 1., page_area);
        }
 }
 
@@ -287,7 +288,7 @@ ev_transition_animation_blinds (cairo_t               *cr,
                      "alignment", &alignment,
                      NULL);
 
-       paint_surface (cr, priv->origin_surface, 0, 0, 0, page_area);
+       paint_surface (cr, priv->origin_surface, 0, 0, 1., page_area);
 
        for (i = 0; i < N_BLINDS; i++) {
                cairo_save (cr);
@@ -307,7 +308,7 @@ ev_transition_animation_blinds (cairo_t               *cr,
                }
 
                cairo_clip (cr);
-               paint_surface (cr, priv->dest_surface, 0, 0, 0, page_area);
+               paint_surface (cr, priv->dest_surface, 0, 0, 1., page_area);
                cairo_restore (cr);
        }
 }
@@ -332,7 +333,7 @@ ev_transition_animation_box (cairo_t               *cr,
                      NULL);
 
        if (direction == EV_TRANSITION_DIRECTION_INWARD) {
-               paint_surface (cr, priv->dest_surface, 0, 0, 0, page_area);
+               paint_surface (cr, priv->dest_surface, 0, 0, 1., page_area);
 
                cairo_rectangle (cr,
                                 width * progress / 2,
@@ -341,9 +342,9 @@ ev_transition_animation_box (cairo_t               *cr,
                                 height * (1 - progress));
                cairo_clip (cr);
 
-               paint_surface (cr, priv->origin_surface, 0, 0, 0, page_area);
+               paint_surface (cr, priv->origin_surface, 0, 0, 1., page_area);
        } else {
-               paint_surface (cr, priv->origin_surface, 0, 0, 0, page_area);
+               paint_surface (cr, priv->origin_surface, 0, 0, 1., page_area);
 
                cairo_rectangle (cr,
                                 (width / 2) - (width * progress / 2),
@@ -352,7 +353,7 @@ ev_transition_animation_box (cairo_t               *cr,
                                 height * progress);
                cairo_clip (cr);
 
-               paint_surface (cr, priv->dest_surface, 0, 0, 0, page_area);
+               paint_surface (cr, priv->dest_surface, 0, 0, 1., page_area);
        }
 }
 
@@ -375,7 +376,7 @@ ev_transition_animation_wipe (cairo_t               *cr,
                      "angle", &angle,
                      NULL);
 
-       paint_surface (cr, priv->origin_surface, 0, 0, 0, page_area);
+       paint_surface (cr, priv->origin_surface, 0, 0, 1., page_area);
 
        if (angle == 0) {
                /* left to right */
@@ -407,7 +408,7 @@ ev_transition_animation_wipe (cairo_t               *cr,
 
        cairo_clip (cr);
 
-       paint_surface (cr, priv->dest_surface, 0, 0, 0, page_area);
+       paint_surface (cr, priv->dest_surface, 0, 0, 1., page_area);
 }
 
 static void
@@ -421,7 +422,7 @@ ev_transition_animation_dissolve (cairo_t               *cr,
 
        priv = EV_TRANSITION_ANIMATION_GET_PRIVATE (animation);
 
-       paint_surface (cr, priv->dest_surface, 0, 0, 0, page_area);
+       paint_surface (cr, priv->dest_surface, 0, 0, 1., page_area);
        paint_surface (cr, priv->origin_surface, 0, 0, 1 - progress, page_area);
 }
 
@@ -446,12 +447,12 @@ ev_transition_animation_push (cairo_t               *cr,
 
        if (angle == 0) {
                /* left to right */
-               paint_surface (cr, priv->origin_surface, - (width * progress), 0, 0, page_area);
-               paint_surface (cr, priv->dest_surface, width * (1 - progress), 0, 0, page_area);
+               paint_surface (cr, priv->origin_surface, - (width * progress), 0, 1., page_area);
+               paint_surface (cr, priv->dest_surface, width * (1 - progress), 0, 1., page_area);
        } else {
                /* top to bottom */
-               paint_surface (cr, priv->origin_surface, 0, - (height * progress), 0, page_area);
-               paint_surface (cr, priv->dest_surface, 0, height * (1 - progress), 0, page_area);
+               paint_surface (cr, priv->origin_surface, 0, - (height * progress), 1., page_area);
+               paint_surface (cr, priv->dest_surface, 0, height * (1 - progress), 1., page_area);
        }
 }
 
@@ -474,14 +475,14 @@ ev_transition_animation_cover (cairo_t               *cr,
                      "angle", &angle,
                      NULL);
 
-       paint_surface (cr, priv->origin_surface, 0, 0, 0, page_area);
+       paint_surface (cr, priv->origin_surface, 0, 0, 1., page_area);
 
        if (angle == 0) {
                /* left to right */
-               paint_surface (cr, priv->dest_surface, width * (1 - progress), 0, 0, page_area);
+               paint_surface (cr, priv->dest_surface, width * (1 - progress), 0, 1., page_area);
        } else {
                /* top to bottom */
-               paint_surface (cr, priv->dest_surface, 0, height * (1 - progress), 0, page_area);
+               paint_surface (cr, priv->dest_surface, 0, height * (1 - progress), 1., page_area);
        }
 }
 
@@ -504,14 +505,14 @@ ev_transition_animation_uncover (cairo_t               *cr,
                      "angle", &angle,
                      NULL);
 
-       paint_surface (cr, priv->dest_surface, 0, 0, 0, page_area);
+       paint_surface (cr, priv->dest_surface, 0, 0, 1., page_area);
 
        if (angle == 0) {
                /* left to right */
-               paint_surface (cr, priv->origin_surface, - (width * progress), 0, 0, page_area);
+               paint_surface (cr, priv->origin_surface, - (width * progress), 0, 1., page_area);
        } else {
                /* top to bottom */
-               paint_surface (cr, priv->origin_surface, 0, - (height * progress), 0, page_area);
+               paint_surface (cr, priv->origin_surface, 0, - (height * progress), 1., page_area);
        }
 }
 
@@ -526,7 +527,7 @@ ev_transition_animation_fade (cairo_t               *cr,
 
        priv = EV_TRANSITION_ANIMATION_GET_PRIVATE (animation);
 
-       paint_surface (cr, priv->origin_surface, 0, 0, 0, page_area);
+       paint_surface (cr, priv->origin_surface, 0, 0, 1., page_area);
        paint_surface (cr, priv->dest_surface, 0, 0, progress, page_area);
 }
 
@@ -545,7 +546,7 @@ ev_transition_animation_paint (EvTransitionAnimation *animation,
 
        if (!priv->dest_surface) {
                /* animation is still not ready, paint the origin surface */
-               paint_surface (cr, priv->origin_surface, 0, 0, 0, page_area);
+               paint_surface (cr, priv->origin_surface, 0, 0, 1., page_area);
                return;
        }
 
@@ -555,7 +556,7 @@ ev_transition_animation_paint (EvTransitionAnimation *animation,
        switch (type) {
        case EV_TRANSITION_EFFECT_REPLACE:
                /* just paint the destination slide */
-               paint_surface (cr, priv->dest_surface, 0, 0, 0, page_area);
+               paint_surface (cr, priv->dest_surface, 0, 0, 1., page_area);
                break;
        case EV_TRANSITION_EFFECT_SPLIT:
                ev_transition_animation_split (cr, animation, priv->effect, progress, page_area);
@@ -595,7 +596,7 @@ ev_transition_animation_paint (EvTransitionAnimation *animation,
                           enum_value->value_nick);
 
                /* just paint the destination slide */
-               paint_surface (cr, priv->dest_surface, 0, 0, 0, page_area);
+               paint_surface (cr, priv->dest_surface, 0, 0, 1., page_area);
                }
        }
 }