본문 바로가기
개발툴/Android Studio

[안드로이드 스튜디오] 전화걸기 및 레이아웃 간 변수 전달

by 펜네임 2019. 10. 1.

코드

 

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

    <EditText
        android:id="@+id/et_tel"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:ems="10"
        android:inputType="textPersonName"
        android:text="Name"
        app:layout_constraintBottom_toTopOf="@+id/btn_tel"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.08"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintVertical_bias="0.533" />

    <Button
        android:id="@+id/btn_tel"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:onClick="OnBtnClick"
        android:text="전화걸기"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.049"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintVertical_bias="0.109" />

    <Button
        android:id="@+id/button2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="16dp"
        android:onClick="OnBtnClickSub"
        android:text="SUB 이동"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.049"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/btn_tel" />
</androidx.constraintlayout.widget.ConstraintLayout>

 

 

 

MainActivity.java

package com.example.phonesample;

import androidx.appcompat.app.AppCompatActivity;

import android.content.Intent;
import android.net.Uri;
import android.os.Bundle;
import android.view.View;
import android.widget.EditText;

public class MainActivity extends AppCompatActivity {
    EditText et_tel;

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

        // 객체 연결
        et_tel = findViewById(R.id.et_tel);

    }

    // 버튼 이벤트 (Button1)
    public void OnBtnClick(View v) {
        String data = et_tel.getText().toString();      // toString() : 받은 값을 문자열로 바꿔줌

        Intent intent = new Intent(Intent.ACTION_VIEW, Uri.parse(data));
        startActivity(intent);
    }

    // sub 이동 버튼 클릭 시 이벤트
    public void OnBtnClickSub(View v) {
        Intent intent = new Intent(this, SubActivity.class);    // 현재 액티비티에서, 섭액티비티로 가겠음
        intent.putExtra("name", "이혜민");     // 인텐트에다 다른 액티비티에 넘길 String 값을 저장
        intent.putExtra("age", 27);            // 인텐트에다 다른 액티비티에 넘길 int 값을 저장
        startActivity(intent);
    }

}

 

 

 

activity_sub.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"
    android:orientation="vertical">

    <TextView
        android:id="@+id/tv2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="TextView"
        android:textSize="24sp"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.469"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/tv1"
        app:layout_constraintVertical_bias="0.084" />

    <TextView
        android:id="@+id/tv1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="TextView"
        android:textSize="24sp"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.469"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintVertical_bias="0.446" />

</androidx.constraintlayout.widget.ConstraintLayout>

 

 

 

SubActivity.java

package com.example.phonesample;

import android.content.Intent;
import android.os.Bundle;
import android.widget.TextView;

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

public class SubActivity extends AppCompatActivity {    // 액티비티의 기본 소양 : AppCompatActivity를 상속받을 것

    @Override
    protected void onCreate(@Nullable Bundle savedInstanceState) {      // 결과는 onCreate에서 받음
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_sub);

        Intent intent = getIntent();      // MainActivity에서 넘어온 intent 값을 받을 빈 intent
        String name = intent.getStringExtra("name");        // String을 받는 문법
        int age = intent.getIntExtra("age", 0);        // int를 받는 문법, 만약 넘어온 값이 없을 경우 값을 0으로 세팅하겠다

        TextView tv1 = findViewById(R.id.tv1);      // 메모리를 고려해 지역변수로 선언.
        TextView tv2 = findViewById(R.id.tv2);

        tv1.setText(name);
        tv2.setText(age + "");      // setText 매개변수로는 String 자료형만 가능. int를 setting 하려면 이런 문법을 사용해 String 타입으로 만들어야 함.
//        tv2.setText(Integer.toString(age));   // 이렇게도 String 타입(문자열)로 바꿀 수 있음
    }

}

 

 

 

AndroidManifest.xml

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

    <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/AppTheme">

        <activity android:name=".MainActivity">
            <intent-filter>     // app이 실행됐을 때 가장 먼저 띄우라는 명령 태그
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>

        <activity android:name=".SubActivity"
            android:label="Sub">
        </activity>

    </application>

</manifest>

 

 

 


실행화면

 

 

메인페이지

 

 

 

전화걸기 버튼 클릭 시

 

 

 

Sub 화면 (SUB 이동 버튼 클릭 시)

댓글