728x90
반응형
안녕하세요 이번 글에서는 저번 글에 이어서 intent의 사용방법에 대해서 알아보겠습니다.
지난 글에서는 intent를 이용하여 값을 전달하는 방법에 대해서 알아보았습니다.
이번 글에서는 보낸 intent객체를 다시 돌려받는 방법을 알아보겠습니다.
<?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=".MainActivity">
<TextView
android:id="@+id/textView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Hello World!"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<Button
android:id="@+id/btn_a"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="32dp"
android:text="서브 화면으로 이동"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/textView" />
</androidx.constraintlayout.widget.ConstraintLayout>
activity_main.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=".subActivity">
<TextView
android:id="@+id/tv_getMsg"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="서브 텍스트뷰"
android:textSize="80px"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<Button
android:id="@+id/btn_close"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="액티비티 닫기"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/tv_getMsg"
app:layout_constraintVertical_bias="0.209" />
</androidx.constraintlayout.widget.ConstraintLayout>
activity_sub.xml
package com.example.intent_kt
import android.app.Activity
import android.content.Intent
import androidx.appcompat.app.AppCompatActivity
import android.os.Bundle
import android.widget.Toast
import kotlinx.android.synthetic.main.activity_main.*
class MainActivity : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
//버튼 클릭 이벤트
btn_a.setOnClickListener{
val intent = Intent(this,subActivity::class.java) // 다음 화면으로 이동하기 위한 인텐트 객체 생성
intent.putExtra("msg",textView.text.toString()) // key value 값 으로 생성
/*
* intent객체를 보낸 다음 돌려받을 때에는 startActivityForResult() 사용한다.
* startActivityForResult의 두번쨰 인자인 requestCode는 메인 액티비티에서 서브 액티비티를 호출하는 버튼이 여러개 있을 때 어떤 버튼에서
* 호출된 것인지를 구분하는 용도입니다.
* */
startActivityForResult(intent,99);//intent 에 저장되어 있는 액티비티 쪽으로 이동한다.
}
}
// 서브 액티비티 에서 돌려준 intent를 받기위한 함수
override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {
super.onActivityResult(requestCode, resultCode, data)
//서브 액티비티 에서 정상적으로 데이터가 넘어 왔는지 확인하는 코드
if(resultCode == Activity.RESULT_OK){
//startActivityForResult를 사용하여 보낸 reqeustCode를 확인하기 위한 코드
when(requestCode){
99 -> {
var message = data?.getStringExtra("message")
//Toast메세지를 이용하여 값확인
Toast.makeText(this,message,Toast.LENGTH_SHORT).show()
}
}
}
}
}
MainActivity를 위와 같이 코딩하여 줍니다.
package com.example.intent_kt
import android.app.Activity
import android.content.Intent
import androidx.appcompat.app.AppCompatActivity
import android.os.Bundle
import kotlinx.android.synthetic.main.activity_sub.*
class subActivity : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_sub)
//넘겨 받은 Intent 객체에 해당 Key 값이 들어 있는지 확인
if(intent.hasExtra("msg")){
tv_getMsg.text = intent.getStringExtra("msg") // 서브 액티비티에 존재하는 텍스트뷰에다가 Hello World 가 옮겨져 온다.
}
btn_close.setOnClickListener {
//intent 객체를 돌려줄 때는 target을 따로 설정하지 않습니다.
val returnIntent:Intent = intent
intent.putExtra("message","리턴받은 intent")
//setResult를 이용하여 돌려줍니다.
//첫번쨰 인자는 성공실패 여부를 보내는 구분값으로 사용 됩니다.
setResult(Activity.RESULT_OK,returnIntent)
finish()
}
}
}
SubActivity를 위와 같이 코딩하여 줍니다.
차례대로 버튼을 클릭하면 위와 같은 결과 화면을 확인할 수 있습니다.
감사합니다.
728x90
반응형
'KOTLIN' 카테고리의 다른 글
코틀린(Kotlin) 리사이클러뷰 사용하기 (1) | 2021.01.10 |
---|---|
코틀린(Kotlin) Spinner 사용하기 (0) | 2021.01.09 |
코틀린(Kotlin) Intent 사용하기 (0) | 2021.01.09 |
[ 안드로이드 스튜디오 ] 컨스트레인트 레이아웃 사용하기 (0) | 2021.01.02 |
코틀린(Kotlin) Null 값에 대한 처리 (0) | 2021.01.02 |