상세 컨텐츠

본문 제목

[안드로이드] 다이얼로그(Dialog) 사용자정의 (Custom) 화면으로 보여주기

안드로이드

by aries574 2021. 1. 7. 15:35

본문


2021/01/05 - [안드로이드] - [안드로이드] 다이얼로그(Dialog) 리스트(List)로 보여주는 방법

2021/01/06 - [안드로이드] - [안드로이드]다이얼로그(Dialog) 체크박스(CheckBox)로 보여주기


이번 시간에는 다이얼로그 화면을 사용자가 직접 만든 화면으로 적용하는 예제를 

만들어 보겠습니다.


1. 메인화면 구현(activity_main.xml)

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout 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:id="@+id/rootLayout"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
tools:context=".MainActivity"
>

<Button
android:id="@+id/btn_dialog"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerVertical="true"
android:layout_centerHorizontal="true"
android:text="다이얼로그"/>

</RelativeLayout>


2. 다이얼로그(Dialog)커스텀 화면 만들기

파일명은 custom_dialog_layout 로 하겠습니다

custom_dialog_layout.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="horizontal">

<ImageView
android:layout_width="wrap_content"
android:layout_height="150dp"
android:src="@drawable/ic_person"/>

<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical">

<EditText
android:layout_width="match_parent"
android:layout_height="75dp"
android:hint="ID"
/>

<EditText
android:layout_width="match_parent"
android:layout_height="75dp"
android:hint="Password"
/>
</LinearLayout>

</LinearLayout>

imageView 파일

ic_person.xml



3. 메인코드 구현(MainActivity.java)


import androidx.appcompat.app.AlertDialog;
import androidx.appcompat.app.AppCompatActivity;
import android.content.DialogInterface;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.widget.Button;


public class MainActivity extends AppCompatActivity{

Button btn_dialog;

AlertDialog.Builder builder;

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

btn_dialog = findViewById(R.id.btn_dialog);

btn_dialog.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
showDialog();
}
});
}

public void showDialog(){

builder = new AlertDialog.Builder(MainActivity.this);

//커스텀 화면 적용
LayoutInflater inflater = getLayoutInflater();

builder.setView(inflater.inflate(R.layout.custom_dialog_layout, null));

//
builder.setPositiveButton("Login", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {

}
});

//아니오
builder.setNegativeButton("Cancel", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
dialog.cancel();
}
});

AlertDialog alertDialog = builder.create();
alertDialog.show();
}
}


4. 실행화면




2021/01/05 - [안드로이드] - [안드로이드] 다이얼로그(Dialog) 리스트(List)로 보여주는 방법

2021/01/06 - [안드로이드] - [안드로이드]다이얼로그(Dialog) 체크박스(CheckBox)로 보여주기



반응형

관련글 더보기

댓글 영역