Android UI - Dialog

Dialog

Android 中的对话框大概可分为这几种类型,普通对话框、列表对话框、单选对话框、多选对话框、自定义对话框。它们的原理都差不多,下面是创建对话框的基本步骤:

  1. 创建一个 AlertDialog.Builder 对象并获取它的构造器;
  2. 设置对话框的图标、标题、内容;
  3. 设置对话框按钮的监听事件;
  4. 创建对话框并显示出来。

普通对话框

1. XML 布局文件:

<LinearLayout 
    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:orientation="vertical"
    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="net.monkeychan.dialogtest.MainActivity" >

    <Button
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:onClick="simpleDialog"
        android:text="普通对话框" />

</LinearLayout>

2. Java 代码:

public class MainActivity extends Activity {

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

    }

    public void simpleDialog(View view) {
        
        // 1. 创建一个 AlertDialog.Builder 对象并获取它的构造器;
        AlertDialog.Builder builder = new AlertDialog.Builder(this);

        // 2. 设置对话框的图标、标题、内容;
        builder.setIcon(R.drawable.ic_launcher)
               .setTitle("普通对话框")
               .setMessage("是否授予这个应用拍照权限");

        // 3. 设置对话框按钮的监听事件;
        // 确定按钮
        builder.setPositiveButton("确定", new OnClickListener() {

            @Override
            public void onClick(DialogInterface dialog, int which) {
                Toast.makeText(MainActivity.this, "你授予了这个应用拍照权限", Toast.LENGTH_SHORT).show();
            }
        });
        // 取消按钮
        builder.setNegativeButton("拒绝", new OnClickListener() {

            @Override
            public void onClick(DialogInterface dialog, int which) {
                Toast.makeText(MainActivity.this, "你拒绝了授予这个应用拍照权限", Toast.LENGTH_SHORT).show();
            }
        });
        // 其它按钮
        builder.setNeutralButton("忽略", new OnClickListener() {

            @Override
            public void onClick(DialogInterface dialog, int which) {
                Toast.makeText(MainActivity.this, "你忽略了这个应用申请拍照权限的请求", Toast.LENGTH_SHORT).show();
            }
        });

        // 4. 创建对话框并显示出来。
        builder.create().show();
    }

}

3. 效果演示:

4. 代码优化:

上面三个按钮的代码有许多重复的地方,我们可以对其进行优化,下面是优化后的代码:

public class MainActivity extends Activity {

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

    }

    public void simpleDialog(View view) {

        // 创建一个 listener,用来监听对话框按钮的点击事件
        DialogInterface.OnClickListener listener = new OnClickListener() {

            @Override
            public void onClick(DialogInterface dialog, int which) {
                switch (which) {
                case Dialog.BUTTON_POSITIVE:
                    Toast.makeText(MainActivity.this, "你授予了这个应用拍照权限", Toast.LENGTH_SHORT).show();
                    break;
                case Dialog.BUTTON_NEGATIVE:
                    Toast.makeText(MainActivity.this, "你拒绝了授予这个应用拍照权限", Toast.LENGTH_SHORT).show();
                    break;
                case Dialog.BUTTON_NEUTRAL:
                    Toast.makeText(MainActivity.this, "你忽略了这个应用申请拍照权限的请求", Toast.LENGTH_SHORT).show();
                    break;
                }
            }
        };

        // 1. 创建一个 AlertDialog.Builder 对象并获取它的构造器;
        AlertDialog.Builder builder = new AlertDialog.Builder(this);

        // 2. 设置对话框的图标、标题、内容;
        builder.setIcon(R.drawable.ic_launcher)
               .setTitle("普通对话框")
               .setMessage("是否授予这个应用拍照权限");

        // 3. 设置对话框按钮的监听事件;
        // 确定按钮
        builder.setPositiveButton("确定", listener);
        // 取消按钮
        builder.setNegativeButton("拒绝", listener);
        // 其它按钮
        builder.setNeutralButton("忽略", listener);

        // 4. 创建对话框并显示出来。
        builder.create().show();
    }

}

列表对话框

1. XML 布局文件:

<LinearLayout 
    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:orientation="vertical"
    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="net.monkeychan.dialogtest.MainActivity" >

    <Button
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:onClick="listDialog"
        android:text="列表对话框" />

</LinearLayout>

2. Java 代码:

public class MainActivity extends Activity {

    private String[] fruit = { "Apple", "Banana", "Cherry", "Orange" };

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

    }

    public void listDialog(View view) {

        // 1. 创建一个 AlertDialog.Builder 对象并获取它的构造器;
        AlertDialog.Builder builder = new AlertDialog.Builder(this);

        // 2. 设置对话框的图标、标题、内容;
        // 3. 设置对话框按钮的监听事件;
        builder.setIcon(R.drawable.ic_launcher)
               .setTitle("列表对话框")
               .setItems(items, new OnClickListener() {

            @Override
            public void onClick(DialogInterface dialog, int which) {
                Toast.makeText(MainActivity.this, "你点击了" + fruit[which], Toast.LENGTH_SHORT).show();
            }
        });

        // 4. 创建对话框并显示出来。
        builder.create().show();
    }
}

3. 效果演示:

单选列表对话框

1. XML 布局文件:

<LinearLayout 
    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:orientation="vertical"
    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="net.monkeychan.dialogtest.MainActivity" >

    <Button
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:onClick="singleChoiceDialog"
        android:text="单选列表对话框" />

</LinearLayout>

2. Java 代码:

public class MainActivity extends Activity {

    private String[] gender = { "男", "女", "保密" };
    private String userSelect = "";

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

    }

    public void singleChoiceDialog(View view) {

        // 1. 创建一个 AlertDialog.Builder 对象并获取它的构造器;
        AlertDialog.Builder builder = new AlertDialog.Builder(this);

        // 2. 设置对话框的图标、标题、内容;
        builder.setIcon(R.drawable.ic_launcher)
               .setTitle("请选择您的性别")
               // 第一个参数为列表内容,第二个参数为默认选中项,第三个参数为监听事件
               .setSingleChoiceItems(gender, 0, new OnClickListener() {
                    
                    @Override
                    public void onClick(DialogInterface dialog, int which) {
                        // 获取用户的选择
                        userSelect = gender[which];
                    }
                });

        // 3. 设置对话框按钮的监听事件;
        // 确定按钮
        builder.setPositiveButton("确定", new OnClickListener() {
            
            @Override
            public void onClick(DialogInterface dialog, int which) {
                Toast.makeText(MainActivity.this, "您的性别是" + userSelect, Toast.LENGTH_SHORT).show();
            }
        });
        // 取消按钮
        builder.setNegativeButton("取消", null);

        // 4. 创建对话框并显示出来。
        builder.create().show();
    }

}

3. 效果演示:

多选列表对话框

1. XML 布局文件:

<LinearLayout 
    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:orientation="vertical"
    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="net.monkeychan.dialogtest.MainActivity" >

    <Button
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:onClick="multiChoiceDialog"
        android:text="多选列表对话框" />

</LinearLayout>

2. Java 代码:

public class MainActivity extends Activity {
    
    private String[] sports = { "足球", "篮球", "橄榄球", "撑杆跳", "台球" };
    private boolean[] selectStatus = { false, false, false, false, false, false };
    private String userSelect = "";

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

    }
    
    public void multiChoiceDialog(View view) {

        // 1. 创建一个 AlertDialog.Builder 对象并获取它的构造器;
        AlertDialog.Builder builder = new AlertDialog.Builder(this);

        // 2. 设置对话框的图标、标题、内容;
        builder.setIcon(R.drawable.ic_launcher)
               .setTitle("请选择您喜欢的运动")
               .setMultiChoiceItems(sports, selectStatus, new OnMultiChoiceClickListener() {
                // 第一个参数为多选列表的内容,第二个参数为默认选中项,该参数为一个 boolean 类型的数组,第三个参数为监听事件
                @Override
                    public void onClick(DialogInterface dialog, int which, boolean isChecked) {
                        userSelect = "";
                        for (int i = 0; i < selectStatus.length; i++) {
                            if (selectStatus[i]) {
                                userSelect += sports[i] + " ";
                            }
                        }
                    }
                });

        // 3. 设置对话框的监听事件;
        // 确定按钮
        builder.setPositiveButton("确定", new OnClickListener() {
            
            @Override
            public void onClick(DialogInterface dialog, int which) {
                Toast.makeText(MainActivity.this, "您选择的是 " + userSelect, Toast.LENGTH_SHORT).show();
            }
        });
        // 取消按钮
        builder.setNegativeButton("取消", null);

        // 4. 创建对话框并显示出来。
        builder.create().show();
    }

}

3. 效果演示:

进度条对话框

1. XML 布局文件:

<LinearLayout 
    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:orientation="vertical"
    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="net.monkeychan.dialogtest.MainActivity" >

    <Button
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:onClick="progressDialog"
        android:text="进度条对话框" />

</LinearLayout>

2. Java 代码:

public class MainActivity extends Activity {

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

    }
    
    public void progressDialog(View view) {
        
        // 创建一个 listener,用来监听对话框按钮的点击事件
                DialogInterface.OnClickListener listener = new OnClickListener() {

                    @Override
                    public void onClick(DialogInterface dialog, int which) {
                        switch (which) {
                        case ProgressDialog.BUTTON_POSITIVE:
                            Toast.makeText(MainActivity.this, "后台下载中", Toast.LENGTH_SHORT).show();
                            break;
                        case ProgressDialog.BUTTON_NEGATIVE:
                            Toast.makeText(MainActivity.this, "已取消下载", Toast.LENGTH_SHORT).show();
                            break;
                        }
                    }
                };

        // 1. 创建一个 ProgressDialog 对象;
        ProgressDialog progressDialog = new ProgressDialog(MainActivity.this);

        // 2. 设置对话框的图标、标题、内容,样式等;
        progressDialog.setIcon(R.drawable.ic_launcher);
        progressDialog.setTitle("文件下载");
        progressDialog.setMessage("文件下载中...");
        progressDialog.setProgressStyle(ProgressDialog.STYLE_HORIZONTAL); // 设置进度条为水平样式
        progressDialog.setCancelable(false); // 设置是否运行用户点击返回键取消对话框,false 表示不允许
        

        // 3. 设置对话框按钮的监听事件;
        // 确定按钮
        progressDialog.setButton(ProgressDialog.BUTTON_POSITIVE, "后台下载", listener);
        // 取消按钮
        progressDialog.setButton(ProgressDialog.BUTTON_NEGATIVE, "取消下载", listener);

        // 4. 显示对话框。
        progressDialog.show();
    }

}

3. 效果演示:

自定义对话框

1. 主布局文件:

<LinearLayout 
    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:orientation="vertical"
    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="net.monkeychan.dialogtest.MainActivity" >

    <Button
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:onClick="customDialog"
        android:text="自定义对话框" />

</LinearLayout>

2. 自定义布局文件:

<RelativeLayout
     xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:layout_margin="20dp" >
    
    <TextView 
        android:id="@+id/tv_name"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:textSize="16sp"
        android:text="用户名:" />
    
    <EditText 
        android:layout_toRightOf="@id/tv_name"
        android:id="@+id/et_name"
        android:layout_width="match_parent"
        android:layout_height="wrap_content" />
    
    <TextView 
        android:layout_marginTop="20dp"
        android:layout_below="@id/tv_name"
        android:id="@+id/tv_passwd"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
         android:textSize="16sp"
        android:text="密   码:" />
    
    <EditText
        android:id="@+id/et_passwd"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_below="@id/et_name"
        android:layout_toRightOf="@id/tv_passwd" />

</RelativeLayout>

3. 主布局文件对应的 Java 代码:

public class MainActivity extends Activity {
    
    EditText inputUserName;
    EditText inputUserPasswd;

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

    }
    
    public void customDialog(View view) {
        
        // 1. 创建一个 AlertDialog.Builder 对象并获取它的构造器;
        AlertDialog.Builder builder = new AlertDialog.Builder(this);
        
        // 2. 设置对话框的图标、标题、内容;
        // 使用布局加载器加载自定义布局
        View customView = getLayoutInflater().inflate(R.layout.login_layout, null);
        inputUserName = (EditText) customView.findViewById(R.id.et_name);
        inputUserPasswd = (EditText) customView.findViewById(R.id.et_passwd);
        
        builder.setIcon(R.drawable.ic_launcher)
               .setTitle("用户登录")
               .setView(customView); // 传入自定义布局
        
        // 3. 设置对话框按钮的监听事件;
        // 确定按钮
        builder.setPositiveButton("登录", new OnClickListener() {

            @Override
            public void onClick(DialogInterface dialog, int which) {

                String name = inputUserName.getText().toString();
                String passwd = inputUserPasswd.getText().toString();
                if (name.equals("123") && passwd.equals("abc")) {
                    Toast.makeText(MainActivity.this, "登录成功", 0).show();
                } else {
                    Toast.makeText(MainActivity.this, "登录失败", 0).show();
                }

            }
        });
        // 取消按钮
        builder.setNegativeButton("取消", null);
        
        // 4. 创建对话框并显示出来
        builder.create().show();
    }

}

4. 效果演示:


参考资料:

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,794评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,050评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,587评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,861评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,901评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,898评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,832评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,617评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,077评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,349评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,483评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,199评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,824评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,442评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,632评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,474评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,393评论 2 352

推荐阅读更多精彩内容