app中肯定是少不了与用户交互的各种dialog,下面给大家介绍几种提示框的提示。
一般创建一个对话框需要经过以下几步:
1、创建alertdialog.builder对象。
2、调用alertdialog.builder的settitle()或者setcustomtitle()方法设置标题。
3、调用alertdialog.builder的seticon()方法设置标题logo。
4、调用alertdialog.builder的相关方法设置对话框内容。
5、调用alertdialog.builder的setpositivebutton()、setnegativebutton()或setneutralbutton()方法添加多个按钮。
6、调用alertdialog.builder的create()方法创建alertdialog对象,再调用alertdialog对象的show()方法将该对话框显示出来。
其中,第4步设置对话框的内容,这里有6种方法来指定:
·setmessage():设置对话框内容为简单文本内容。
·setitems():设置对话框内容为简单列表项。
·setsinglechoiceitems():设置对话框内容为单选列表项。
·setmultichoiceitems():设置对话框内容为多选列表项。
·setadapter():设置对话框内容为自定义列表项。
·setview():设置对话框内容为自定义view。
下面通过几个实例来介绍一下alertdialog的用法。
1、显示提示消息的对话框。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
/** * 显示提示消息的对话框 * @author codingblock -- * @param context 上下文 * @param title 对话框标题 * @param message 对话框提示内容 * @return */ public alertdialog.builder simpledialog( final context context, string title, string message){ alertdialog.builder builder = new alertdialog.builder(context) .settitle(title) .seticon(r.drawable.ic_launcher) .setmessage(message) .setpositivebutton( "完成" , null ) .setnegativebutton( "取消" , null ); return builder; } |
上面的代码是将一个简单提示对话框封装成了一个方法,调用时可以省去重复代码,直接传递title,message等参数即可,其中该对话框用设置了icon,title等属性,还调用了setpositivebutton()和setnegativebutton()方法添加按钮,因为该方法(simpledialog())在这里仅提供调用,所以没有实现按钮的具体功能,可在实际调用中重写这两个方法从而实现具体功能。
调用方式如下,其他几种方式的对话框与此方法调用方式基本一致,以下就不再一一给出。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
public void onclicksimple(view v){ builder = new dialog().simpledialog( this , "简单对话框" , "对话框内容" ); builder.setpositivebutton( "确定" , new onclicklistener() { @override public void onclick(dialoginterface arg, int arg) { //确定 } }) .setnegativebutton( "取消" , new onclicklistener() { @override public void onclick(dialoginterface arg, int arg) { //取消 } }); builder.create().show(); } |
除此之外,alertdialog.builder还提供了setneutralbutton()方法来添加一个装饰性的按钮。因此android的对话一共可以生成三个按钮的对话框。
2、简单列表项对话框
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
/** * 简单列表项对话框 * @author codingblock -- * @param context 上下文 * @param title 对话框标题 * @param items 对话框列表项charsequence类型数组,也可根据需要改成其他类型 * @return */ public alertdialog.builder simplelistdialog( final context context, string title, final charsequence[] items){ alertdialog.builder builder = new alertdialog.builder(context) .settitle(title) .seticon(r.drawable.ic_launcher) .setitems(items, new onclicklistener() { @override public void onclick(dialoginterface dialog, int which) { toast.maketext(context, "您选中了:" + items[which], toast.length_short).show(); } }); return builder; } |
上面的代码通过调用setitems()方法为对话框设置了多个列表项,其中setitems的第一个参数可以是charsequence和int类型。
3、单选列表项对话框
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
/** * 单选列表项对话框 * @author codingblock -- * @param context 上下文 * @param title 对话框标题 * @param items 对话框列表项 charsequence类型数组 * @return */ public alertdialog.builder simplechoicedialog( final context context, string title, final charsequence[] items){ alertdialog.builder builder = new alertdialog.builder(context) .settitle(title) .seticon(r.drawable.ic_launcher) //第二个参数为默认选中项, :代表默认选中第一项 .setsinglechoiceitems(items, , new onclicklistener() { @override public void onclick(dialoginterface dialog, int which) { toast.maketext(context, "您选中了:" + items[which], toast.length_short).show(); } }); return builder; } |
以上代码通过调用setsinglechoiceitems()方法创建了带单选列表的对话框。调用setsinglechoiceitems()方法时既可传入数组作为参数,也可传入cursor(相当于数据库查询结果集)作为参数,也可传入listadapter作为参数。另外,如果传入listadapter作为参数,则由listadapter来提供多个列表项组件。
4、多选列表对话框
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
/** * 多选列表项对话框 * @author codingblock -- * @param context 上下文 * @param title 对话框标题 * @param items 对话框列表项 charsequence类型数组 * @param checked 对话框初始选定状态 boolean类型数组 * @return */ public alertdialog.builder multichoicedialog( final context context, string title, final charsequence[] items, final boolean [] checked){ alertdialog.builder builder = new alertdialog.builder(context) .settitle(title) .seticon(r.drawable.ic_launcher) //第二个参数为默认选中项,是一个boolean型的数组 .setmultichoiceitems(items, checked, null ) .setpositivebutton( "完成" , null ) .setnegativebutton( "取消" , null ); return builder; } |
以上代码通过调用setmultichoiceitems()方法创建了一个多选列表的对话框。在调用setmultichoiceitems()时既可传入数组作为参数,也可传入cursor作为参数。需要注意的时在调用setmultichoiceitems()方法添加多选列表时,还需要传入一个boolean[]参数,该参数有两个作用:①设置初始化时选中哪些列表项。②该boolean[]类型的参数还可用于动态的获取多选列表项的选中状态。
5、自定义列表项对话框
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
/** * 自定义列表项对话框 * @author codingblock -- * @param context 上下文 * @param title 对话框标题 * @param items 对话框列表项 string类型数组,也可更具需要改成其他类型 * @return */ public alertdialog.builder customlistdialog( final context context, string title, string[] items){ alertdialog.builder builder = new alertdialog.builder(context) .settitle(title) .seticon(r.drawable.ic_launcher) .setadapter( new arrayadapter<string>(context, r.layout.array_item, r.id.tv_item, items), null ) .setpositivebutton( "完成" , null ) .setnegativebutton( "取消" , null ); return builder; } |
以上代码通过setadapter()设置了对话框的内容,该方法需要传入一个adapter参数,这样的话,就可以通过adapter实现多个组件的绘制。其中setadapter方法中调用的布局文件array_item.xml代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
<linearlayout xmlns:android= "http://schemas.android.com/apk/res/android" xmlns:tools= "http://schemas.android.com/tools" android:id= "@+id/container" android:layout_width= "match_parent" android:layout_height= "match_parent" android:gravity= "center" android:padding= "dp" android:orientation= "horizontal" > <imageview android:id= "@+id/iv_img" android:layout_width= "dp" android:layout_height= "dp" android:src= "@drawable/ic_launcher" /> <textview android:id= "@+id/tv_item" android:layout_width= "fill_parent" android:layout_height= "wrap_content" android:layout_margin= "dp" android:gravity= "center" android:text= "列表项" /> </linearlayout> |
其实,不仅setadapter()方法可以接受adapter作为参数,setsinglechoice()方法也可以接受adapter参数,也就是说,使用setsinglechoice()方法也可以实现自定义列表项对话框。
6、自定义view的对话框
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
/** * 自定义view的对话框 * @author codingblock -- * @param context 上下文 * @param title 对话框标题 */ public alertdialog.builder customeviewdialog( final context context, string title){ linearlayout logindialog = (linearlayout)layoutinflater.from(context).inflate(r.layout.login_dialog, null ); alertdialog.builder builder = new alertdialog.builder(context) .settitle(title) .seticon(r.drawable.ic_launcher) .setview(logindialog) .setpositivebutton( "完成" , null ) .setnegativebutton( "取消" , null ); return builder; } |
以上代码通过setview()方法调用自定义的布局文件显示界面。代码中首先显示装载了login_dialog.xml文件,并返回该文件对应的view,接下来程序调用了setview()方法来显示view。
其中的login_dialog.xml文件代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
|
<linearlayout xmlns:android= "http://schemas.android.com/apk/res/android" xmlns:tools= "http://schemas.android.com/tools" android:id= "@+id/container" android:layout_width= "match_parent" android:layout_height= "match_parent" android:padding= "dp" android:orientation= "vertical" > <linearlayout android:layout_width= "fill_parent" android:layout_height= "wrap_content" android:orientation= "horizontal" > <textview android:id= "@+id/tv_name" android:layout_width= "wrap_content" android:layout_height= "wrap_content" android:text= "用户名:" /> <edittext android:id= "@+id/et_name" android:layout_width= "match_parent" android:layout_height= "wrap_content" android:focusable= "true" android:hint= "input name" /> </linearlayout> <linearlayout android:layout_width= "fill_parent" android:layout_height= "wrap_content" android:orientation= "horizontal" > <textview android:id= "@+id/tv_pwd" android:layout_width= "wrap_content" android:layout_height= "wrap_content" android:text= "密码:" /> <edittext android:id= "@+id/et_pwd" android:layout_width= "match_parent" android:layout_height= "wrap_content" android:hint= "input password" /> </linearlayout> </linearlayout> |
以上介绍了六种不同对话框的实现方式,希望对大家有所帮助。