Computer >> คอมพิวเตอร์ >  >> การเขียนโปรแกรม >> Android

จะสร้างไดอะล็อกแบบกำหนดเองแบบเต็มหน้าจอใน Android ได้อย่างไร


ตัวอย่างนี้สาธิตเกี่ยวกับวิธีการสร้างกล่องโต้ตอบแบบกำหนดเองแบบเต็มหน้าจอ

ขั้นตอนที่ 1 − สร้างโครงการใหม่ใน Android Studio ไปที่ไฟล์ ⇒ โครงการใหม่และกรอกรายละเอียดที่จำเป็นทั้งหมดเพื่อสร้างโครงการใหม่

ขั้นตอนที่ 2 − เพิ่มรหัสต่อไปนี้ใน res/layout/activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="https://schemas.android.com/apk/res/android"
   android:id="@+id/parent"
   xmlns:tools="https://schemas.android.com/tools"
   android:layout_width="match_parent"
   android:layout_height="match_parent"
   tools:context=".MainActivity"
   android:gravity="center"
   android:orientation="vertical">
   <Button
      android:id="@+id/customDialog"
      android:text="Custom Dialog"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content" />
</LinearLayout>

ในโค้ดด้านบนเราได้นำปุ่ม เมื่อผู้ใช้คลิกที่ปุ่ม มันจะแสดงกล่องโต้ตอบที่กำหนดเอง

ขั้นตอนที่ 3 − เพิ่มรหัสต่อไปนี้ใน src/MainActivity.java

package com.example.andy.myapplication;
import android.app.Activity;
import android.graphics.Rect;
import android.os.Build;
import android.os.Bundle;
import android.support.annotation.RequiresApi;
import android.support.v7.app.AlertDialog;
import android.support.v7.app.AppCompatActivity;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.view.Window;
import android.view.WindowManager;
import android.widget.Button;

public class MainActivity extends AppCompatActivity {
   @RequiresApi(api = Build.VERSION_CODES.JELLY_BEAN)
   @Override
   protected void onCreate(Bundle savedInstanceState) {
      super.onCreate(savedInstanceState);
      setContentView(R.layout.activity_main);
      findViewById(R.id.customDialog).setOnClickListener(new View.OnClickListener() {
         @Override
         public void onClick(View v) {
            Rect displayRectangle = new Rect();
            Window window = MainActivity.this.getWindow();
            window.getDecorView().getWindowVisibleDisplayFrame(displayRectangle);
            final AlertDialog.Builder builder = new AlertDialog.Builder(MainActivity.this,R.style.CustomAlertDialog);
            ViewGroup viewGroup = findViewById(android.R.id.content);
            View dialogView = LayoutInflater.from(v.getContext()).inflate(R.layout.customview, viewGroup, false);
            dialogView.setMinimumWidth((int)(displayRectangle.width() * 1f));
            dialogView.setMinimumHeight((int)(displayRectangle.height() * 1f));
            builder.setView(dialogView);
            final AlertDialog alertDialog = builder.create();
            Button buttonOk=dialogView.findViewById(R.id.buttonOk);
            buttonOk.setOnClickListener(new View.OnClickListener() {
               @Override
               public void onClick(View v) {
                  alertDialog.dismiss();
               }
            });
            alertDialog.show();
         }
      });
   }
}

เพื่อแสดงกล่องโต้ตอบที่กำหนดเอง เราได้ขยายมุมมองเป็นมุมมองที่กำหนดเอง ดังนั้นสร้าง customview.xml และเพิ่มรหัสต่อไปนี้ -

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="https://schemas.android.com/apk/res/android"
   android:layout_width="match_parent"
   android:layout_height="match_parent"
   android:orientation="vertical">
   <LinearLayout
      android:layout_width="match_parent"
      android:layout_height="wrap_content"
      android:orientation="vertical"
      android:padding="16dp">
      <TextView
         android:layout_width="match_parent"
         android:layout_height="wrap_content"
         android:text="Success"
         android:textAlignment="center"
         android:textAppearance="@style/TextAppearance.AppCompat.Headline" />
      <TextView
         android:layout_width="match_parent"
         android:layout_height="wrap_content"
         android:layout_marginTop="10dp"
         android:text="Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nulla eu erat tincidunt lacus fermentum rutrum."
         android:textAlignment="center"
         android:textAppearance="@style/TextAppearance.AppCompat.Medium" />
      <Button
         android:id="@+id/buttonOk"
         android:layout_width="200dp"
         android:layout_height="wrap_content"
         android:layout_gravity="center"
         android:layout_marginTop="15dp"
         android:background="@color/colorPrimary"
         android:text="Ok"
         android:textColor="#FFF" />
   </LinearLayout>
</LinearLayout>

ในโค้ดด้านบนนี้ เราได้ติดตั้งธีมที่กำหนดเองสำหรับกล่องโต้ตอบการแจ้งเตือนดังที่แสดงด้านล่าง -

final AlertDialog.Builder builder = new AlertDialog.Builder(MainActivity.this,R.style.CustomAlertDialog);

ตอนนี้สร้างแท็กใน res/styles.xml ดังที่แสดงด้านล่าง -

<style name="CustomAlertDialog" parent="Theme.AppCompat.Light.Dialog.Alert">
   <item name="android:windowBackground">@drawable/popup_background</item>
</style>

ใน cod ด้านบนเราได้เพิ่มพื้นหลังเป็น popup_backround ดังนั้นให้สร้าง drawable ในโฟลเดอร์ drawable เป็น popup_background.xml และเพิ่มรหัสต่อไปนี้ -

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="https://schemas.android.com/apk/res/android">
   <solid android:color="#FFFFFF" />
   <corners android:radius="6dp" />
</shape>

หากต้องการแสดงกล่องโต้ตอบการแจ้งเตือนที่กำหนดเองแบบเต็มหน้าจอ ให้ใช้รหัสต่อไปนี้ -

Rect displayRectangle = new Rect();
Window window = MainActivity.this.getWindow();
window.getDecorView().getWindowVisibleDisplayFrame(displayRectangle);
final AlertDialog.Builder builder = new AlertDialog.Builder(MainActivity.this,R.style.CustomAlertDialog);
ViewGroup viewGroup = findViewById(android.R.id.content);
View dialogView = LayoutInflater.from(v.getContext()).inflate(R.layout.customview, viewGroup, false);
dialogView.setMinimumWidth((int)(displayRectangle.width() * 1f));
dialogView.setMinimumHeight((int)(displayRectangle.height() * 1f));
builder.setView(dialogView);
final AlertDialog alertDialog = builder.create();
Button buttonOk=dialogView.findViewById(R.id.buttonOk);
buttonOk.setOnClickListener(new View.OnClickListener() {
   @Override
   public void onClick(View v) {
      alertDialog.dismiss();
   }
});
alertDialog.show();

มาลองเรียกใช้แอปพลิเคชันของคุณกัน ฉันคิดว่าคุณได้เชื่อมต่ออุปกรณ์มือถือ Android จริงกับคอมพิวเตอร์ของคุณ ในการรันแอพจาก android studio ให้เปิดไฟล์กิจกรรมของโปรเจ็กต์แล้วคลิก Runicon จากแถบเครื่องมือ เลือกอุปกรณ์มือถือของคุณเป็นตัวเลือก แล้วตรวจสอบอุปกรณ์มือถือของคุณซึ่งจะแสดงหน้าจอเริ่มต้นของคุณ -

จะสร้างไดอะล็อกแบบกำหนดเองแบบเต็มหน้าจอใน Android ได้อย่างไร

ในผลลัพธ์ข้างต้น มันแสดงหน้าจอเริ่มต้น ตอนนี้คลิกที่ปุ่มจะเปิดกล่องโต้ตอบที่กำหนดเองแบบเต็มหน้าจอดังที่แสดงด้านล่าง -

จะสร้างไดอะล็อกแบบกำหนดเองแบบเต็มหน้าจอใน Android ได้อย่างไร