Android Activity 转场动画全面解析与实现指南

一、基础动画实现方式

1. 通过主题样式设置(全局生效)

在 res/values/styles.xml 中定义:

<style name="AppTheme" parent="Theme.AppCompat.Light">
    <!-- 进入动画 -->
    <item name="android:windowAnimationStyle">@style/ActivityAnimation</item>
</style>

<style name="ActivityAnimation" parent="@android:style/Animation.Activity">
    <item name="android:activityOpenEnterAnimation">@anim/slide_in_right</item>
    <item name="android:activityOpenExitAnimation">@anim/slide_out_left</item>
    <item name="android:activityCloseEnterAnimation">@anim/slide_in_left</item>
    <item name="android:activityCloseExitAnimation">@anim/slide_out_right</item>
</style>

2. 通过代码动态设置(单个Activity)

// 启动Activity时
startActivity(intent);
overridePendingTransition(R.anim.slide_in_right, R.anim.slide_out_left);

// 结束Activity时
finish();
overridePendingTransition(R.anim.slide_in_left, R.anim.slide_out_right);

二、动画资源文件示例

1. 从右滑入 (slide_in_right.xml)

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android"
    android:shareInterpolator="false">
    <translate
        android:duration="300"
        android:fromXDelta="100%"
        android:toXDelta="0%"
        android:interpolator="@android:anim/decelerate_interpolator"/>
</set>

2. 向左滑出 (slide_out_left.xml)

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
    <translate
        android:duration="300"
        android:fromXDelta="0%"
        android:toXDelta="-100%"
        android:interpolator="@android:anim/accelerate_interpolator"/>
</set>

三、高级转场动画(API 21+)

1. 使用 Transition API

(1) 启用窗口内容转换
// 在setContentView之前调用
getWindow().requestFeature(Window.FEATURE_CONTENT_TRANSITIONS);

// 设置进入/退出动画
getWindow().setEnterTransition(new Slide(Gravity.END));
getWindow().setExitTransition(new Slide(Gravity.START));
(2) 启动Activity
ActivityOptions options = ActivityOptions
    .makeSceneTransitionAnimation(this);
startActivity(intent, options.toBundle());

2. 共享元素过渡

(1) 布局文件添加transitionName
<!-- 第一个Activity -->
<ImageView
    android:id="@+id/image"
    android:transitionName="shared_image"/>

<!-- 第二个Activity -->
<ImageView
    android:id="@+id/target_image"
    android:transitionName="shared_image"/>
(2) 启动共享元素动画
ActivityOptions options = ActivityOptions
    .makeSceneTransitionAnimation(this, 
        Pair.create(view, "shared_image"));
startActivity(intent, options.toBundle());

四、动画类型大全

1. 内置过渡效果

动画类效果描述
Slide滑动进入/退出
Fade淡入淡出
Explode爆炸式分散
ChangeBounds视图边界变化
ChangeTransform视图缩放旋转

2. 自定义过渡动画

public class CustomTransition extends Transition {
    @Override
    public void captureStartValues(TransitionValues values) {
        // 记录起始状态
    }

    @Override
    public void captureEndValues(TransitionValues values) {
        // 记录结束状态
    }

    @Override
    public Animator createAnimator(ViewGroup sceneRoot,
            TransitionValues startValues,
            TransitionValues endValues) {
        // 创建自定义动画
        return ObjectAnimator.ofFloat(endValues.view, "alpha", 0, 1);
    }
}

五、常见问题解决方案

1. 动画不生效检查清单

  • 确保 overridePendingTransition() 在 startActivity() 或 finish() 之后立即调用

  • 检查动画资源文件是否正确定义

  • API 21+ 确保调用了 requestFeature(Window.FEATURE_CONTENT_TRANSITIONS)

2. 解决黑屏问题

// 在style中添加
<item name="android:windowIsTranslucent">true</item>
<item name="android:windowBackground">@android:color/transparent</item>

3. 适配低版本

if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
    // 使用Transition API
} else {
    // 使用overridePendingTransition
}

六、性能优化建议

  1. 减少动画复杂度:避免过多属性同时动画

  2. 使用硬件加速:在manifest中设置 android:hardwareAccelerated="true"

  3. 优化资源文件

    • 使用 objectAnimator 代替 set

    • 减少动画持续时间(推荐200-500ms)

  4. 内存管理

    @Override
    protected void onStop() {
        super.onStop();
        // 清除动画防止内存泄漏
        getWindow().setEnterTransition(null);
    }

通过以上方法,您可以灵活控制Activity的转场效果,从简单的滑动动画到复杂的共享元素过渡,打造流畅的用户体验

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值