반응형
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 |