玩转Android之如何处理返回按钮

这篇博客探讨了Android设备上的返回按钮处理,包括如何捕获返回按钮事件,以及在捕获事件后除了默认回退操作外还能进行的自定义动画设置。通过创建两个Activity并实现跳转,作者展示了如何在Activity中监听返回按钮,并提供了自定义动画的XML示例,以增强用户体验。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Android和iPhone什么的手机在按键上有一个很大的区别就是Android的手机有返回按钮。今天就来讲一下这个返回按钮。这个问题处理不好后面会遇到些许的麻烦。

捕获返回按钮事件

首先创建一个我们今天要用的APP项目,然后给项目中添加两个Activity:一个是ActivityOne,一个是ActivityTwo。实现一个简单的功能,就是从ActivityOne跳转到ActivityTwo。然后在ActivityTwo中点击返回按钮返回到第一个Activity。

要响应返回按钮的操作就要捕获返回按钮事件。代码如下:

    @Override
    public void onBackPressed() {
        Log.i(TAG, "back button pressed");
        super.onBackPressed();
    }

现在你在ActivityTwo点击了返回按钮之后,你就会看看到这个方法执行了。当然,不会有什么不一样的,还是返回到了前一个Activity。如果你把super.onBackPressed();这句注掉,点击返回按钮就不会再返回前一个Activity了,只留在原来的Activity里。

捕获了返回操作,能做点什么呢

一般情况下,返回按钮都应该只处理一件事:退回到上一个Activity。但是还是可以干点别的事的。第一,修改默认的返回动画。你可以在anim文件夹下添加动画,然后在onBackPressed()方法里使用这个动画覆盖默认的返回动画。

    @Override
    public void onBackPressed() {
        Log.i(TAG, "back button pressed");
        super.onBackPressed();
        overridePendingTransition(R.anim.zoom_in, R.anim.zoom_out);
    }

动画xml文件:
zoom_in.xml

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android"
    android:duration="500"
    android:shareInterpolator="@android:anim/accelerate_decelerate_interpolator">
    <scale
        android:fromXScale="80%"
        android:fromYScale="80%"
        android:pivotX="50%"
        android:pivotY="50%"
        android:toXScale="100%"
        android:toYScale="100%" />
    <alpha
        android:fromAlpha="0.5"
        android:toAlpha="1.0" />
</set>

zoom_out.xml

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android"
    android:duration="500"
    android:shareInterpolator="@android:anim/accelerate_decelerate_interpolator">
    <scale
        android:fromXScale="100%"
        android:fromYScale="100%"
        android:pivotX="50%"
        android:pivotY="50%"
        android:toXScale="150%"
        android:toYScale="150%" />
    <alpha
        android:fromAlpha="1.0"
        android:toAlpha="0.5" />
</set>

这里我们用自定义的动画代替了系统默认的Activity之间切换的动画。关于动画现在不用了解太多,之后会有详细的讲解。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值