Android之Material Dialogs详解
文章大纲
一、什么是Material Dialogs
二、Material Dialogs实战
三、项目源码下载

一、什么是Material Dialogs
Material Dialogs是一个漂亮、流畅、可定制的对话框,核心模块包含创建基本、列表、单/多选项、进度、输入等对话框。
二、Material Dialogs实战
使用注意点:
(1)使用MaterialDialog的Activity需要继承AppCompat
(2)默认的MaterialDialog在点击空白位置时候会自动关闭弹出框,取消dialog以外的区域的点击事件代码如下
//取消dialog以外的区域的点击事件(默认为true)这里我们设置成false就ok啦
.canceledOnTouchOutside(false)
1. 添加依赖
//添加material-dialogs依赖
//核心模块的依赖
implementation 'com.afollestad.material-dialogs:core:0.9.1.0'
//公共模块的依赖
//公共模块包含不是每个人都需要的扩展库。 这包括 ColorChooserDialog、FolderChooserDialog、Material Preference 类和 MaterialSimpleListAdapter / MaterialSimpleListItem
implementation 'com.afollestad.material-dialogs:commons:0.9.1.0'
2. 创建基本弹框
new MaterialDialog.Builder(MainActivity.this)
.title("标题")
.content("内容")
.positiveText("确认")
.negativeText("取消")
.show();
运行结果如下:

温馨提示:取消弹框采用dialog.dismiss();
3. 创建带图标弹框(包含两个按钮)
new MaterialDialog.Builder(MainActivity.this)
.title("标题")
.content("内容;测试长度测试长度测试长度测试长度测试长度测试长度测试长度测试长度测试长度测试长度测试长度测试长度测试长度测试长度测试长度测试长度测试长度测试长度")
.positiveText("确认")
.negativeText("取消")
.icon(getResources().getDrawable(R.drawable.ic_launcher))
.show();
运行结果如下:

温馨提示:可以用maxIconSize(int size)限制图标最大size
4. 创建带三个按钮弹框
new MaterialDialog.Builder(MainActivity.this)
.title("标题")
.content("内容")
.positiveText("确认")
.negativeText("取消")
.neutralText("更多")
.show();
运行结果如下:

5. 创建带点击事件的弹出框
//如果你想监听三种动作按钮,只用一个onAny就行了,which会告诉你点击了什么按钮,根据需要去判断,which.toString()的名字分别是Positive,Negative等
//new MaterialDialog.Builder(this)
// .title("标题")
// .content("内容")
// .positiveText("确认")
// .negativeText("取消")
// .neutralText("更多")
// .onAny(new MaterialDialog.SingleButtonCallback() {
// @Override
// public void onClick(MaterialDialog dialog, DialogAction which) {
// Toast.makeText(MainActivity.this, which.toString(), Toast.LENGTH_SHORT).show();
// }
// })
// .show();
click_button = (Button)findViewById(R.id.click_button);
click_button.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
new MaterialDialog.Builder(MainActivity.this)
.title("标题")
.content("内容")
.positiveText("确认")
.negativeText("取消")
.neutralText("更多")
.onPositive(new MaterialDialog.SingleButtonCallback() {
@Override
public void onClick(MaterialDialog dialog, DialogAction which) {
Toast.makeText(MainActivity.this, "点击了确认按钮", Toast.LENGTH_SHORT).show();
}
})
.onNeutral(new MaterialDialog.SingleButtonCallback() {
@Override
public void onClick(MaterialDialog dialog, DialogAction which) {
Toast.makeText(MainActivity.this, "点击了更多按钮", Toast.LENGTH_SHORT).show();
}
})
.onNegative(new MaterialDialog.SingleButtonCallback() {
@Override
public void onClick(MaterialDialog dialog, DialogAction which) {
Toast.makeText(MainActivity.this, "点击了取消按钮", Toast.LENGTH_SHORT).show();
}
})
.show();
}
});
运行结果如下:


6. 创建是否不再询问弹出框
new MaterialDialog.Builder(MainActivity.this)
.title("标题")
.content("内容")
.positiveText("确认")
//第二次参数代表初始状态是否为勾选
.checkBoxPromptRes(R.string.isShowAgain, true, null)
.onAny(new MaterialDialog.SingleButtonCallback() {
@Override
public void onClick(MaterialDialog dialog, DialogAction which) {
//dialog.isPromptCheckBoxChecked()+""如果返回true,表示用户勾选了,false表示没有
Toast.makeText(MainActivity.this, dialog.isPromptCheckBoxChecked()+"", Toast.LENGTH_SHORT).show();
}
})
.show();
运行结果如下:

7. 创建不带样式列表单选框
final String[] array = {"aa","bb"};
new MaterialDialog.Builder(MainActivity.this)
.title("标题")
.positiveText("确认")
.negativeText("取消")
.items(array)
.itemsCallback(new MaterialDialog.ListCallback() {
@Override
public void onSelection(MaterialDialog dialog, View view, int which, CharSequence text) {
Toast.makeText(MainActivity.this, which+"", Toast.LENGTH_SHORT).show();
}
})
.show();
运行结果如下:

8. 创建带样式的列表单选框
new MaterialDialog.Builder(MainActivity.this)
.title("标题")
.items(array)
.itemsCallbackSingleChoice(-1, new MaterialDialog.ListCallbackSingleChoice() {
@Override
public boolean onSelection(MaterialDialog dialog, View view, int which, CharSequence text) {
return true;
}
})
.show();
运行结果如下:

9. 创建多选列表
new MaterialDialog.Builder(MainActivity.this)
.title("标题")
.positiveText("确认")
.items(array)
.itemsCallbackMultiChoice(null, new MaterialDialog.ListCallbackMultiChoice() {
@Override
public boolean onSelection(MaterialDialog dialog, Integer[] which, CharSequence[] text) {
return true;
}
})
.show();
运行结果如下:

10. 创建自定义视图
new MaterialDialog.Builder(MainActivity.this)
.title("Title")
.customView(R.layout.activity_main, true)
.positiveText("CHOOSE")
.show();
运行结果如下:

11.创建带限制的输入框
new MaterialDialog.Builder(MainActivity.this)
.title("Title")
//限制输入的长度
.inputRangeRes(2, 20, R.color.colorPrimary)
//限制输入类型
.inputType(InputType.TYPE_CLASS_PHONE)
.input("哈哈哈", null, new MaterialDialog.InputCallback() {
@Override
public void onInput(MaterialDialog dialog, CharSequence input) {
Toast.makeText(MainActivity.this, input, Toast.LENGTH_SHORT).show();
}
})
.positiveText("确定")
.show();
运行结果如下:

12. 创建等待提示框(圆圈加载)
new MaterialDialog.Builder(MainActivity.this)
.title("提示框")
.content("请稍等...")
.progress(true, 0)
.show();
运行结果如下:

13. 创建等待提示框(水平加载)
new MaterialDialog.Builder(MainActivity.this)
.title("提示框")
.content("请稍等...")
.progress(true, 0)
.progressIndeterminateStyle(true)
.show();
运行结果如下:

14. 创建带进度条的等待框
new MaterialDialog.Builder(MainActivity.this).title("Progress").content("please wait...").contentGravity(GravityEnum.CENTER).progress(false, 100, true).cancelListener(dialog -> {
if (thread != null) {
thread.interrupt();
}
}).showListener(dialogInterface -> {
final MaterialDialog dialog = (MaterialDialog) dialogInterface;
startThread(() -> {
while (dialog.getCurrentProgress() != dialog.getMaxProgress() && !Thread.currentThread().isInterrupted()) {
if (dialog.isCancelled()) {
break;
}
try {
Thread.sleep(50);
} catch (InterruptedException e) {
break;
}
dialog.incrementProgress(1);
}
runOnUiThread(() -> {
thread = null;
dialog.setContent(getString(R.string.md_done_label));
});
});
}).show();
运行结果如下:


15.其他功能
(1)MaterialDialog可以通过以下方式设置颜色
// .titleColorRes(R.color.material_red_500)
// .contentColor(Color.WHITE) // notice no 'res' postfix for literal color
// .linkColorAttr(R.attr.my_link_color_attr) // notice attr is used instead of none or res for attribute resolving
// .dividerColorRes(R.color.material_pink_500)
// .backgroundColorRes(R.color.material_blue_grey_800)
// .positiveColorRes(R.color.material_red_500)
// .neutralColorRes(R.color.material_red_500)
// .negativeColorRes(R.color.material_red_500)
// .widgetColorRes(R.color.material_red_500)
// .buttonRippleColorRes(R.color.material_red_500)
(2)通过以下方式设置MaterialDialog主题
.theme(Theme.DARK)
(3)设置文字、按钮等内容的位置
.titleGravity(GravityEnum.CENTER)
.contentGravity(GravityEnum.CENTER)
.btnStackedGravity(GravityEnum.START)
.itemsGravity(GravityEnum.END)
.buttonsGravity(GravityEnum.END)
(4)改变drawable被点击或聚焦时的状态
.btnSelector(R.drawable.custom_btn_selector)
.btnSelector(R.drawable.custom_btn_selector_primary, DialogAction.POSITIVE)
.btnSelectorStacked(R.drawable.custom_btn_selector_stacked)
.listSelector(R.drawable.custom_list_and_stackedbtn_selector)!
三、项目源码下载
链接:https://pan.baidu.com/s/1dJFaw1xfvaOiI8XGPwwaRg
密码:sfd8
Android之Material Dialogs详解的更多相关文章
- ANDROID L——Material Design详解(UI控件)
转载请注明本文出自大苞米的博客(http://blog.csdn.net/a396901990),谢谢支持! Android L: Google已经确认Android L就是Android Lolli ...
- [转]ANDROID L——Material Design详解(动画篇)
转载请注明本文出自大苞米的博客(http://blog.csdn.net/a396901990),谢谢支持! 转自:http://blog.csdn.net/a396901990/article/de ...
- 转:android Support 兼容包详解
本文转自stormzhang的ANDROID SUPPORT兼容包详解 背景 来自于知乎上邀请回答的一个问题Android中AppCompat和Holo的一个问题?, 看来很多人还是对这些兼容包搞不清 ...
- 《Android NFC 开发实战详解 》简介+源码+样章+勘误ING
<Android NFC 开发实战详解>简介+源码+样章+勘误ING SkySeraph Mar. 14th 2014 Email:skyseraph00@163.com 更多精彩请直接 ...
- Android开发之InstanceState详解
Android开发之InstanceState详解 本文介绍Android中关于Activity的两个神秘方法:onSaveInstanceState() 和 onRestoreInstanceS ...
- android bundle存放数据详解
转载自:android bundle存放数据详解 正如大家所知道,Activity之间传递数据,是将数据存放在Intent或者Bundle中 例如: 将数据存放倒Intent中传递: 将数据放到Bun ...
- Cordova 打包 Android release app 过程详解
Cordova 打包 Android release app 过程详解 时间 -- :: SegmentFault 原文 https://segmentfault.com/a/119000000517 ...
- Android中Service(服务)详解
http://blog.csdn.net/ryantang03/article/details/7770939 Android中Service(服务)详解 标签: serviceandroidappl ...
- 给 Android 开发者的 RxJava 详解
我从去年开始使用 RxJava ,到现在一年多了.今年加入了 Flipboard 后,看到 Flipboard 的 Android 项目也在使用 RxJava ,并且使用的场景越来越多 .而最近这几个 ...
随机推荐
- Vue 实现网易云音乐 WebApp
- nohup在linux中的挂起
笔者也是一个linux新手,最近在学习linux相关的东西,本人是一个node爱好者,想在linux上写一个linux服务,我的环境是centeros7,用putty链接远端的服务器,要想让服务在服务 ...
- sniffer 软件的使用方法
一.捕获数据包前的准备工作 在默认情况下,sniffer将捕获其接入碰撞域中流经的所有数据包,但在某些场景下,有些数据包可能不是我们所需要的,为了快速定位网络问题所在,有必要对所要捕获的数据包作过滤. ...
- 使用EHCache需要注意的几个问题(转)
最近做一个小项目,需要对一批数据进行缓存,且要求持久化到磁盘.使用ehcache非常简单和直观,一般来说只需要配置ehcache.xml文件,接着直接使用@Cacheable, @Cacheput, ...
- 跟我学ASP.NET MVC之四:使用Razor
摘要: 视图引擎处理ASP.NET内容,并查找指令,典型情况是向浏览器输出插入动态内容.MVC框架视图引擎的名字是Razor. 在本文中,我将带领读者快速认识Razor,以后你们看到他们的时候能够认识 ...
- 再谈DOMContentLoaded与渲染阻塞—分析html页面事件与资源加载
浏览器的多线程中,有的线程负责加载资源,有的线程负责执行脚本,有的线程负责渲染界面,有的线程负责轮询.监听用户事件. 这些线程,根据浏览器自身特点以及web标准等等,有的会被浏览器特意的阻塞.两个很明 ...
- random.nextInt()与Math.random()基础用法
相关文章:关于Random(47)与randon.nextInt(100)的区别 1.来源 random.nextInt() 为 java.util.Random类中的方法: Random类中还提供各 ...
- vector作为函数返回值
在实际的操作中,我们经常会碰到需要返回一序列字符串或者一列数字的时候,以前会用到数组来保存这列的字符串或者数字,现在我们可以用vector来保存这些数据.但是当数据量很大的时候使用vector效率就比 ...
- 【NOIP2011】 聪明的质监员
小 T 是一名质量监督员,最近负责检验一批矿产的质量.这批矿产共有n个矿石,从 1 到n逐一编号,每个矿石都有自己的重量wi以及价值vi.检验矿产的流程是: 1. 给定 m个区间[Li,Ri]: 2. ...
- BZOJ_2792_[Poi2012]Well_二分答案
BZOJ_2792_[Poi2012]Well_二分答案 Description 给出n个正整数X1,X2,...Xn,可以进行不超过m次操作,每次操作选择一个非零的Xi,并将它减一. 最终要求存在某 ...