显示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的时候再做记录。