如何在 Android 中使用 Kotlin 将数据发送回主 Activity?


此示例演示如何在 Android 中使用 Kotlin 将数据发送回主 Activity

步骤 1 − 在 Android Studio 中创建一个新项目,转到文件 ⇒ 新建项目,并填写所有必需的详细信息以创建新项目。

步骤 2 − 将以下代码添加到 res/layout/activity_main.xml。

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
   xmlns:tools="http://schemas.android.com/tools"
   android:layout_width="match_parent"
   android:layout_height="match_parent"
   android:gravity="center_horizontal"
   android:orientation="vertical"
   tools:context=".MainActivity">
   <TextView
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:layout_marginTop="100dp"
      android:layout_marginBottom="50dp"
      android:text="Tutorials Point"
      android:textAlignment="center"
      android:textColor="@android:color/holo_green_dark"
      android:textSize="32sp"
      android:textStyle="bold" />
   <TextView
      android:id="@+id/textViewNumbers"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:text="Numbers: "
      android:textColor="@android:color/black"
      android:textSize="24sp"
      android:textStyle="bold" />
   <Button
      android:id="@+id/buttonAdd"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:layout_marginTop="10dp"
      android:text="add" />
   <Button
      android:id="@+id/buttonSubtract"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:layout_marginTop="5dp"
      android:text="subtract" />
</LinearLayout>

步骤 3 − 将以下代码添加到 src/MainActivity.kt

import android.app.Activity
import android.content.Intent
import android.os.Bundle
import android.widget.Button
import android.widget.EditText
import android.widget.TextView
import android.widget.Toast
import androidx.appcompat.app.AppCompatActivity
class MainActivity : AppCompatActivity() {
   private lateinit var textViewResult: TextView
   private lateinit var editTextNumber1: EditText
   private lateinit var editTextNumber2: EditText
   private lateinit var button: Button
   override fun onCreate(savedInstanceState: Bundle?) {
      super.onCreate(savedInstanceState)
      setContentView(R.layout.activity_main)
      title = "KotlinApp"
      textViewResult = findViewById(R.id.textViewResult)
      editTextNumber1 = findViewById(R.id.editTextNumber1)
      editTextNumber2 = findViewById(R.id.editTextNumber2)
      button = findViewById(R.id.btnOpenActivity2)
      button.setOnClickListener {
         if ((editTextNumber1.text.toString() == "" || editTextNumber2.text.toString() == "")) {
            Toast.makeText(this@MainActivity, "Please insert numbers", Toast.LENGTH_SHORT).show()
         } else {
            val number1 = Integer.parseInt(editTextNumber1.text.toString())
            val number2 = Integer.parseInt(editTextNumber2.text.toString())
            val intent = Intent(this@MainActivity, SecondActivity::class.java)
            intent.putExtra("number1", number1)
            intent.putExtra("number2", number2)
            startActivityForResult(intent, 1)
         }
      }
   }
   override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {
      super.onActivityResult(requestCode, resultCode, data)
      if (requestCode == 1) {
         if (resultCode == Activity.RESULT_OK) {
            val result = data!!.getIntExtra("result", 0)
            textViewResult.text = "" + result
         }
         if (resultCode == Activity.RESULT_CANCELED) {
            textViewResult.text = "Nothing selected"
         }
      }
   }
}

步骤 4 − 创建一个新的 Activity 并添加以下代码 −

activity_second.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
   xmlns:tools="http://schemas.android.com/tools"
   android:layout_width="match_parent"
   android:layout_height="match_parent"
   android:gravity="center_horizontal"
   android:orientation="vertical"
   tools:context=".MainActivity">
   <TextView
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:layout_marginTop="100dp"
      android:layout_marginBottom="50dp"
      android:text="Tutorials Point"
      android:textAlignment="center"
      android:textColor="@android:color/holo_green_dark"
      android:textSize="32sp"
      android:textStyle="bold" />
   <TextView
      android:id="@+id/textViewNumbers"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:text="Numbers: "
      android:textColor="@android:color/black"
      android:textSize="24sp"
      android:textStyle="bold" />
   <Button
      android:id="@+id/buttonAdd"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:layout_marginTop="10dp"
      android:text="add" />
   <Button
      android:id="@+id/buttonSubtract"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:layout_marginTop="5dp"
      android:text="subtract" />
</LinearLayout>

SecondActivity.kt

import android.app.Activity
import android.content.Intent
import android.os.Bundle
import android.widget.Button
import android.widget.TextView
import androidx.appcompat.app.AppCompatActivity
class SecondActivity : AppCompatActivity() {
   lateinit var textViewNumber: TextView
   lateinit var buttonAdd: Button
   lateinit var buttonSubtract: Button
   override fun onCreate(savedInstanceState: Bundle?) {
      super.onCreate(savedInstanceState)
      setContentView(R.layout.activity_second)
      val intent = intent
      val number1 = intent.getIntExtra("number1", 0)
      val number2 = intent.getIntExtra("number2", 0)
      textViewNumber = findViewById(R.id.textViewNumbers)
      textViewNumber.text = "Numbers: $number1, $number2"
      buttonAdd = findViewById(R.id.buttonAdd)
      buttonSubtract = findViewById(R.id.buttonSubtract)
      buttonAdd.setOnClickListener {
         val result = number1 + number2
         val resultIntent = Intent()
         resultIntent.putExtra("result", result)
         setResult(Activity.RESULT_OK, resultIntent)
         finish()
      }
      buttonSubtract.setOnClickListener {
         val result = number1 - number2
         val resultIntent = Intent()
         resultIntent.putExtra("result", result)
         setResult(Activity.RESULT_OK, resultIntent)
         finish()
      }
   }
}

步骤 5 − 将以下代码添加到 androidManifest.xml

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
   package="com.example.q11">
   <application
      android:allowBackup="true"
      android:icon="@mipmap/ic_launcher"
      android:label="@string/app_name"
      android:roundIcon="@mipmap/ic_launcher_round"
      android:supportsRtl="true"
      android:theme="@style/AppTheme">
      <activity android:name=".MainActivity">
         <intent-filter>
            <action android:name="android.intent.action.MAIN" />
            <category android:name="android.intent.category.LAUNCHER" />
         </intent-filter>
      </activity>
   </application>
</manifest>

让我们尝试运行您的应用程序。我假设您已将您的实际 Android 移动设备连接到您的计算机。要从 Android Studio 运行应用程序,请打开您的一个项目 Activity 文件,然后单击工具栏中的运行图标 。选择您的移动设备作为选项,然后检查您的移动设备,它将显示您的默认屏幕。

更新于:2020年11月5日

887 次浏览

启动您的 职业生涯

完成课程获得认证

开始学习
广告
© . All rights reserved.