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>
|
以上介绍了六种不同对话框的实现方式,希望对大家有所帮助。