Activity 活动跳转(Java&Kotlin)

时间:2022-07-25
本文章向大家介绍Activity 活动跳转(Java&Kotlin),主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

Activity 活动跳转(Java&Kotlin)

任何正式APP都不可能只有一个Activity,当有多个Activity时,怎么从一个Activity进入到另一个Activity呢? 答案就是活动跳转。

① 普通跳转

顾名思义,就是单纯从A到B,不带任何内容。 Java

	//活动跳转,从MainActivity跳转到TestActivity,普通跳转
   	startActivity(new Intent(MainActivity.this,TestActivity.class));

如果把刚才Java里的代码复制到Kotlin里,会需要转译,转译后的Kotlin代码如下:

Kotlin

		//活动跳转,从MainActivity跳转到TestActivity,普通跳转
        //MainActivity.this  可以 简写成  this
        startActivity(Intent(this@MainActivity, TestActivity::class.java))

有没有感觉这个看起来比Java的更复杂啊,这当然不行啊,所以我们可以自己写。

	//TestActivity 为要跳转的页面
    startActivity<TestActivity>()

就这么简单,不管是从代码上还是从意思上都比Java要简洁明了,要这样使用的话你的Kotlin需要里引入Anko库, 第一步 修改项目的build.gradle,在buildscript里加上

ext.anko_version = '0.10.8'

修改模块的build.gradle,在dependencies里加上

implementation "org.jetbrains.anko:anko-common:$anko_version"

加完之后Sync同步一样。 然后在MainActivity中导入

import org.jetbrains.anko.startActivity

然后就可以直接使用了。

② 传递数据

实际开发中的页面跳转都不会是单纯的跳转,肯定会携带一些参数的。 Java

	//传递方
	//活动跳转时传值  通过键值的方式传递  另一页面接收根据键来取值
    Intent intent = new Intent(this,TestActivity.class);
    intent.putExtra("id",456);
    intent.putExtra("name","晨曦");
    startActivity(intent);
	//接收方
    //接收int类型数据,使用getIntExtra,如果没有拿到值则用默认值,
    //接收String类型数据,使用getStringExtra,不用默认值.
    int id = getIntent().getIntExtra("id",0);
    String name = getIntent().getStringExtra("name");

Kotlin

	//传递方
    //通过关键字to分隔键与值,前面是键 后面是 值
    //第一种写法
    startActivity<TestActivity>("id" to 456, "name" to "晨曦")
        
    //第二种写法
    //Pair类把参数名和参数值进行配对,这种方式和Java有点像
    startActivity<TestActivity>(
        Pair("id",456),
        Pair("name","晨曦")
    )
	//接收方
    //通过intent.extras?拿到包裹的数据,通过getInt和getString拿到相对应键的值
    val id = intent.extras?.getInt("id")
    val name = intent.extras?.getString("name")

③ 跳转时指定启动模式

在代码中动态指定页面的启动模式,因为在AndroidManifest.xml中对每个Activity只能指定唯一的启动模式,如果想在不同时候对同一个Activity运用不同的启动模式,显然固定的launchMode属性无法满足找个需求。所以Android允许在代码中手动设置启动表示,这样在不同时候调用startActivity方法就能运行特定的启动模式。 适用于setFlags方法的几种启动标志的取值说明如下表:

Intent类的启动标志

说明

Intent.FLAG_ACTIVITY_NEW_TASK

开启一个新任务,flag默认该值类似于launchMode=“standard”,不同之处在于,如果原来不存在活动栈,FLAG_ACTIVITY_NEW_TASK 就会创建一个新栈

Intent.FLAG_ACTIVITY_SINGLE_TOP

当栈顶为你跳转的Activity实例时,重用栈顶的实例。该值等同于launchMode=“singleTop”

Intent.FLAG_ACTIVITY_CLEAR_TOP

当栈顶存在待跳转的Activity实例时,重新创建一个新实例,并将原实例上方的所有实例加以清楚。该值与launchMode="singleTask"类似,但launchMode="singleTask"采用onNewIntent启动原任务,而FLAG_ACTIVITY_CLEAR_TOP 采用先onDestroy再onCreate创建新任务

Intent.FLAG_ACTIVITY_NO_HISTORY

该标志与launchMode="standard"情况类似,但栈中不保存新启动的Activity实例。这样下次无论以何种方式启动该实例,也要走standard的完整流程

Intent.FLAG_ACTIVITY_CLEAR_TASK

该标志非常暴力,跳转到新页面时,栈中的原有实例都被情况,注意:该标志要结合FLAG_ACTIVITY_NEW_TASK 使用,即setFlags的参数为“Intent.FLAG_ACTIVITY_CLEAR_TASK

启动模式在Java中是比较琐碎的,在Kotlin中则通过Anko库扩展出来的intentFor函数简化启动标志的设置方式,列如,启动标志FLAG_ACTIVITY_NEW_TASK 对应的Anko写法如下:

startActivity(intent.newTask())

短小精悍

来看一下所有的Java方法对应的Anko库的写法

Intent类的启动标志

Anko库的标志设置函数

FLAG_ACTIVITY_NEW_TASK

newTask()

FLAG_ACTIVITY_SINGLE_TOP

singleTop()

FLAG_ACTIVITY_CLEAR_TOP

clearTop()

FLAG_ACTIVITY_NO_HISTORY

noHistory()

FLAG_ACTIVITY_CLEAR_TASK

clearTask()

Java

		intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);//新任务
        intent.setFlags(Intent.FLAG_ACTIVITY_SINGLE_TOP);//置于栈顶
        intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);//清空栈顶
        intent.setFlags(Intent.FLAG_ACTIVITY_NO_HISTORY);//历史
        intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TASK|Intent.FLAG_ACTIVITY_NEW_TASK);//清除之后新建一个任务

Kotlin

		startActivity(intent.newTask())//新任务
        startActivity(intent.singleTop())//置于栈顶
        startActivity(intent.clearTop())//清空栈顶
        startActivity(intent.noHistory())//历史
        startActivity(intent.clearTask().newTask())//清除之后新建一个任务

④ 处理返回数据

页面跳转的多数情况是上一个页面传递请求参数给下一个页面,当然也有少数情况是上一个页面需要接受下一个页面的返回数据,此时Kotlin和Java一样都采取startActivityForResult方法,表示这次活动跳转要求处理返回信息。 Java

	@Override
    public void startActivityForResult(Intent intent, int requestCode) {
        super.startActivityForResult(intent, requestCode);
    }

    @Override
    protected void onActivityResult(int requestCode, int resultCode, @Nullable Intent data) {
        super.onActivityResult(requestCode, resultCode, data);
    }

Kotlin

	override fun startActivityForResult(intent: Intent?, requestCode: Int) {
        super.startActivityForResult(intent, requestCode)
    }

    override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {
        super.onActivityResult(requestCode, resultCode, data)
    }