当前位置:   article > 正文

Android Studio Kotlin中使用Intent(携带数据)完成Activity之间的切换。_kotlin intent.putextra

kotlin intent.putextra

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

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

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

下面是FirstActivity的代码。

xml

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. xmlns:app="http://schemas.android.com/apk/res-auto"
  4. xmlns:tools="http://schemas.android.com/tools"
  5. android:layout_width="match_parent"
  6. android:layout_height="match_parent"
  7. tools:context=".FirstActivity">
  8. <Button
  9. android:id="@+id/btn"
  10. android:layout_width="wrap_content"
  11. android:layout_height="wrap_content"
  12. android:text="Intent"
  13. app:layout_constraintBottom_toBottomOf="parent"
  14. app:layout_constraintLeft_toLeftOf="parent"
  15. app:layout_constraintRight_toRightOf="parent"
  16. app:layout_constraintTop_toTopOf="parent" />
  17. </androidx.constraintlayout.widget.ConstraintLayout>

kt代码

  1. package com.ldx.firstkotlin
  2. import android.content.Intent
  3. import androidx.appcompat.app.AppCompatActivity
  4. import android.os.Bundle
  5. import android.view.Menu
  6. import android.view.MenuItem
  7. import android.widget.Toast
  8. import kotlinx.android.synthetic.main.activity_main.*
  9. class FirstActivity : AppCompatActivity() {
  10. override fun onCreate(savedInstanceState: Bundle?) {
  11. super.onCreate(savedInstanceState)
  12. setContentView(R.layout.activity_main)
  13. btn.setOnClickListener {
  14. btn.setOnClickListener {
  15. var intent=Intent(this,SecondActivity::class.java)
  16. startActivity(intent)
  17. }
  18. }
  19. }
  20. }

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

FirstActivity跳转到SecondActivity中携带数据

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

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

FirstActivity(xml)

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. xmlns:app="http://schemas.android.com/apk/res-auto"
  4. xmlns:tools="http://schemas.android.com/tools"
  5. android:layout_width="match_parent"
  6. android:layout_height="match_parent"
  7. tools:context=".FirstActivity">
  8. <Button
  9. android:id="@+id/btn"
  10. android:layout_width="wrap_content"
  11. android:layout_height="wrap_content"
  12. android:text="携带数据跳转"
  13. app:layout_constraintBottom_toBottomOf="parent"
  14. app:layout_constraintLeft_toLeftOf="parent"
  15. app:layout_constraintRight_toRightOf="parent"
  16. app:layout_constraintTop_toTopOf="parent" />
  17. </androidx.constraintlayout.widget.ConstraintLayout>

FirstActivity(kt)

  1. class FirstActivity : AppCompatActivity() {
  2. override fun onCreate(savedInstanceState: Bundle?) {
  3. super.onCreate(savedInstanceState)
  4. setContentView(R.layout.activity_main)
  5. btn.setOnClickListener {
  6. btn.setOnClickListener {
  7. var intent=Intent(this,SecondActivity::class.java)
  8. intent.putExtra("msg1",1000)
  9. intent.putExtra("msg2","我是msg2")
  10. startActivity(intent)
  11. }
  12. }
  13. }
  14. }

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

SecondActivity(kt)

  1. class SecondActivity : AppCompatActivity() {
  2. override fun onCreate(savedInstanceState: Bundle?) {
  3. super.onCreate(savedInstanceState)
  4. setContentView(R.layout.activity_second)
  5. var msg1=intent.getIntExtra("msg1",-1)
  6. var msg2=intent.getStringExtra("msg2")
  7. Toast.makeText(this,"msg1 为:$msg1 msg2 为 $msg2",Toast.LENGTH_LONG).show()
  8. }
  9. }

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

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

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

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

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. xmlns:app="http://schemas.android.com/apk/res-auto"
  4. xmlns:tools="http://schemas.android.com/tools"
  5. android:layout_width="match_parent"
  6. android:layout_height="match_parent"
  7. tools:context=".intent.FirstActivity">
  8. <Button
  9. android:id="@+id/btn"
  10. android:layout_width="wrap_content"
  11. android:layout_height="wrap_content"
  12. android:text="跳转按钮"
  13. app:layout_constraintBottom_toBottomOf="parent"
  14. app:layout_constraintLeft_toLeftOf="parent"
  15. app:layout_constraintRight_toRightOf="parent"
  16. app:layout_constraintTop_toTopOf="parent" />
  17. </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在下面)

  1. class FirstActivity : AppCompatActivity() {
  2. override fun onCreate(savedInstanceState: Bundle?) {
  3. super.onCreate(savedInstanceState)
  4. setContentView(R.layout.activity_main)
  5. btn.setOnClickListener {
  6. var intent = Intent(this, SecondActivity::class.java)
  7. startActivityForResult(intent, 1)
  8. }
  9. }
  10. override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {
  11. super.onActivityResult(requestCode, resultCode, data)
  12. when (requestCode) {
  13. 1 -> if (Activity.RESULT_OK == resultCode) {
  14. Toast.makeText(
  15. this, "返回的数据为:" + data?.getStringExtra("data")
  16. , Toast.LENGTH_LONG
  17. ).show()
  18. }
  19. }
  20. }
  21. }

SecondActivity(xml)

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. xmlns:app="http://schemas.android.com/apk/res-auto"
  4. xmlns:tools="http://schemas.android.com/tools"
  5. android:layout_width="match_parent"
  6. android:layout_height="match_parent"
  7. tools:context=".intent.SecondActivity">
  8. <Button
  9. android:id="@+id/btnReturn"
  10. android:layout_width="match_parent"
  11. android:layout_height="wrap_content"
  12. android:text="Finish"
  13. android:textAllCaps="false"
  14. app:layout_constraintTop_toTopOf="parent" />
  15. </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

  1. class SecondActivity : AppCompatActivity() {
  2. override fun onCreate(savedInstanceState: Bundle?) {
  3. super.onCreate(savedInstanceState)
  4. setContentView(R.layout.activity_second)
  5. btnReturn.setOnClickListener {
  6. val intent =Intent()
  7. intent.putExtra("data","我是返回的数据")
  8. setResult(Activity.RESULT_OK,intent)
  9. finish()
  10. }
  11. }
  12. }

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

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

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

1、Activity之间的跳转

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

  1. <activity
  2. android:name=".intent.SecondActivity"
  3. android:label="SecondActivity">
  4. <intent-filter>
  5. <action android:name="ldx"/>
  6. <category android:name="android.intent.category.DEFAULT"/>
  7. </intent-filter>
  8. </activity>

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

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

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

FirstActivity.kt

  1. class FirstActivity : AppCompatActivity() {
  2. override fun onCreate(savedInstanceState: Bundle?) {
  3. super.onCreate(savedInstanceState)
  4. setContentView(R.layout.activity_main)
  5. btn.setOnClickListener {
  6. val intent=Intent("ldx")
  7. startActivity(intent)
  8. }
  9. }
  10. }

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

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

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

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

代码如下:

AndroidManifest.xml

  1. <activity
  2. android:name=".intent.SecondActivity"
  3. android:label="SecondActivity">
  4. <intent-filter>
  5. <action android:name="ldx"/>
  6. <category android:name="android.intent.category.DEFAULT"/>
  7. <!--这个DEFAULT不能删除,其他的category该怎么加还要怎么加-->
  8. <category android:name="zw"/>
  9. </intent-filter>
  10. </activity>

FirstActivity.kt

  1. class FirstActivity : AppCompatActivity() {
  2. override fun onCreate(savedInstanceState: Bundle?) {
  3. super.onCreate(savedInstanceState)
  4. setContentView(R.layout.activity_main)
  5. btn.setOnClickListener {
  6. val intent=Intent("ldx")
  7. intent.addCategory("zw")
  8. startActivity(intent)
  9. }
  10. }
  11. }

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

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

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/我家小花儿/article/detail/267059
推荐阅读
相关标签