前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Android经典面试题之如何设置activity的启动动画,让它像dialog一样从底部往上出来

Android经典面试题之如何设置activity的启动动画,让它像dialog一样从底部往上出来

作者头像
AntDream
发布2024-07-31 17:59:02
900
发布2024-07-31 17:59:02
举报
文章被收录于专栏:程序员修炼之路

在 Android 中,你可以通过定义自定义的动画资源并在启动和结束 Activity 时应用这些动画,实现类似对话框从底部向上进入,从上向下退出的效果。具体步骤如下:

1. 定义动画资源

首先,创建两个 XML 动画文件,一个用于 Activity 进入时的动画,一个用于退出时的动画。

res/anim/activity_slide_in.xml
代码语言:javascript
复制
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
    <translate
        android:duration="300"
        android:fromYDelta="100%"
        android:toYDelta="0%" />
    <alpha
        android:duration="300"
        android:fromAlpha="0.0"
        android:toAlpha="1.0"/>
</set>
res/anim/activity_slide_out.xml
代码语言:javascript
复制
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
    <translate
        android:duration="300"
        android:fromYDelta="0%"
        android:toYDelta="100%" />
    <alpha
        android:duration="300"
        android:fromAlpha="1.0"
        android:toAlpha="0.0"/>
</set>

2. 应用动画资源

在你的 Activity 的 overridePendingTransition 方法中指定这两个动画文件。

启动新的 Activity 时

在启动一个新的 Activity 时你可以这样使用:

代码语言:javascript
复制
val intent = Intent(this, NewActivity::class.java)
startActivity(intent)
overridePendingTransition(R.anim.activity_slide_in, R.anim.activity_slide_out)
结束当前 Activity 时

在结束当前 Activity 时你需要在 finish 之前调用 overridePendingTransition

代码语言:javascript
复制
finish()
overridePendingTransition(R.anim.activity_slide_in, R.anim.activity_slide_out)
针对 Activity 退出动画

为了确保 Activity 在退出时使用自定义动画,你还需要覆盖 onBackPressed 方法:

代码语言:javascript
复制
override fun onBackPressed() {
    super.onBackPressed()
    overridePendingTransition(R.anim.activity_slide_in, R.anim.activity_slide_out)
}

示例代码

假设你有两个 Activity,MainActivityNewActivity,以下是应用动画的示例代码:

代码语言:javascript
复制
// In MainActivity.kt
class MainActivity : AppCompatActivity() {
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)

        val button = findViewById<Button>(R.id.openActivityButton)
        button.setOnClickListener {
            val intent = Intent(this, NewActivity::class.java)
            startActivity(intent)
            overridePendingTransition(R.anim.activity_slide_in, R.anim.activity_slide_out)
        }
    }
}

// In NewActivity.kt
class NewActivity : AppCompatActivity() {
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_new)
    }

    override fun onBackPressed() {
        super.onBackPressed()
        overridePendingTransition(R.anim.activity_slide_in, R.anim.activity_slide_out)
    }
}

通过这个方法,你可以轻松地让你的 Activity 像 Dialog 一样,从底部向上进入,从上到下退出。上述动画时长可以根据实际需求进行调整。

如何只让新启动的activity有动画效果,之前的activity不动

先定义一个静止的动画

res/anim/no_animation.xml
代码语言:javascript
复制
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
    <alpha
        android:duration="0"
        android:fromAlpha="1.0"
        android:toAlpha="1.0" />
</set>

no_animation.xml 是一个没有任何动画效果的动画文件,用于主 Activity 保持静止。

启动新的 Activity 时
代码语言:javascript
复制
val intent = Intent(this, NewActivity::class.java)
startActivity(intent)
overridePendingTransition(R.anim.activity_slide_in, R.anim.no_animation)
在新的 Activity 返回时,也不需要动画

在新的 Activity 中,确保返回时无动画:

代码语言:javascript
复制
override fun finish() {
    super.finish()
    overridePendingTransition(0, 0)
}

END

点亮【赞和在看】,让钱和爱都流向你。

心里种花,人生才不会荒芜,如果你也想一起成长,请点个关注吧。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2024-07-26,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 AntDream 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. 定义动画资源
    • res/anim/activity_slide_in.xml
      • res/anim/activity_slide_out.xml
      • 2. 应用动画资源
        • 启动新的 Activity 时
          • 结束当前 Activity 时
            • 针对 Activity 退出动画
            • 示例代码
            • 如何只让新启动的activity有动画效果,之前的activity不动
              • res/anim/no_animation.xml
                • 启动新的 Activity 时
                  • 在新的 Activity 返回时,也不需要动画
                  领券
                  问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档