X-Git-Url: https://www.fi.muni.cz/~kas/git//home/kas/public_html/git/?a=blobdiff_plain;f=shell%2Fev-transition-animation.c;h=5bea280c9bcc52d1f346dda20f6f6b91ddf40164;hb=8fdc90f6d511cd854fdfdf4c5d7066a2bbe00c94;hp=2e39ee6e7de762aaaff9a3f22a3b2a7ed0e91dba;hpb=d66c86c82bbacd93faa4cb1a73572e7860c07308;p=evince.git diff --git a/shell/ev-transition-animation.c b/shell/ev-transition-animation.c index 2e39ee6e..5bea280c 100644 --- a/shell/ev-transition-animation.c +++ b/shell/ev-transition-animation.c @@ -499,6 +499,51 @@ ev_transition_animation_cover (cairo_t *cr, } } +static void +ev_transition_animation_uncover (cairo_t *cr, + EvTransitionAnimation *animation, + EvTransitionEffect *effect, + gdouble progress, + GdkRectangle page_area) +{ + EvTransitionAnimationPriv *priv; + gint width, height; + gint angle; + + priv = EV_TRANSITION_ANIMATION_GET_PRIVATE (animation); + width = page_area.width; + height = page_area.height; + + g_object_get (effect, + "angle", &angle, + NULL); + + paint_surface (cr, priv->dest_surface, 0, 0, 0, page_area); + + if (angle == 0) { + /* left to right */ + paint_surface (cr, priv->origin_surface, - (width * progress), 0, 0, page_area); + } else { + /* top to bottom */ + paint_surface (cr, priv->origin_surface, 0, - (height * progress), 0, page_area); + } +} + +static void +ev_transition_animation_fade (cairo_t *cr, + EvTransitionAnimation *animation, + EvTransitionEffect *effect, + gdouble progress, + GdkRectangle page_area) +{ + EvTransitionAnimationPriv *priv; + + priv = EV_TRANSITION_ANIMATION_GET_PRIVATE (animation); + + paint_surface (cr, priv->origin_surface, 0, 0, 0, page_area); + paint_surface (cr, priv->dest_surface, 0, 0, progress, page_area); +} + void ev_transition_animation_paint (EvTransitionAnimation *animation, cairo_t *cr, @@ -546,6 +591,12 @@ ev_transition_animation_paint (EvTransitionAnimation *animation, case EV_TRANSITION_EFFECT_COVER: ev_transition_animation_cover (cr, animation, priv->effect, progress, page_area); break; + case EV_TRANSITION_EFFECT_UNCOVER: + ev_transition_animation_uncover (cr, animation, priv->effect, progress, page_area); + break; + case EV_TRANSITION_EFFECT_FADE: + ev_transition_animation_fade (cr, animation, priv->effect, progress, page_area); + break; default: { GEnumValue *enum_value;