activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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/tv_comback"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textSize="30sp"
android:text="값을 가져와 주세요"/>
<Button
android:id="@+id/btn_go"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="go"/>
</LinearLayout>
--------------------------------
--------------------------------
MainActivity.java
package com.example.comeback;
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.TextView;
import android.widget.Toast;
public class MainActivity extends AppCompatActivity {
private TextView tv_comback;
private Button btn_go;
private static final int REQUEST_CODE = 777; // 상수 값을 선언 (상수 - 항상 같은 수, 변하지 않을 수)
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
tv_comback = findViewById(R.id.tv_comback);
btn_go = findViewById(R.id.btn_go);
btn_go.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
Intent intent = new Intent(getApplicationContext(), SubActivity.class);
startActivityForResult(intent, REQUEST_CODE);
}
});
}
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
if (resultCode == RESULT_OK) {
Toast.makeText(getApplicationContext(), "수신 성공", Toast.LENGTH_SHORT).show();
} else {
Toast.makeText(getApplicationContext(), "수신 실패", Toast.LENGTH_SHORT).show();
}
if (requestCode == REQUEST_CODE) {
String resultTxt = data.getStringExtra("comback");
tv_comback.setText(resultTxt);
}
}
}
--------------------------------
java 파일 생성
--------------------------------
SubActivity.java
package com.example.comeback;
import androidx.appcompat.app.AppCompatActivity;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
public class SubActivity extends AppCompatActivity {
private EditText et_comback;
private Button btn_close;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_sub);
et_comback = findViewById(R.id.et_comback);
btn_close = findViewById(R.id.btn_close);
btn_close.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
Intent intent = new Intent();
intent.putExtra("comback", et_comback.getText().toString()); // 입력 폼에 적은 값 담아주기
setResult(RESULT_OK, intent); // 결과 값 설정
finish(); // 현재 액티비티 종료
}
});
}
}
--------------------------------
--------------------------------
activity_sub.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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">
<EditText
android:id="@+id/et_comback"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:hint="Main으로 보낼 값을 입력해주세요"/>
<Button
android:id="@+id/btn_close"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="종료"/>
</LinearLayout>
--------------------------------
'안드로이드 앱 만들기' 카테고리의 다른 글
Linear Layout (1) (0) | 2020.09.01 |
---|---|
Button Selector (0) | 2020.08.30 |
바텀 네비게이션 뷰(인스타 하단 바) (0) | 2020.08.29 |
google map (0) | 2020.08.29 |
뒤로가기 두번 눌러 앱 종료 (0) | 2020.08.29 |