自定义DialogAlert对话框并实现对话框的复用

一、演示效果
这里写图片描述
二、项目布局

自定义DialogAlert对话框并实现对话框的复用_第1张图片

三、项目代码

IAlertDialogButtonListener.java

package com.example.dialogalertbyself;

/** * 自定义Listener * * 用于实现Dialog的复用 * * @author xuliugen * */
public interface IAlertDialogButtonListener {

    /** * 实现对话框的点击事件 */
    public void onDialogOkButtonClick();

    public void onDialogCancleButtonClick();

}

MainActivity.java

package com.example.dialogalertbyself;

import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.Toast;

/** * 对于不同的按钮实现对DialogAlert的复用 * * @author xuliugen * */
public class MainActivity extends Activity {

    private Button button1;
    private Button button2;
    private Button button3;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        button1 = (Button) this.findViewById(R.id.button1);
        button2 = (Button) this.findViewById(R.id.button2);
        button3 = (Button) this.findViewById(R.id.button3);

        /* * 设置三个按钮的点击事件 */
        button1.setOnClickListener(new OnClickListener() {

            @Override
            public void onClick(View v) {
                // 将第一个按钮弹出对话框的信息,message和IAlertDialogButtonListener
                Util.showDialog(MainActivity.this, "我是第一个按钮",
                        firstButtonListener);
            }
        });
        button2.setOnClickListener(new OnClickListener() {

            @Override
            public void onClick(View v) {
                Util.showDialog(MainActivity.this, "我是第二个按钮",
                        secondButtonListener);
            }
        });
        button3.setOnClickListener(new OnClickListener() {

            @Override
            public void onClick(View v) {
                Util.showDialog(MainActivity.this, "我是第三个按钮",
                        thirdButtonListener);
            }
        });

    }

    private IAlertDialogButtonListener firstButtonListener = new IAlertDialogButtonListener() {

        @Override
        public void onDialogOkButtonClick() {
            Toast.makeText(MainActivity.this, "第一个按钮--你点的是确认",
                    Toast.LENGTH_SHORT).show();

        }

        @Override
        public void onDialogCancleButtonClick() {
            Toast.makeText(MainActivity.this, "第一个按钮--你点的是取消",
                    Toast.LENGTH_SHORT).show();
        }

    };

    private IAlertDialogButtonListener secondButtonListener = new IAlertDialogButtonListener() {

        @Override
        public void onDialogOkButtonClick() {
            Toast.makeText(MainActivity.this, "第二个按钮--你点的是确认",
                    Toast.LENGTH_SHORT).show();
        }

        @Override
        public void onDialogCancleButtonClick() {
            Toast.makeText(MainActivity.this, "第二个按钮--你点的是取消",
                    Toast.LENGTH_SHORT).show();
        }

    };

    private IAlertDialogButtonListener thirdButtonListener = new IAlertDialogButtonListener() {

        @Override
        public void onDialogOkButtonClick() {
            Toast.makeText(MainActivity.this, "第三个按钮--你点的是确认",
                    Toast.LENGTH_SHORT).show();
        }

        @Override
        public void onDialogCancleButtonClick() {
            Toast.makeText(MainActivity.this, "第三个按钮--你点的是取消",
                    Toast.LENGTH_SHORT).show();
        }

    };

}

Util.java

package com.example.dialogalertbyself;

import android.app.AlertDialog;
import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.ImageButton;
import android.widget.TextView;

public class Util {

    private static AlertDialog mAlertDialog;

    /** * * 显示用户自定义的对话框 * * @param context * @param message * @param listener */
    public static void showDialog(Context context, String message,
            final IAlertDialogButtonListener listener) {

        LayoutInflater inflater = (LayoutInflater) context
                .getSystemService(Context.LAYOUT_INFLATER_SERVICE);

        View dialogView = inflater.inflate(R.layout.dialog_view, null);

        // 在创建Dialog的时候设置样式为透明的,并且要求api最低为11
        AlertDialog.Builder builder = new AlertDialog.Builder(context,
                R.style.Theme_Transparent);

        // ok按钮
        ImageButton btnOkButton = (ImageButton) dialogView
                .findViewById(R.id.btn_dialog_ok);
        // Cancel按钮
        ImageButton btnCancelButton = (ImageButton) dialogView
                .findViewById(R.id.btn_dialog_cancel);
        // 信息
        TextView txtMessageView = (TextView) dialogView
                .findViewById(R.id.text_dialog_message);

        // 设置文字内容
        txtMessageView.setText(message);

        // 设置btnOkButton的事件
        btnOkButton.setOnClickListener(new OnClickListener() {

            @Override
            public void onClick(View v) {
                if (mAlertDialog != null) { // 关闭对话框:判断对话框是否为空
                    mAlertDialog.cancel();
                }

                if (listener != null) {
                    // 设置回调,OnClick()就是IAlertDialogButtonListener接口中的方法
                    listener.onDialogOkButtonClick();// 执行接口的确定方法
                }
            }
        });

        // 设置btnCancelButton的事件
        btnCancelButton.setOnClickListener(new OnClickListener() {

            @Override
            public void onClick(View v) {
                if (mAlertDialog != null) {
                    mAlertDialog.cancel();
                }

                if (listener != null) {
                    // 设置回调,OnClick()就是IAlertDialogButtonListener接口中的方法
                    listener.onDialogCancleButtonClick();// 执行接口的取消方法
                }
            }
        });

        // 为dialog设置View
        builder.setView(dialogView);

        // 创建对话
        mAlertDialog = builder.create();

        // 显示对话框
        mAlertDialog.show();

    }
}

cancel_button_icon.xml

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

    <item android:drawable="@drawable/buytip_cancel_sel" android:state_pressed="true"/>
    <item android:drawable="@drawable/buytip_cancel"/>

</selector>

ok_button_icon.xml

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

    <item android:drawable="@drawable/buytip_ok_sel" android:state_pressed="true"/>
    <item android:drawable="@drawable/buytip_ok"/>

</selector>

activity_main.xml

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:gravity="center"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context=".MainActivity" >

    <Button
        android:id="@+id/button2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignLeft="@+id/button1"
        android:layout_below="@+id/button1"
        android:layout_marginTop="25dp"
        android:background="@drawable/bg"
        android:text="第二个按钮" />

    <Button
        android:id="@+id/button3"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignLeft="@+id/button2"
        android:layout_below="@+id/button2"
        android:layout_marginTop="22dp"
        android:background="@drawable/bg"
        android:text="第三个按钮" />

    <Button
        android:id="@+id/button1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentLeft="true"
        android:layout_alignParentTop="true"
        android:background="@drawable/bg"
        android:text="第一个按钮" />

</RelativeLayout>

dialog_view.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:background="@drawable/buytip_bg" android:gravity="center_horizontal" android:orientation="vertical" >

    <TextView  android:id="@+id/textView1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="提示" android:textColor="@color/black" android:textSize="24sp" />

    <TextView  android:id="@+id/text_dialog_message" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginBottom="40dp" android:layout_marginTop="40dp" android:paddingLeft="10dp" android:paddingRight="10dp" android:text="TextView" android:textColor="@color/black" android:textSize="18sp" />

    <LinearLayout  android:layout_width="match_parent" android:layout_height="wrap_content" android:gravity="center_horizontal" >

        <ImageButton  android:id="@+id/btn_dialog_cancel" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginRight="20dp" android:background="@drawable/cancel_button_icon" />

        <ImageButton  android:id="@+id/btn_dialog_ok" android:layout_width="wrap_content" android:layout_height="wrap_content" android:background="@drawable/ok_button_icon" />
    </LinearLayout>

</LinearLayout>

项目源码地址:
http://yunpan.cn/cJ4JLACNyqpkT 访问密码 683e

你可能感兴趣的:(自定义,DialogAler)