KOTLIN

코틀린(Kotlin) Intent 사용하기

사과씨앗 2021. 1. 9. 20:17
728x90
반응형

안녕하세요 이번 글에서는 안드로이드 애플리케이션에서 화면 전환 시 사용되는 intent를 사용하는 방법에 대해서 알아보겠습니다. 

 

먼저 main_activity.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=".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>

 

그다음 sub_activity.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" />
</androidx.constraintlayout.widget.ConstraintLayout>

 

화면이 완성 되었으면 MainActivy로 이동하겠습니다.

 

package com.example.intent_kt

import android.content.Intent
import androidx.appcompat.app.AppCompatActivity
import android.os.Bundle
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 값 으로 생성
            startActivity(intent);//intent 에 저장되어 있는 액티비티 쪽으로 이동한다.
            finish(); // 자기 자신의 액티비티를 파괴한다.
        }

    }
}

 

위 코드처럼 intent객체 초기화 시에 다음 화면으로 이동할 Activy를 지정하여 준 다음

putExtra를 이용하여 같이 넘겨줄 데이터를 세팅하여 줍니다. 

정리가 되었스면 startActivity를 이용하여 인텐트 객체를 보내여 줍니다.

그럼 ActivityManager는 데이터를 가지고 있는 intent 객체를 target이 된 Activity로 보내어줍니다.

 

 

package com.example.intent_kt

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 가 옮겨져 온다.

        }
    }
}

SubActivity로 이동하여 보내준 intent객체에서 키값을 기준으로 데이터를 불러와서 사용할 수 있습니다. 

 

main_activity

 

sub_activity

 

다음 글에서는 main_activity로 값을 돌려주는 방법에 대해서 알아보겠습니다.

 

감사합니다. 

728x90
반응형