본문 바로가기

안드로이드

여러 화면 전환

반응형
https://whatisthenext.tistory.com/64
인텐트는 액티비티 간의 통신장치이다

 

 

액티비티에서 새 액티비티를 띄우기만 하는 것은 startActivity 메소드로 구현해도 되지만,

새 액티비티에서 원래의 액티비티로 돌아오면서, 새 액티비틔 응답을 받아 처리해야 하는 경우에는

어떤 액티비티로부터 돌아온 응답인지 구분해야, 이 응답을 처리 할 수 있으므로, 이를 처리 하기 위해 startActivitryForResult 메소드를 이용한다

 

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=".MainActivity">

    <Button
        android:id="@+id/button2"
        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_toTopOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout>

 

 

 

activity_menu.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=".MenuActivity">

    <Button
        android:id="@+id/button"
        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_toTopOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout>

 

 

app/manifests/AndroidManifest.xml

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.a20_sampleintent">

    <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/Theme.A20_SampleIntent">

        <!--
        label - 화면의 제목 설정
        theme - 테마 설정
        android:theme="@style/Theme.AppCompat.Dialog" - 액티비티 대화 상자 형태로 나타남
        -->
        <activity
            android:name=".MenuActivity"
            android:label="메뉴 액티비티"
            android:theme="@style/Theme.AppCompat.Dialog"></activity>

        <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>

 

 

MenuActivity

package com.example.a20_sampleintent;

import androidx.appcompat.app.AppCompatActivity;

import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;

public class MenuActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_menu);

        Button button = findViewById(R.id.button);
        button.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
//                https://whatisthenext.tistory.com/64
//                Intent - 액티비티끼리 서로 호출하기 위해서 필요한 통신장치
                Intent intent = new Intent();
                intent.putExtra("name", "mike");

//                Intent의 작업 결과를 대입
                setResult(RESULT_OK, intent);

//                현재 액티비티 없애기
                finish();
            }
        });
    }
}

 

 

 

MainActivity

package com.example.a20_sampleintent;

import androidx.annotation.Nullable;
import androidx.appcompat.app.AppCompatActivity;

import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.Toast;

public class MainActivity extends AppCompatActivity {

    //    새 액티비티를 띄울 때 보낼 요청 코드
    public static final int REQUEST_CODE_MENU = 101;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        Button button = findViewById(R.id.button2);
        button.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
//                getApplicationContext() 메소드를 사용해 이 앱의 Context 객체를 참조한 후 전달
                Intent intent = new Intent(getApplicationContext(), MenuActivity.class);

                startActivityForResult(intent, REQUEST_CODE_MENU);
            }
        });
    }

//    새로 띄웠던 메뉴액티비티가 응답을 보내오면, 그 응답을 처리하는 메소드
//    requestCode - 액티비티를 띄울 때 전달했던 요청 코드
//    resultCode - 새 액티비티로부터 전달된 응답 코드
//    data - 새 액티비티로부터 전달 받은 인텐트
    @Override
    protected void onActivityResult(int requestCode, int resultCode, Intent data) {
        super.onActivityResult(requestCode, resultCode, data);

        if (requestCode == REQUEST_CODE_MENU) {
            Toast.makeText(getApplicationContext(), "onActivityResult 호출됨. 요청 코드 : " + requestCode + ", 결과 코드 : " + requestCode, Toast.LENGTH_LONG).show();

            if (resultCode == RESULT_OK) {
                String name = data.getStringExtra("name");
                Toast.makeText(getApplicationContext(), "응답으로 전달된 name : " + name, Toast.LENGTH_LONG).show();
            }
        }
    }
}
반응형

'안드로이드' 카테고리의 다른 글

로그인 화면과 메뉴 화면 전환  (0) 2021.10.14
인텐트  (0) 2021.10.14
부분 화면  (0) 2021.10.13
시크바와 프로그레스바 보여주기  (0) 2021.10.12
두 종류의 버튼 모양 만들기  (0) 2021.10.12