如何在 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 次瀏覽

啟動您的 職業生涯

完成課程獲得認證

開始學習
廣告