Loading core/java/android/animation/LayoutTransition.java +33 −5 Original line number Diff line number Diff line Loading @@ -190,14 +190,26 @@ public class LayoutTransition { private long mChangingDisappearingStagger = 0; private long mChangingStagger = 0; /** * Static interpolators - these are stateless and can be shared across the instances */ private static TimeInterpolator ACCEL_DECEL_INTERPOLATOR = new AccelerateDecelerateInterpolator(); private static TimeInterpolator DECEL_INTERPOLATOR = new DecelerateInterpolator(); private static TimeInterpolator sAppearingInterpolator = ACCEL_DECEL_INTERPOLATOR; private static TimeInterpolator sDisappearingInterpolator = ACCEL_DECEL_INTERPOLATOR; private static TimeInterpolator sChangingAppearingInterpolator = DECEL_INTERPOLATOR; private static TimeInterpolator sChangingDisappearingInterpolator = DECEL_INTERPOLATOR; private static TimeInterpolator sChangingInterpolator = DECEL_INTERPOLATOR; /** * The default interpolators used for the animations */ private TimeInterpolator mAppearingInterpolator = new AccelerateDecelerateInterpolator(); private TimeInterpolator mDisappearingInterpolator = new AccelerateDecelerateInterpolator(); private TimeInterpolator mChangingAppearingInterpolator = new DecelerateInterpolator(); private TimeInterpolator mChangingDisappearingInterpolator = new DecelerateInterpolator(); private TimeInterpolator mChangingInterpolator = new DecelerateInterpolator(); private TimeInterpolator mAppearingInterpolator = sAppearingInterpolator; private TimeInterpolator mDisappearingInterpolator = sDisappearingInterpolator; private TimeInterpolator mChangingAppearingInterpolator = sChangingAppearingInterpolator; private TimeInterpolator mChangingDisappearingInterpolator = sChangingDisappearingInterpolator; private TimeInterpolator mChangingInterpolator = sChangingInterpolator; /** * These hashmaps are used to store the animations that are currently running as part of Loading Loading @@ -905,14 +917,24 @@ public class LayoutTransition { case APPEARING: startDelay = mChangingAppearingDelay + staggerDelay; staggerDelay += mChangingAppearingStagger; if (mChangingAppearingInterpolator != sChangingAppearingInterpolator) { anim.setInterpolator(mChangingAppearingInterpolator); } break; case DISAPPEARING: startDelay = mChangingDisappearingDelay + staggerDelay; staggerDelay += mChangingDisappearingStagger; if (mChangingDisappearingInterpolator != sChangingDisappearingInterpolator) { anim.setInterpolator(mChangingDisappearingInterpolator); } break; case CHANGING: startDelay = mChangingDelay + staggerDelay; staggerDelay += mChangingStagger; if (mChangingInterpolator != sChangingInterpolator) { anim.setInterpolator(mChangingInterpolator); } break; } anim.setStartDelay(startDelay); Loading Loading @@ -1148,6 +1170,9 @@ public class LayoutTransition { anim.setTarget(child); anim.setStartDelay(mAppearingDelay); anim.setDuration(mAppearingDuration); if (mAppearingInterpolator != sAppearingInterpolator) { anim.setInterpolator(mAppearingInterpolator); } if (anim instanceof ObjectAnimator) { ((ObjectAnimator) anim).setCurrentPlayTime(0); } Loading Loading @@ -1192,6 +1217,9 @@ public class LayoutTransition { Animator anim = mDisappearingAnim.clone(); anim.setStartDelay(mDisappearingDelay); anim.setDuration(mDisappearingDuration); if (mDisappearingInterpolator != sDisappearingInterpolator) { anim.setInterpolator(mDisappearingInterpolator); } anim.setTarget(child); final float preAnimAlpha = child.getAlpha(); anim.addListener(new AnimatorListenerAdapter() { Loading Loading
core/java/android/animation/LayoutTransition.java +33 −5 Original line number Diff line number Diff line Loading @@ -190,14 +190,26 @@ public class LayoutTransition { private long mChangingDisappearingStagger = 0; private long mChangingStagger = 0; /** * Static interpolators - these are stateless and can be shared across the instances */ private static TimeInterpolator ACCEL_DECEL_INTERPOLATOR = new AccelerateDecelerateInterpolator(); private static TimeInterpolator DECEL_INTERPOLATOR = new DecelerateInterpolator(); private static TimeInterpolator sAppearingInterpolator = ACCEL_DECEL_INTERPOLATOR; private static TimeInterpolator sDisappearingInterpolator = ACCEL_DECEL_INTERPOLATOR; private static TimeInterpolator sChangingAppearingInterpolator = DECEL_INTERPOLATOR; private static TimeInterpolator sChangingDisappearingInterpolator = DECEL_INTERPOLATOR; private static TimeInterpolator sChangingInterpolator = DECEL_INTERPOLATOR; /** * The default interpolators used for the animations */ private TimeInterpolator mAppearingInterpolator = new AccelerateDecelerateInterpolator(); private TimeInterpolator mDisappearingInterpolator = new AccelerateDecelerateInterpolator(); private TimeInterpolator mChangingAppearingInterpolator = new DecelerateInterpolator(); private TimeInterpolator mChangingDisappearingInterpolator = new DecelerateInterpolator(); private TimeInterpolator mChangingInterpolator = new DecelerateInterpolator(); private TimeInterpolator mAppearingInterpolator = sAppearingInterpolator; private TimeInterpolator mDisappearingInterpolator = sDisappearingInterpolator; private TimeInterpolator mChangingAppearingInterpolator = sChangingAppearingInterpolator; private TimeInterpolator mChangingDisappearingInterpolator = sChangingDisappearingInterpolator; private TimeInterpolator mChangingInterpolator = sChangingInterpolator; /** * These hashmaps are used to store the animations that are currently running as part of Loading Loading @@ -905,14 +917,24 @@ public class LayoutTransition { case APPEARING: startDelay = mChangingAppearingDelay + staggerDelay; staggerDelay += mChangingAppearingStagger; if (mChangingAppearingInterpolator != sChangingAppearingInterpolator) { anim.setInterpolator(mChangingAppearingInterpolator); } break; case DISAPPEARING: startDelay = mChangingDisappearingDelay + staggerDelay; staggerDelay += mChangingDisappearingStagger; if (mChangingDisappearingInterpolator != sChangingDisappearingInterpolator) { anim.setInterpolator(mChangingDisappearingInterpolator); } break; case CHANGING: startDelay = mChangingDelay + staggerDelay; staggerDelay += mChangingStagger; if (mChangingInterpolator != sChangingInterpolator) { anim.setInterpolator(mChangingInterpolator); } break; } anim.setStartDelay(startDelay); Loading Loading @@ -1148,6 +1170,9 @@ public class LayoutTransition { anim.setTarget(child); anim.setStartDelay(mAppearingDelay); anim.setDuration(mAppearingDuration); if (mAppearingInterpolator != sAppearingInterpolator) { anim.setInterpolator(mAppearingInterpolator); } if (anim instanceof ObjectAnimator) { ((ObjectAnimator) anim).setCurrentPlayTime(0); } Loading Loading @@ -1192,6 +1217,9 @@ public class LayoutTransition { Animator anim = mDisappearingAnim.clone(); anim.setStartDelay(mDisappearingDelay); anim.setDuration(mDisappearingDuration); if (mDisappearingInterpolator != sDisappearingInterpolator) { anim.setInterpolator(mDisappearingInterpolator); } anim.setTarget(child); final float preAnimAlpha = child.getAlpha(); anim.addListener(new AnimatorListenerAdapter() { Loading