QMUIDialog
提供了一系列常用的对话框,解决了使用系统默认对话框时在不同 Android 版本上的表现不一致的问题。使用不同的 Builder 来构建不同类型的对话框,这些 Builder 都拥有设置 title 和添加底部按钮的功能,不同的 Builder 特有的作用如下:
1.MessageDialogBuilder: 消息类型的对话框 Builder。通过它可以生成一个带标题、文本消息、按钮的对话框。
2.ConfirmMessageDialogBuilder: 带 Checkbox 的消息确认框 Builder。
3.EditTextDialogBuilder: 带输入框的对话框 Builder。
4.MenuDialogBuilder: 菜单对话框 Builder。
5.CheckableDialogBuilder: 单选类型的对话框 Builder。
6.MultiCheckableDialogBuilder: 多选类型的对话框 Builder。
7.CustomDialogBuilder: 自定义对话框内容区域的 Builder。
8.AutoResizeDialogBuilder: 随键盘升降自动调整 Dialog 高度的 Builder
设计模式和Dialog一样,所以用法也没什么差异
消息类型对话框(蓝色按钮)
/**
* 消息类型对话框(蓝色按钮)
*/
private void showMessagePositiveDialog() {
new QMUIDialog.MessageDialogBuilder(context)
.setMessage("标题")
.setTitle("确认要发送吗?")
.addAction("取消", new QMUIDialogAction.ActionListener() {
@Override
public void onClick(QMUIDialog dialog, int index) {
dialog.dismiss();
}
})
.addAction("确认", new QMUIDialogAction.ActionListener() {
@Override
public void onClick(QMUIDialog dialog, int index) {
dialog.dismiss();
}
})
.create(mCurrentDialogStyle).show();
}
}
菜单类型对话框
/**
* 菜单类型对话框
*/
private void showMenuDialog() {
final String strs []=new String[]{"选项一","选项二","选项三"};
new QMUIDialog.MenuDialogBuilder(context)
.addItems(strs, new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
Toast.makeText(context,"我点第"+"which"+"个",Toast.LENGTH_SHORT).show();
}
}).create(mCurrentDialogStyle).show();
}
带checkbox的消息确认框
/**
* 带checkbox的消息确认框
*/
private void showConfirmMessageDialog() {
new QMUIDialog.CheckBoxMessageDialogBuilder(context)
.setTitle("退出后是否删除账号信息?")
.setMessage("删除账号信息")
.setChecked(true)
.addAction("取消", new QMUIDialogAction.ActionListener() {
@Override
public void onClick(QMUIDialog dialog, int index) {
}
})
.addAction("退出", new QMUIDialogAction.ActionListener() {
@Override
public void onClick(QMUIDialog dialog, int index) {
}
})
.create(mCurrentDialogStyle)
.show();
}
单选类型对话框
/**
* 单选菜单
*/
private void showSingleChoiceDialog() {
final String [] strs=new String[]{"选项一","选项二","选项三"};
final int checkIndex=1;
new QMUIDialog.CheckableDialogBuilder(context)
.addItems(strs, new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
Toast.makeText(context,"选择一"+"which",Toast.LENGTH_SHORT).show();
}
})
.setCheckedIndex(checkIndex)
.create(mCurrentDialogStyle)
.show();
}
多选类型对话框
/**
* 多选菜单
*/
private void showMultiChoiceDialog() {
final String items []=new String[]{"选项1","选项2","选项3","选项4","选项5","选项6","选项7","选项8"};
final QMUIDialog.MultiCheckableDialogBuilder builder = new QMUIDialog.MultiCheckableDialogBuilder(context)
.addItems(items, new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
}
})
.setCheckedItems(new int[]{1, 3});
builder.addAction("取消", new QMUIDialogAction.ActionListener() {
@Override
public void onClick(QMUIDialog dialog, int index) {
}
});
builder.addAction("确定", new QMUIDialogAction.ActionListener() {
@Override
public void onClick(QMUIDialog dialog, int index) {
String result="你选择了";
for(int i=0;i<builder.getCheckedItemIndexes().length;i++){
result+=""+builder.getCheckedItemIndexes()[i]+"";
Toast.makeText(context, result, Toast.LENGTH_SHORT).show();
dialog.dismiss();
}
}
});
builder.create(mCurrentDialogStyle).show();
}
带输入框的对话框
/**
* 带输入框的dialog
*/
private void showEditTextDialog() {
final QMUIDialog.EditTextDialogBuilder builder = new QMUIDialog.EditTextDialogBuilder(context);
builder.setTitle("我是标题");
builder.setPlaceholder("在此输入昵称");
builder.setInputType(InputType.TYPE_CLASS_TEXT);
builder.addAction("取消", new QMUIDialogAction.ActionListener() {
@Override
public void onClick(QMUIDialog dialog, int index) {
}
});
builder.addAction("确定", new QMUIDialogAction.ActionListener() {
@Override
public void onClick(QMUIDialog dialog, int index) {
String inputStr=builder.getEditText().getText().toString();
if(!TextUtils.isEmpty(inputStr)){
Toast.makeText(context,inputStr,Toast.LENGTH_SHORT).show();
dialog.dismiss();
}else{
Toast.makeText(context,"请输入昵称",Toast.LENGTH_SHORT).show();
}
}
});
builder.create(mCurrentDialogStyle).show();
}