显示Intent->最简单的Activity的切换。

这是最简单的使用Intent完成Activity的切换。

首先我们需要建立两个Activity,FirstActivity,SecondActivity。我们要完成的就是从FirstActivity跳转到SecondActivity。比较简单我就不多说了,直接上代码吧。

下面是FirstActivity的代码。

xml

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".FirstActivity">

    <Button
        android:id="@+id/btn"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Intent"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintLeft_toLeftOf="parent"
        app:layout_constraintRight_toRightOf="parent"
        app:layout_constraintTop_toTopOf="parent" />


</androidx.constraintlayout.widget.ConstraintLayout>

kt代码

package com.ldx.firstkotlin

import android.content.Intent
import androidx.appcompat.app.AppCompatActivity
import android.os.Bundle
import android.view.Menu
import android.view.MenuItem
import android.widget.Toast
import kotlinx.android.synthetic.main.activity_main.*

class FirstActivity : AppCompatActivity() {

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
        btn.setOnClickListener {
            btn.setOnClickListener {
                var intent=Intent(this,SecondActivity::class.java)
                startActivity(intent)
            }
        }
    }
}

这里主要写的是从FirstActivity跳转到SecondActivity,所有操作都是在FirstActivity中完成的。SecondActivity没有任何操作,所以代码就不放啦。

FirstActivity跳转到SecondActivity中携带数据

这里我以最基本的数据string int为例,完成跳转时携带数据。

FirstActivity跳转到SecondActivity,FirstActivity属于发送数据。SecondActivity属于接收数据。比较简单,直接看代码。

FirstActivity(xml)

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".FirstActivity">

    <Button
        android:id="@+id/btn"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="携带数据跳转"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintLeft_toLeftOf="parent"
        app:layout_constraintRight_toRightOf="parent"
        app:layout_constraintTop_toTopOf="parent" />


</androidx.constraintlayout.widget.ConstraintLayout>

FirstActivity(kt)

class FirstActivity : AppCompatActivity() {

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
        btn.setOnClickListener {
            btn.setOnClickListener {
                var intent=Intent(this,SecondActivity::class.java)
                intent.putExtra("msg1",1000)
                intent.putExtra("msg2","我是msg2")
                startActivity(intent)
            }
        }
    }
}

SecondActivity(xml)默认的xml 没有写多余代码,不放出来了。

SecondActivity(kt)

class SecondActivity : AppCompatActivity() {

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_second)
        var msg1=intent.getIntExtra("msg1",-1)
        var msg2=intent.getStringExtra("msg2")
        Toast.makeText(this,"msg1 为:$msg1 msg2 为 $msg2",Toast.LENGTH_LONG).show()
    }
}

使用StartActivityForResult完成从SecondActivity返回到FirstActivity时携带数据

这里展示的是做携带简单的数据,int string 等,如果要携带大量数据的话,推荐用EventBus等(摘自阿里巴巴Android开发手册)

我们要是实现的功能是从FirstActivity跳转到SecondActivity中,然后从SecondActivity中返回的时候,携带一条数据。下面请看代码:

FirstAvtivity(xml) xml代码比较简单,就是简单放置一个按钮

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".intent.FirstActivity">

    <Button
        android:id="@+id/btn"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="跳转按钮"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintLeft_toLeftOf="parent"
        app:layout_constraintRight_toRightOf="parent"
        app:layout_constraintTop_toTopOf="parent" />


</androidx.constraintlayout.widget.ConstraintLayout>

FirstActivity(kt)

FirstActivity中只要包含两个功能1:跳转到SecondActivity,2:处理从SecondActivity返回时传递的数据。下面简单说一下:

1、跳转到SecondActivity

以前跳转的时候用的是startActivity,首先我们要把这个方法换成public void startActivityForResult(@SuppressLint("UnknownNullness") Intent intent, int requestCode),这里我们可以看到,这个方法没有返回值,第一个参数是Intent(意图),第二个参数requestCode,此处我直接设为1,可以直接翻译为“请求码”,用于区别是从“谁(Activity)”返回到的FirstActivity。到目前为止在功能上和startActivity一样的。

这一步我们定义为步骤1

2、处理从SecondActivity返回时传递的数据

当从SecondActivity中返回到FirstActivity的时候,requestCode,我们在上一步已经设置好,所以这里用when做判断,上一步骤我们已经将resultCode设为RESULT_OK,判断条件都已经通过,这里我们获取到一个包含返回信息的Intent,我们返回的数据,就保存在这个Intent中。我们采用data?.getStringExtra("data")来获取传递回来的数据。

这一步我们定义为步骤3(别着急步骤2在下面)

class FirstActivity : AppCompatActivity() {

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
        btn.setOnClickListener {
            var intent = Intent(this, SecondActivity::class.java)
            startActivityForResult(intent, 1)
        }
    }

    override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {
        super.onActivityResult(requestCode, resultCode, data)
        when (requestCode) {
            1 -> if (Activity.RESULT_OK == resultCode) {
                Toast.makeText(
                    this, "返回的数据为:" + data?.getStringExtra("data")
                    , Toast.LENGTH_LONG
                ).show()
            }
        }
    }
}

SecondActivity(xml)

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".intent.SecondActivity">

    <Button
        android:id="@+id/btnReturn"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="Finish"
        android:textAllCaps="false"
        app:layout_constraintTop_toTopOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout>

SecondActivity(kt)

SecondActivity的作用只有一个:携带数据返回到FirstActivity中,在下面的代码中,我们先实例化一个意图Intent,将数据封装在Intent中,通过public final void setResult(int resultCode, Intent data) 方法将数据返回,setResult方法接收两个参数:resultCode:直接理解为结果码,data就是封装了数据的Intent。此时数据已经打包好,调用finish方法,返回到FirstActivity中。

这一步我们定义为步骤2

class SecondActivity : AppCompatActivity() {
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_second)
        btnReturn.setOnClickListener {
            val intent =Intent()
            intent.putExtra("data","我是返回的数据")
            setResult(Activity.RESULT_OK,intent)
            finish()
        }
    }
}

点击SecondActivity中的Finish按钮,就可以返回到FirstActivity中,并且把“我是返回的数据”携带到FirstActivity中。

上面所写的都是显示跳转,下面简单讲解一下隐式跳转,书中没有详细的解释,只是说了怎么使用,我在项目中中,使用显式较多,基本没有用过隐式,网上有一种说法是,本项目内部使用显示,需要调用其他APP比如浏览器时需要使用隐式浏览器。

下面我从几个方面简单说一下隐式Intent

1、Activity之间的跳转

还是以FirstActivity跳转到SecondActivity为例讲解隐式跳转的情况,在隐式跳转中,SecondActivity在.kt文件中不用做操作,但是需要在AndroidManifest.xml中做操作。具体请看代码:

<activity
            android:name=".intent.SecondActivity"
            android:label="SecondActivity">
            <intent-filter>
                <action android:name="ldx"/>
                <category android:name="android.intent.category.DEFAULT"/>
            </intent-filter>
        </activity>

intent-filter中我们指定了两个标签,action,category。

action 标签的的name属性,我填了ldx 就是想告诉大家 这个name属性的值随便填,但是最好由一定的意义。

category标签的name属性,现在是DEFAULT是一种默认的category。

FirstActivity.kt

class FirstActivity : AppCompatActivity() {

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
        btn.setOnClickListener {
            val intent=Intent("ldx")
            startActivity(intent)
        }
    }
}

这里先实例化一个Intent对象,这次我们使用的是不同于显示Intent的重载,这里的ldx和上面的action是对应的。此时点击按钮就可以跳转了。

这里不知道有没有同学疑问?category 是啥用啊?这也没体现出来啊。下面我就为大家解答。

上面category的作用是默认功能,开发者只需要匹配action,就可以启动一个Activity。

大部分情况下是重写写category的。但是有一点需要说明,category中的DEFAULT是不能删除的。哪怕我们自己添加了新的category。

代码如下:

AndroidManifest.xml

<activity
            android:name=".intent.SecondActivity"
            android:label="SecondActivity">
            <intent-filter>
                <action android:name="ldx"/>
                <category android:name="android.intent.category.DEFAULT"/>
                <!--这个DEFAULT不能删除,其他的category该怎么加还要怎么加-->
                <category android:name="zw"/>
            </intent-filter>
        </activity>

FirstActivity.kt

class FirstActivity : AppCompatActivity() {

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
        btn.setOnClickListener {
            val intent=Intent("ldx")
            intent.addCategory("zw")
            startActivity(intent)
        }
    }
}

需要说明的是新添加的category,name值随便设置,但是必须有一定的意义;并且 <category android:name="android.intent.category.DEFAULT"/>不能删除。

隐式Intent还可以调用其他APP,可能,这是最主要的一个功能,我目前没有用到,这篇文章就写到这里吧,以后用到隐式Intent跳转其他APP的时候再做记录。