KOTLIN

코틀린(Kotlin) intent 사용하기 - [setResult & startActivityForResult]

사과씨앗 2021. 1. 9. 20:54
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
반응형