安卓弹出对话框——Alertdialog(一)

首先看各种样式的对话框:

我们看到,Dialog有很多的子类实现,所以我们要定义一个对话框,使用其子类来实例化一个即可,而不要直接使用Dialog这个父类来构造。

二、AlertDialog

今天我们重点要来了解的就是AlertDialog对话框,我们看到,AlertDialog是Dialog的一个直接子类。

使用AlertDialog,我们可以显示一个标题,最多3个按钮操作,以及一组选择框或者是自己定义的弹出框。

这里借用android的官方文档提供的一个图来看看AlertDialog框的组成:

bubuko.com,布布扣

①区域1那里就是定义弹出框的头部信息,包括标题名或者是一个图标。

②区域2那里是AlertDialog对话框的content部分,在这里我们可以设置一些message信息,或者是定义一组选择框,还可以定义我们自己的布局弹出框。

③区域3那里使我们的Action Buttons部分,这里我们可以定义我们的操作按钮。

说到Action Buttons这里要特别注意一下:

在AlertDialog中,定义按钮都是通过 setXXXButton 方法来完成,其中一共有3种不同的Action Buttons供我们选择:

bubuko.com,布布扣

1.setPositiveButton(CharSequence text, DialogInterface.OnClickListener listener)</p><p>这是一个相当于OK、确定操作的按钮,</p><p>2.setNegativeButton (CharSequence text, DialogInterface.OnClickListener listener)</p><p>这是一个相当于取消操作的按钮。</p><p>3. setNeutralButton (CharSequence text, DialogInterface.OnClickListener listener)</p><p>这个是相当于一个忽略操作的按钮。

bubuko.com,布布扣

我们每一种action buttons最多只能出现一个,即弹出对话框最多只能出现一个PositiveButton。

接下来我们通过一个一个的具体实例来看看我们常用的几种AlertDialog对话框。

1.弹出一个警告框,并有三个按钮可选择

bubuko.com,布布扣

我们来看看代码部分:

bubuko.com,布布扣

button.setOnClickListener(new OnClickListener()</p><p>        {</p><p>            @Override</p><p>            public void onClick(View v)</p><p>            {</p><p>                //    通过AlertDialog.Builder这个类来实例化我们的一个AlertDialog的对象</p><p>                AlertDialog.Builder builder = new AlertDialog.Builder(MainActivity.this);</p><p>                //    设置Title的图标</p><p>                builder.setIcon(R.drawable.ic_launcher);</p><p>                //    设置Title的内容</p><p>                builder.setTitle("弹出警告框");</p><p>                //    设置Content来显示一个信息</p><p>                builder.setMessage("确定删除吗?");</p><p>                //    设置一个PositiveButton</p><p>                builder.setPositiveButton("确定", new DialogInterface.OnClickListener()</p><p>                {</p><p>                    @Override</p><p>                    public void onClick(DialogInterface dialog, int which)</p><p>                    {</p><p>                        Toast.makeText(MainActivity.this, "positive: " + which, Toast.LENGTH_SHORT).show();</p><p>                    }</p><p>                });</p><p>                //    设置一个NegativeButton</p><p>                builder.setNegativeButton("取消", new DialogInterface.OnClickListener()</p><p>                {</p><p>                    @Override</p><p>                    public void onClick(DialogInterface dialog, int which)</p><p>                    {</p><p>                        Toast.makeText(MainActivity.this, "negative: " + which, Toast.LENGTH_SHORT).show();</p><p>                    }</p><p>                });</p><p>                //    设置一个NeutralButton</p><p>                builder.setNeutralButton("忽略", new DialogInterface.OnClickListener()</p><p>                {</p><p>                    @Override</p><p>                    public void onClick(DialogInterface dialog, int which)</p><p>                    {</p><p>                        Toast.makeText(MainActivity.this, "neutral: " + which, Toast.LENGTH_SHORT).show();</p><p>                    }</p><p>                });</p><p>                //    显示出该对话框</p><p>                builder.show();</p><p>            }</p><p>        });

bubuko.com,布布扣

我们如果要创建一个AlertDialog对话框,需要使用AlertDialog的一个内部类,即AlertDialog.Builder来构建一个AlertDialog的对话框,然后通过setXX方法来设置我们想要显示的内容即可。

我们看到,我们一共设置了3个action buttons,每一个button都为其绑定了一个 DialogInterface.OnClickListener() 的监听事件,然后在里面通过Toast吐司对话框(这个在后面随笔中会讲解)来弹出一下我们的一些信息,which方法表示的是action button所代表的int值:

positive:  -1</p><p>negative:  -2</p><p>neutral:  -3

我们可以知道,which=-1就表示点击的是确定按钮,-2表示点击的是取消按钮,-3表示点击的是忽略按钮。

2.下拉列表弹出框

bubuko.com,布布扣

关键代码如下:

bubuko.com,布布扣

button2.setOnClickListener(new OnClickListener()</p><p>        {</p><p>            @Override</p><p>            public void onClick(View arg0)</p><p>            {</p><p>                AlertDialog.Builder builder = new AlertDialog.Builder(MainActivity.this);</p><p>                builder.setIcon(R.drawable.ic_launcher);</p><p>                builder.setTitle("选择一个城市");</p><p>                //    指定下拉列表的显示数据</p><p>                final String[] cities = {"广州", "上海", "北京", "香港", "澳门"};</p><p>                //    设置一个下拉的列表选择项</p><p>                builder.setItems(cities, new DialogInterface.OnClickListener()</p><p>                {</p><p>                    @Override</p><p>                    public void onClick(DialogInterface dialog, int which)</p><p>                    {</p><p>                        Toast.makeText(MainActivity.this, "选择的城市为:" + cities[which], Toast.LENGTH_SHORT).show();</p><p>                    }</p><p>                });</p><p>                builder.show();</p><p>            }</p><p>        });

bubuko.com,布布扣

在这里我们通过 setItems(CharSequence[] items, DialogInterface.OnClickListener listener) 方法来设置我们的一个下拉列表框。注意:因为下拉列表框或者是下拉多选框这些都是显示在Content中的,所以message和下拉列表框这些是不能够同时存在的

我们也可以给其绑定一个DialogInterface.OnClickListener监听器,当选中一个选项时,对话框就会消失掉。这里的which代表的是下拉列表的每个选项的索引,通过这个我们可以轻松得到用户选中的是哪一个选项。

bubuko.com,布布扣

3.弹出一个下拉单选框

bubuko.com,布布扣

bubuko.com,布布扣

button3.setOnClickListener(new OnClickListener()</p><p>        {</p><p>            @Override</p><p>            public void onClick(View v)</p><p>            {</p><p>                AlertDialog.Builder builder = new AlertDialog.Builder(MainActivity.this);</p><p>                builder.setIcon(R.drawable.ic_launcher);</p><p>                builder.setTitle("请选择性别");</p><p>                final String[] sex = {"男", "女", "未知性别"};</p><p>                //    设置一个单项选择下拉框</p><p>                /**</p><p>                 * 第一个参数指定我们要显示的一组下拉单选框的数据集合</p><p>                 * 第二个参数代表索引,指定默认哪一个单选框被勾选上,1表示默认‘女‘ 会被勾选上</p><p>                 * 第三个参数给每一个单选项绑定一个监听器</p><p>                 */</p><p>                builder.setSingleChoiceItems(sex, 1, new DialogInterface.OnClickListener()</p><p>                {</p><p>                    @Override</p><p>                    public void onClick(DialogInterface dialog, int which)</p><p>                    {</p><p>                        Toast.makeText(MainActivity.this, "性别为:" + sex[which], Toast.LENGTH_SHORT).show();</p><p>                    }</p><p>                });</p><p>                builder.setPositiveButton("确定", new DialogInterface.OnClickListener()</p><p>                {</p><p>                    @Override</p><p>                    public void onClick(DialogInterface dialog, int which)</p><p>                    {</p><p>                        </p><p>                    }</p><p>                });</p><p>                builder.setNegativeButton("取消", new DialogInterface.OnClickListener()</p><p>                {</p><p>                    @Override</p><p>                    public void onClick(DialogInterface dialog, int which)</p><p>                    {</p><p>                        </p><p>                    }</p><p>                });</p><p>                builder.show();</p><p>            }</p><p>        });

bubuko.com,布布扣

注意在弹出下拉单选框时,当我们选中一个选项,对话框是不会消失的,我们需要点击action button才能让对话框消失

bubuko.com,布布扣

4.弹出一个下拉多选框

bubuko.com,布布扣

bubuko.com,布布扣

button4.setOnClickListener(new OnClickListener()</p><p>        {</p><p>            @Override</p><p>            public void onClick(View v)</p><p>            {</p><p>                AlertDialog.Builder builder = new AlertDialog.Builder(MainActivity.this);</p><p>                builder.setIcon(R.drawable.ic_launcher);</p><p>                builder.setTitle("爱好");</p><p>                final String[] hobbies = {"篮球", "足球", "网球", "斯诺克"};</p><p>                //    设置一个单项选择下拉框</p><p>                /**</p><p>                 * 第一个参数指定我们要显示的一组下拉多选框的数据集合</p><p>                 * 第二个参数代表哪几个选项被选择,如果是null,则表示一个都不选择,如果希望指定哪一个多选选项框被选择,</p><p>                 * 需要传递一个boolean[]数组进去,其长度要和第一个参数的长度相同,例如 {true, false, false, true};</p><p>                 * 第三个参数给每一个多选项绑定一个监听器</p><p>                 */</p><p>                builder.setMultiChoiceItems(hobbies, null, new DialogInterface.OnMultiChoiceClickListener()</p><p>                {</p><p>                    StringBuffer sb = new StringBuffer(100);</p><p>                    @Override</p><p>                    public void onClick(DialogInterface dialog, int which, boolean isChecked)</p><p>                    {</p><p>                        if(isChecked)</p><p>                        {</p><p>                            sb.append(hobbies[which] + ", ");</p><p>                        }</p><p>                        Toast.makeText(MainActivity.this, "爱好为:" + sb.toString(), Toast.LENGTH_SHORT).show();</p><p>                    }</p><p>                });</p><p>                builder.setPositiveButton("确定", new DialogInterface.OnClickListener()</p><p>                {</p><p>                    @Override</p><p>                    public void onClick(DialogInterface dialog, int which)</p><p>                    {</p><p>                        </p><p>                    }</p><p>                });</p><p>                builder.setNegativeButton("取消", new DialogInterface.OnClickListener()</p><p>                {</p><p>                    @Override</p><p>                    public void onClick(DialogInterface dialog, int which)</p><p>                    {</p><p>                        </p><p>                    }</p><p>                });</p><p>                builder.show();</p><p>            }</p><p>        });

bubuko.com,布布扣

我们看到在设置下拉多选框时使用的是setMultiChoiceItems方法,其各个参数的含义,在上面代码中已经阐述了。
同样,对于下拉多选框,当我们选中其中一个选项时,对话框是不会消失的,只有点击了action button才会消失

bubuko.com,布布扣

5.自定义弹出对话框

对于自定义弹出对话框,我们就需要自己指定一个自定义的布局文件了,我们就给出一个最简单的输入用户名和密码的两个EditText:

dialog.xml

bubuko.com,布布扣

&lt;?xml version="1.0" encoding="utf-8"?&gt;</p><p>&lt;RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"</p><p>    android:layout_width="match_parent"</p><p>    android:layout_height="match_parent" &gt;</p><p>    </p><p>    &lt;EditText </p><p>        android:id="@+id/username"</p><p>        android:layout_width="match_parent"</p><p>        android:layout_height="wrap_content"</p><p>        android:hint="username"/&gt;</p><p>    </p><p>    &lt;EditText</p><p>        android:id="@+id/password"</p><p>        android:layout_width="match_parent"</p><p>        android:layout_height="wrap_content"</p><p>        android:layout_below="@id/username"</p><p>        android:hint="password"</p><p>        android:inputType="textPassword"/&gt;</p><p>&lt;/RelativeLayout&gt;

bubuko.com,布布扣

bubuko.com,布布扣

关键代码:

bubuko.com,布布扣

button5.setOnClickListener(new OnClickListener()</p><p>        {</p><p>            @Override</p><p>            public void onClick(View v)</p><p>            {</p><p>                AlertDialog.Builder builder = new AlertDialog.Builder(MainActivity.this);</p><p>                builder.setIcon(R.drawable.ic_launcher);</p><p>                builder.setTitle("请输入用户名和密码");</p><p>                //    通过LayoutInflater来加载一个xml的布局文件作为一个View对象</p><p>                View view = LayoutInflater.from(MainActivity.this).inflate(R.layout.dialog, null);</p><p>                //    设置我们自己定义的布局文件作为弹出框的Content</p><p>                builder.setView(view);</p><p>                </p><p>                final EditText username = (EditText)view.findViewById(R.id.username);</p><p>                final EditText password = (EditText)view.findViewById(R.id.password);</p><p>                </p><p>                builder.setPositiveButton("确定", new DialogInterface.OnClickListener()</p><p>                {</p><p>                    @Override</p><p>                    public void onClick(DialogInterface dialog, int which)</p><p>                    {</p><p>                        String a = username.getText().toString().trim();</p><p>                        String b = password.getText().toString().trim();</p><p>                        //    将输入的用户名和密码打印出来</p><p>                        Toast.makeText(MainActivity.this, "用户名: " + a + ", 密码: " + b, Toast.LENGTH_SHORT).show();</p><p>                    } </p><p>                });</p><p>                builder.setNegativeButton("取消", new DialogInterface.OnClickListener()</p><p>                {</p><p>                    @Override</p><p>                    public void onClick(DialogInterface dialog, int which)</p><p>                    {</p><p>                        </p><p>                    }</p><p>                });</p><p>                builder.show();</p><p>            }</p><p>        });

bubuko.com,布布扣

我们看到,通过自定义弹出框,我们首先需要写一个xml的布局文件,然后在里面定义我们的布局,我们不需要在布局文件里定义Button按钮,可以通过 AlertDialog.Builder 来设置 action buttons。

通过 View view = LayoutInflater.from(MainActivity.this).inflate(R.layout.dialog, null); 我们可以将我们的布局文件加载进来,得到一个View对象,然后通过 AlertDialog.Builder 的setView方法来设置我们的自定义弹出框

bubuko.com,布布扣

 

总结:到这里,基本上将AlertDialog详细的讲解完了,本篇随笔主要讲解了Dialog弹出框的基本概念以及详细讲解了AlertDialog这个弹出框,包括定义一个基本的弹出警告框、下拉列表框、下拉多选框等等。后续的随笔将会继续记录学习Android的点点滴滴。

来源URL:http://www.mamicode.com/info-detail-96206.html