一、基础动画实现方式
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
}
六、性能优化建议
-
减少动画复杂度:避免过多属性同时动画
-
使用硬件加速:在manifest中设置
android:hardwareAccelerated="true" -
优化资源文件:
-
使用
objectAnimator代替set -
减少动画持续时间(推荐200-500ms)
-
-
内存管理:
@Override protected void onStop() { super.onStop(); // 清除动画防止内存泄漏 getWindow().setEnterTransition(null); }
通过以上方法,您可以灵活控制Activity的转场效果,从简单的滑动动画到复杂的共享元素过渡,打造流畅的用户体验

833

被折叠的 条评论
为什么被折叠?



