代码地址如下:
http://www.demodashi.com/demo/12592.html

通用对话弹窗CommonDialog

Version 1.0

Created by chenchangjun on 18/1/12.

  • 抽离普通基类BaseNormalDialog
  • 优化扩展方式3.1 基本扩展
  • 添加必要注释



项目中,对话框,种类繁多, 难以维护, 有的继承popwindow, 有的继承dialog, 有的继承dialogFragment....而且写法 各不相同.

效果图

调用

//通用弹框 生产类
public class DialogCreator {
/**
* 无标题,单btn弹窗
*
* @param mActivity
* @param msg
* @param strLeft
* @param leftListener
*/
public static BaseDialog showConfirmDialog(Context mActivity, String msg, String strLeft, OnLeftListener leftListener) {
CommonNormalDialog confrimDialog = new CommonNormalDialog(mActivity);
confrimDialog.setDialogType(DialogConfig.TYPE_HAS_NO_HEADER)
.setContent(msg)
.setContentGravity(DialogConfig.TYPE_GRIVITY_CENTER)
.setConfirmBtn(strLeft, leftListener)
.start();
return confrimDialog;
} /**
* 无标题,单btn弹窗
*
* @param mActivity
* @param msg
* @param strLeft
* @param leftListener
*/
public static BaseDialog showTitleConfirmDialog(Context mActivity, String title, String msg, String strLeft, OnLeftListener leftListener) {
CommonNormalDialog confrimDialog = new CommonNormalDialog(mActivity);
confrimDialog.setDialogType(DialogConfig.TYPE_HAS_HEADER)
.setTitle(title)
.setContent(msg)
.setContentGravity(DialogConfig.TYPE_GRIVITY_CENTER)
.setConfirmBtn(strLeft, leftListener)
.start();
return confrimDialog;
}
....
}

思路

1.定义顶级抽象类 BaseDialog,

装饰AlertDialog, 统一dialog样式, 并且用 模板方法模式 进行抽象约束 子类型为.

为了达到 易扩展,代码复用的角度, 将整体dialog,根据 功能区域 布局和加载分为3部分----

  • 头部header: 扩展头部区域,像图片logo头部,带背景,大标题.
  • 中间content: 主内容显示区域,比如输入框,内容详情等等.
  • 底部footer:底部扩展区,主要用来放置 确认按钮等等.

/**
* 子类必须实现该方法用于显示在界面上的Dialog的Title部分
*
* @return title部分的显示的View,返回的titleView为null的话,Dialog将不显示title部分
*/
protected abstract View initHeader(); /**
* 子类必须实现该方法用于显示在界面上的正文部分控件
* @return content部分显示的内容,如果返回null,将会抛出异常
*/
protected abstract View initContent(); /**
* 子类实现该方法用于显示底部的view
*
* @return bottom部分显示的view,如果返回null,bottom部分将不显示
*/
protected abstract View initBottom(); /**
* 模板方法
*/
protected abstract void loadHeader(); protected abstract void loadContent(); protected abstract void loadBottom(); public void start(){
loadHeader();
loadContent();
loadBottom();
};

2. 新建子类,CommonNormalDialog CommonImgHeaderDialog CommonLogoHeaderDialog等

子类 分别对模板方法进行实现, 以CommonNormalDialog为例

/**
* 普通样式无头部
* @return
*/
@Override
protected View initHeader() {
return null;
} /**
* 创建内容布局
* @return 内容布局
*/
@Override
protected View initContent() { View content = View.inflate(context, R.layout.common_dialog_content, null); tv_title = (TextView) content.findViewById(R.id.tv_title);
tv_content = (TextView) content.findViewById(R.id.tv_content); etv_content = (EditText) content.findViewById(R.id.etv_content); v_vertical_line = content.findViewById(R.id.v_vertical_line);
tv_left = (TextView) content.findViewById(R.id.tv_left);
tv_right = (TextView) content.findViewById(R.id.tv_right); iv_cancel = (ImageView) content.findViewById(R.id.iv_content_cancel); iv_cancel.setOnClickListener(this);
return content;
} /**
* 创建 底部 按钮布局
* @return
*/
@Override
protected View initBottom() {
View footer = View.inflate(context, R.layout.common_dialog_footer_btn, null); v_vertical_line = footer.findViewById(R.id.v_vertical_line);
tv_left = (TextView) footer.findViewById(R.id.tv_left);
tv_right = (TextView) footer.findViewById(R.id.tv_right); return footer;

3.扩展

3.1 普通扩展

如果想要 用如下的 弹窗样式. 那么只需要简单几步就可以实现.

3.1.1 学习并继承 NormalBaseDialog,并实现其中的三个抽象方法 即可.

/*************************构造子类的内容布局***********************/ /**
* 构造 实现类 内容布局
* @return
*/
public abstract View createContentView(); /**
* 处理 实现类的 view数据
* @param parents view 的ViewGroup容器
* @param v view本身
*/
public abstract void handleContentView(ViewGroup parents, View v); /**
* 子类view 监听器
* @param v 事件分发 view
*/
public abstract void onContentClick(View v);
3.1.2 举例说明 在app module中, 有MyDialogDialog ,清爽的代码~ .


/**
* 自定义样式
* Created by chenchangjun on 17/10/11.
*/ public class MyDialogDialog extends NormalBaseDialog implements View.OnClickListener { private ImageView card_pic;
private TextView card_price;
private TextView card_title; /**
* 构造 实现类 内容布局
*
* @return
*/
@Override
public View createContentView() {
View myView = View.inflate(context, R.layout.dialog_content_focus_dialog_v1, null); card_pic= (ImageView) myView.findViewById(R.id.card_pic); card_price= (TextView) myView.findViewById(R.id.card_price);
card_title= (TextView) myView.findViewById(R.id.card_title);
card_pic.setOnClickListener(this);
return myView;
} /**
* 处理 实现类的 view数据
*
* @param parents view 的ViewGroup容器
* @param v view本身
*/
@Override
public void handleContentView(ViewGroup parents, View v) {
card_pic.setImageResource(R.mipmap.ic_launcher_round); } /**
* 子类view 监听器
*
* @param v 事件分发 view
*/
@Override
public void onContentClick(View v) { int i = v.getId();
if (i == R.id.card_pic) {
Toast.makeText(context,"hello MyDialog!!!!",Toast.LENGTH_SHORT).show();
}
} public MyDialogDialog setMyView(String st) {
card_title.setText(st);
return this;
} public MyDialogDialog(Context context) {
super(context);
} }

3.2 其他扩展

如果想要扩展, 根据需求相互扩展即可.

比如 CommonImgHeaderDialog 可以选择继承CommonNormalDialog.共用CommonNormalDialog的 内容布局和 底部布局. 所以,只需要加载header布局即可.

/**
* 通用 带头部背景 样式
* Created by chenchangjun on 17/10/11.
*/ public class CommonImgHeaderDialog extends CommonNormalDialog implements View.OnClickListener { private String url_header;
private ImageView iv_header_cancel;
private SimpleDraweeView iv_header; @Override
protected void loadHeader() { if (type== DialogConfig.TYPE_HAS_HEADER){
iv_header.setVisibility(View.VISIBLE);
iv_header_cancel.setVisibility(View.VISIBLE); if (TextUtils.isEmpty(url_header)) {
iv_header.setVisibility(View.GONE);
} else {
//iv_header.setImageURI(url_header);
iv_header.setBackgroundResource(R.drawable.common_dialog_header_bg);
Uri uri = Uri.parse(url_header);
iv_header.setImageURI(uri);
} }
} public CommonImgHeaderDialog setHeaderUrl(String str) {
url_header = str;
return this;
} public CommonImgHeaderDialog(Context context) {
super(context);
} @Override
protected View initHeader() {
View header=null;
if (type==DialogConfig.TYPE_HAS_NO_HEADER){
return null;
}
header = View.inflate(context, R.layout.common_dialog_pic_header, null);
iv_header_cancel = (ImageView) header.findViewById(R.id.iv_header_cancel);
iv_header = (SimpleDraweeView) header.findViewById(R.id.iv_header);
iv_header_cancel.setOnClickListener(this); return header;
} }

4. 后期优化

1.优化为一个组件库 发布到 JCenter来使用

2.兼容更多的样式处理

3.精简lib中依赖的处理第三方库......通用对话弹窗CommonDialog

代码地址如下:
http://www.demodashi.com/demo/12592.html

注:本文著作权归作者,由demo大师代发,拒绝转载,转载需要作者授权

通用对话弹窗CommonDialog的更多相关文章

  1. 项目期复习:JS操作符,弹窗与调试,凝视,数据类型转换

    版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/huangyibin628/article/details/26364901 1.JS操作符 ① 除法 ...

  2. tkinter 基础教程

    目录 介绍 模块 导入方式 API 使用 主窗口 运行窗口 组件列表介绍 Label 标签 Button 按钮 Options 属性选项 文本框 Entry 单行文本框 Text 多行文本框 文本框属 ...

  3. gulp工作流

    小屁活动使用 gulp+less gulpfile.js var gulp = require('gulp'), cssmin = require('gulp-minify-css'), less = ...

  4. JS基础题

    1.三目运算符(三元条件语句)的使用方法? 条件表达式?true表达式:false表达式 2.JS数据中哪些属于引用类型? 数组.对象 引用类型变量,变量名所储存的不是变量值,而是变量所在的地址. 3 ...

  5. 2017-12-22 日语编程语言"抚子"-第三版实现初探

    前文日语编程语言"抚子" - 第三版特色初探仅对语言的语法进行了初步了解. 之前的语言原型实现尝试(如编程语言试验之Antlr4+JavaScript实现"圈4" ...

  6. 网页设计编辑利器——jQuery EasyUI所学整理(待编辑)

    1, Messager弹窗信息 方法: $.messager.alert(...), 在网页中间弹出一个窗口 $.messager.confirm(...) 弹出一个确认窗口, 有确定和取消两个按钮, ...

  7. Teaching Machines to Understand Us 让机器理解我们 之一 引言

    Teaching Machines to Understand Us   By Tom Simonite  MIT Technology Review Vol.118 No.5 2015 让机器理解我 ...

  8. 低于0.01%的极致Crash率是怎么做到的?

    WeTest 导读 看似系统Bug的Crash 99%都不是系统问题!本文将与你一起探索Crash分析的科学方法. 在移动互联网闯荡多年的iOS手机管家,经过不断迭代创新,已经涵盖了隐私(加密相册). ...

  9. PB常用事件

    1.window中的事件 事件名                  触发的时机 01.Activate            在窗口激活之前触发 02.Clicked             当用户用 ...

随机推荐

  1. 【原创】Linux环境下的图形系统和AMD R600显卡编程(3)——AMD显卡简介

    早期的显卡仅用于显示,后来显卡中加入了2D加速部件,这些部件用于做拷屏,画点,画线等操作.随着游戏.三维模拟以及科学计算可视化等需要,对3D的需求逐渐增加,早期图形绘制工作由CPU来完成,要达到真实感 ...

  2. android.useDeprecatedNdk=true

    android.useDeprecatedNdk=true ndk{ moduleName "aa" abiFilter "armeabi-v7a" }

  3. itatis中的数据库配置

    <!--com.microsoft.sqlserver.jdbc.SQLServerDriver --> <property name="JDBC.Driver" ...

  4. jdbc连接警告不安全

    Mon Jun 11 10:46:26 CST 2018 WARN: Establishing SSL connection without server's identity verificatio ...

  5. poj 1389(离散化+计算几何)

    Area of Simple Polygons Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 3412   Accepted ...

  6. CF987C Three displays【一维DP/类似最大子序列和】

    [链接]:CF987C [分析]:先求出每个s[i]后面比s[i]大的c[i]的最小值,然后枚举前两个数c(i),c(j)以及 j 后面递增且存在最小值的dp(j) [代码]: #include< ...

  7. Openjudge1388 Lake Counting【DFS/Flood Fill】

    http://blog.csdn.net/c20182030/article/details/52327948 1388:Lake Counting 总时间限制:   1000ms   内存限制:  ...

  8. UVALive 3027 Corporative Network (带权并查集)

    题意: 有 n 个节点,初始时每个节点的父节点都不存在,你的任务是执行一次 I 操作 和 E 操作,含义如下: I  u  v   :  把节点 u  的父节点设为 v  ,距离为| u - v | ...

  9. 【 模_板 】 for NOIP 2017

    高精度 #include <cstring> #include <cstdio> #define max(a,b) (a>b?a:b) inline void read( ...

  10. Web Api 返回图片流给前端

    public class TestController : ApiController { public HttpResponseMessage GetImg() { //获取文件的绝对路径 stri ...