In this Jetpack compose material tutorial we will learn How to pass data between two activities with jetpack compose in Android application.
Suppose we have two screens Activity A and Activity B. Now when we navigate from A to B i need some data to required at Activity B which is from Activity A. So to pass this data we will use the Intent objects. An activity is basically a single screen in app. We can open a new activity B passing an intent object to startActivity()
Let's get started
Step 1: Create android application in android studio
Step 2: Follow step for setup Jetpack Compose with Android Studio
Create 2 ComponentActivity say MainActivity.kt and Activity1.kt
In MainActivity.kt lets add one button on clicking which we are going to launch ActivityA and pass some data through intent.
To send data from activity to another activity we will use intent extras property . It will takes data as key value pair that carries all the additional information for an activity.
@Composable fun ActivityDemo() { val context = LocalContext.current JetPackTheme() { Column(content = { Text("Activity 1") Text("Name : Rinky") Text("Age : 12") Text("Gender : Male") Text("Param1 : Abhishek") Text("Param2 : Shaw") Text("Click button below to send data to activity 2") Button(onClick = { val intent = Intent(context, Activity1::class.java) intent.putExtra("Name", "Rinky") intent.putExtra("Age", 12) intent.putExtra("IsMale", true) context.startActivity(intent) }) { Text("Click") } }, modifier = Modifier .fillMaxWidth() .fillMaxHeight()) } } |
Intent support only primitive data types to pass data from one screen to other screen. It will support int,String,long,float...
Let's pass data as primitive type
Here is the simple way to pass the data from one screen to other screen
val intent = Intent(context, Activity1::class.java)
intent.putExtra("Name", "Rinky")
intent.putExtra("Age", 12)
intent.putExtra("IsMale", true)
context.startActivity(intent)
|
in the above code we passed int,Sting,boolean type data
How we can pass the object type data between activities?
Intent doesn't provide direct way to pass object type data from one screen to other screen, to pass object type data from one screen to other by two ways
Convert Object to String data type
In this approach we will convert object data to string and pass to the intent. To convert Object to string we are using the GSON converter theory.
Add dependency in build.gradle file
api 'com.google.code.gson:gson:2.8.8' |
Let's create a data class
data class JsonData(val param1: String?, val param2: String?) object JsonDataOps { fun toJson(data: JsonData?): String? { try { if (data != null) { val gsonBuilder = GsonBuilder() gsonBuilder.serializeNulls() val gson = gsonBuilder.create() return gson.toJson(data) } } catch (e: java.lang.Exception) { } return null } fun fromStringToData(value: String?): JsonData? { try { if (value != null) { val typeToken = object : TypeToken() {}.type val gsonBuilder = GsonBuilder() gsonBuilder.serializeNulls() val gson = gsonBuilder.create() if (gson != null) { val data: JsonData? = gson.fromJson(value, typeToken) return data } } } catch (e: java.lang.Exception) { } return null } }
|
In the above we are converted Object data to string by using gson object
gson.fromJson(value, typeToken) |
val intent = Intent(context, Activity1::class.java) intent.putExtra("Name", "Rinky") intent.putExtra("Age", 12) intent.putExtra("IsMale", true) val jsonData = JsonData("Abc", "abc@gmail.com") intent.putExtra("json_data", JsonDataOps.toJson(jsonData)) context.startActivity(intent) |
Pass Object data between screen by Parcelable format
To pass data as Parcelable we need to implement class with Parcelble interface.
Lets create Parcelable class
package com.example.jetpack.datamodels import android.os.Parcel import android.os.Parcelable data class ParcelableData(val param1: String?,val param2: String?):Parcelable{ constructor(parcel: Parcel) : this( parcel.readString(), parcel.readString() ) override fun writeToParcel(parcel: Parcel, flags: Int) { parcel.writeString(param1) parcel.writeString(param2) } override fun describeContents(): Int { return 0 } companion object CREATOR : Parcelable.Creator { override fun createFromParcel(parcel: Parcel): ParcelableData { return ParcelableData(parcel) } override fun newArray(size: Int): Array { return arrayOfNulls(size) } } } |
Now create an object of Parcelable Data and send it through putExtra
val intent = Intent(context, Activity1::class.java)
intent.putExtra("Name", "Rinky")
intent.putExtra("Age", 12)
intent.putExtra("IsMale", true)
val parcelableData = ParcelableData("Abhishek", "Shaw")
intent.putExtra("parcelable_data", parcelableData)
context.startActivity(intent)
|
Full code for MainActivity.kt
package com.example.jetpack
import android.content.Intent
import android.os.Bundle
import android.view.WindowManager
import androidx.activity.ComponentActivity
import androidx.activity.compose.setContent
import androidx.compose.foundation.layout.*
import androidx.compose.material.Button
import androidx.compose.material.Text
import androidx.compose.runtime.*
import androidx.compose.ui.Alignment
import androidx.compose.ui.Modifier
import androidx.compose.ui.platform.LocalContext
import androidx.compose.ui.tooling.preview.Preview
import com.example.jetpack.activities.Activity1
import com.example.jetpack.datamodels.*
import com.example.jetpack.ui.theme.JetPackTheme
class MainActivity : ComponentActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
window.setSoftInputMode(WindowManager.LayoutParams.SOFT_INPUT_ADJUST_RESIZE)
setContent {
ActivityDemo()
}
}
}
@Composable
fun ActivityDemo() {
val context = LocalContext.current
JetPackTheme() {
Column(
content = {
Text("Activity 1")
Text("Name : Rinky")
Text("Age : 12")
Text("Gender : Male")
Text("Param1 : Abhishek")
Text("Param2 : Shaw")
Text("Click button below to send data to activity 2")
Button(onClick = {
val intent = Intent(context, Activity1::class.java)
intent.putExtra("Name", "Rinky")
intent.putExtra("Age", 12)
intent.putExtra("IsMale", true)
val parcelableData = ParcelableData("Abhishek", "Shaw")
intent.putExtra("parcelable_data", parcelableData)
val jsonData = JsonData("Abc", "abc@gmail.com")
intent.putExtra("json_data", JsonDataOps.toJson(jsonData))
context.startActivity(intent)
}) {
Text("Click")
}
}, modifier = Modifier.fillMaxSize(), verticalArrangement = Arrangement.Center,
horizontalAlignment = Alignment.CenterHorizontally
)
}
}
@Preview(showBackground = true)
@Composable
fun DefaultPreview() {
ActivityDemo()
}
|
Full code for Activity1.kt
package com.example.jetpack.activities
import android.os.Bundle
import androidx.activity.ComponentActivity
import androidx.activity.compose.setContent
import androidx.compose.foundation.layout.*
import androidx.compose.material.MaterialTheme
import androidx.compose.material.Surface
import androidx.compose.material.Text
import androidx.compose.runtime.Composable
import androidx.compose.ui.Alignment
import androidx.compose.ui.Modifier
import androidx.compose.ui.platform.LocalContext
import androidx.compose.ui.tooling.preview.Preview
import com.example.jetpack.activites.ui.theme.MyApplicationTheme
import com.example.jetpack.datamodels.JsonDataOps
import com.example.jetpack.datamodels.ParcelableData
class Activity1 : ComponentActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContent {
MyApplicationTheme {
// A surface container using the 'background' color from the theme
Surface(color = MaterialTheme.colors.background) {
ShowData()
}
}
}
}
}
@Composable
fun ShowData() {
val context = LocalContext.current
val intent = (context as Activity1).intent
val name = intent.getStringExtra("Name")
val age = intent.getIntExtra("Age", 0)
val isMale = intent.getBooleanExtra("IsMale", false)
val parcelableData = intent.getParcelableExtra("parcelable_data")
val jsonData = JsonDataOps.fromStringToData(intent.getStringExtra("json_data"))
Column(
content = {
Text("Activity 2")
Text("Name : $name")
Text("Age : $age")
Text("Gender : ${if (isMale) "Male" else "Female"}")
Text("Parcelable Data")
Text("Param1 : ${parcelableData?.param1}")
Text("Param2 : ${parcelableData?.param2}")
Text("Json Data")
Text("Param1 : ${jsonData?.param1}")
Text("Param2 : ${jsonData?.param2}")
}, modifier = Modifier.fillMaxSize(), verticalArrangement = Arrangement.Center,
horizontalAlignment = Alignment.CenterHorizontally
)
}
@Preview(showBackground = true)
@Composable
fun DefaultPreview2() {
MyApplicationTheme {
ShowData()
}
}
|
Images
Article Contributed By :
|
|
|
|
5373 Views |