如何实现接口统一入口_网易考拉Android App如何实现统一弹框
摘要
在快速开发的背景下,经历了n个版本后的考拉Android App中已经存在了各种各样看似相同却各有差别的弹框样式。其中包括系统弹框和自定义弹框,并且在线上时常会出现IllegalArgumentException的异常,而现有的解决方法是通过工具类来保护调用show和dismiss方法,这种方式效率不高,而且覆盖不全,开发过程中容易遗漏。另外现有的Builder方式的弹框构造工具虽然功能强大,能构造各种弹框,但是使用复杂,样式逻辑耦合,使用成本太高。于是,便需要一款样式统一、show和dismiss安全、调用简单、构造方便的统一弹框工具。
目标
- 统一弹框的交互样式
- show和dismiss方法安全
- 样式与逻辑解耦,使用者不必关心弹框样式,只需要完成自己的续逻辑即可
- 使用简单,一个接口即可获得所需样式
- 扩展性,可支持展示特别样式弹框
怎么做?
既然有了特定的目标,那么就要开始弹框的设计了。弹框通过工厂模式设计生产,使用者通过CommonDialogFactory提供的接口,可以直接生产CommonDialog类、KaolaCommonDialog类、KaolaBottomCloseDialog类三种弹框,其中CommonDialog是为了兼容旧逻辑保留的旧的弹框样式,KaolaCommonDialog是新设计统一了样式的弹框类,但是两者在样式上没有很大的区别,KaolaBottomCloseDialog是一种底部关闭的弹框样式。
0、保留CommonDialog的旧的构建方式。
考虑到旧的弹框中有不少弹框的业务逻辑与旧的Builder工具样式有耦合,为了保证业务逻辑不受影响,我保留了以前的Builder方式构造弹框的设计,并且对其进行了接口化封装。这样可以降低构造弹框的成本。
1、整理目前项目中用到的弹框的样式
由于不熟悉别的模块中弹框到底有哪些样式,所以需要整理目前项目中所有用到的弹框样式。统计结果发现大部分弹框使用的是系统弹框,而自定义弹框中不少样式已经不再使用,但是在旧的构造工具中依然存在,由于逻辑耦合,后期维护相对麻烦,这也验证了我们统一弹框组件的必要性。
2、慢慢从DialogManager里面把样式抽出来,形成基本样式
从旧的弹框管理类DialogManager中,将现在正在使用的弹框抽离出来,在弹框工厂CommonDialogFactory中封装成单独的接口以提供使用。也可以根据整理的接口,形成一套基本的弹框样式,这样在后面做样式统一的时候就可以参考着现有的样式去做了。
3、具体弹框样式形成文档维护在wiki上(提供使用帮助)
那么为了更方便地使用和维护统一弹框组件,使用文档是必不可少的。把现有的弹框样式总结在wiki文档中,对于现有可用的弹框样式也是一目了然;还可以根据文档中提供的案例进行调用开发,降低成本。
4、样式全部抽出来之后,那就按照统一的交互进行修正
由于目前没有视觉提供的统一样式,所以我们基于第2点钟抽离出来的基本样式,按照这些样式来做构建的统一。然后再按照后续设计提供的统一交互规范进行进一步的修正,慢慢做到样式也统一,最后真正实现弹框的完全统一
样式
下图中可以看到弹框类的继承关系:
KaolaBaseDialog中实现了安全的show和dismiss方法:
@Overridepublic void show() { if (!checkAllow()) { return; } // 防止check无效 try { super.show(); } catch (Exception e) { e.printStackTrace(); }}@Overridepublic void dismiss() { if (mOnDismissListener != null) { mOnDismissListener.onDismiss(mDismissType); } if (!checkAllow()) { return; } try { super.dismiss(); } catch (Exception e) { e.printStackTrace(); }}/*** 检查环境是否允许** @return*/private boolean checkAllow() { Context context = this.getContext(); if (context instanceof Lifeful) { Lifeful lifeful = (Lifeful) context; if (!lifeful.isAlive()) { return false; } } else if (context instanceof Activity) { if (!ActivityUtils.activityIsAlive(context)) { return false; } } return true;}
KaolaCommonDialog是通用样式类:
KaolaBottomDialog是底部弹出浮层:
KaolaBottomConfirmDialog是底部确认浮层:
KaolaBottomCloseDialog是底部带关闭弹框:
ExpectPickUpTimeDialog是时间选择器浮层:
通用弹框的文案也支持SpannableString的多样展示;另外可以看到KaolaBaseDialog可以使用在各种情况下,不仅仅是通用弹框,还可以是一些通用组件比如ExpectPickUpTimeDialog时间选择器(不过这里做成了与取件业务相关的组件)。
怎么用?
KaolaCommonDialog的使用
直接调用CommonDialogFactory提供的createOneOrTwoButtonsCustomView接口,该接口可以提供标题、文案、自定义view、通用按钮的展示,使用者可以通过wiki文档或者直接查看接口注释了解接口内容。
/*** 一个标题,一个文案,一个view,一个白底红字negative(left)按钮,一个红底白字positive(right)按钮** @param context* @param title 标题,传空不带标题* @param message 提示文案* @param view 自定义区域需要添加的view* @param leftBtn 左边按钮的内容(传空不显示按钮)* @param rightBtn 右边按钮的内容(传空不显示按钮)* @return KaolaCommonDialog*/public KaolaCommonDialog createOneOrTwoButtonsWithCustomView(Context context, String title, CharSequence message, View view, String leftBtn, String rightBtn) { ... }KaolaCommonDialog dialog = CommonDialogFactory.getInstance() .createOneOrTwoButtonsWithCustomView(this, "标题
如何实现接口统一入口_网易考拉Android App如何实现统一弹框相关推荐
- 非静默授权没有弹出弹框_网易考拉Android统一弹框
作者:钱成杰 链接:https://blog.csdn.net/jessicaiu/article/details/82739334 背景 在快速开发的背景下,经历了n个版本后的考拉Android A ...
- java路由总线_网易考拉Android客户端路由总线设计
1.前言 $ e7 | ~% L) i7 @7 B& t3 T5 h* P/ e2 s 当前,Android路由框架已经有很多了,如雨后春笋般出现,大概是因为去年提出了Android组件化的 ...
- 网易考拉Android客户端网络模块设计
本文来自网易云社区 作者:王鲁才 客户端开发中不可避免的需要接触到访问网络的需求,如何把访问网络模块设计的更具有扩展性是每一个移动开发者不得不面对的事情.现在有很多主流的网络请求处理框架,如Squar ...
- 网易考拉Android客户端路由总线设计
1.前言 当前,Android路由框架已经有很多了,如雨后春笋般出现,大概是因为去年提出了Android组件化的概念.当一个产品的业务规模上升到一定程度,或者是跨团队开发时,团队/模块间的合作问题就会 ...
- 网易考拉Android客户端路由总线设计 1
1.前言 当前,Android路由框架已经有很多了,如雨后春笋般出现,大概是因为去年提出了Android组件化的概念.当一个产品的业务规模上升到一定程度,或者是跨团队开发时,团队/模块间的合作问题就会 ...
- c语言安徽省考试成绩查询,2021安徽省考报名入口_安徽省考成绩查询
原标题:2021安徽省考报名入口_安徽省考成绩查询 安徽人事考试网:2021安徽公务员考试成绩已发布!华图教育同步开通2021年安徽公务员考试成绩查询入口,希望对广大考生有所帮助!更多公务员面试备考等 ...
- 小红书竞品分析_小红书与网易考拉海购竞品分析报告
近几年来,国内电商在政策利好形势下纷纷兴起,经过数轮洗牌,已然处于相对稳定的局面.有天猫国际.网易考拉海购.京东全球购等依靠大型集团公司的综合性跨境电商平台,也有小红书.唯品会等在激烈竞争中生存下来的 ...
- 小红书竞品分析_跨境电商APP竞品分析:小红书、网易考拉和达令
本文作者选取跨境电商中发展较为不错的三款APP(红书.网易考拉和达令APP)进行了分析,指出了各自的不足,且提出了自己的建议.作为彼此的竞品,三款软件的侧重点不同,值得一阅. 入选条件 小红书海外购物 ...
- 数据采集时总提示未登录_做电商必须学会这一招!教你用爬虫工具免费采集网易考拉商品数据...
本文主要介绍如何使用后羿采集器的智能模式,免费采集网易考拉商品的价格.累计评价.商品图片等信息. 采集工具简介: 后羿采集器是一款基于人工智能技术的网络爬虫软件,只需要输入网址就能够自动识别网页数据, ...
最新文章
- TCP/IP协议三次握手与四次握手流程解析
- 关于libStagefright系列漏洞分析
- 凸集+非凸集+凸函数+非凸函数
- MATLAB从入门到精通-如何在MATLAB中实现各种特殊上标?
- 解决GitLab中使用SSH的git clone总是提示输入密码且任何密码都不对
- emr系统 php,完整电子病历系统c#源码
- centos7安装gitlab_Docker常用镜像安装:MySql Redis GitLab maven私服等
- uva 11997(优先队列)
- SpringMVC 理论与有用技术(一) 简单、有用、易懂的几个实例
- RHEL 5.7 Yum配置本地源[Errno 2] No such file or directory
- javaaop模式供其他项目调用_结构性模型-静态代理模式
- 金蝶K3WISE V14.0注册方法
- 如何去除html的flash,去除网站Flash动画效果,提升seo优化友好度
- 谷歌浏览器xp32位_如何正确的配置系统的浏览器系列篇(五)——合同管理系统...
- 计算机excel操作知识点汇总,【计算机二级之Excel】考点汇总
- Ubuntu 16.04安装32bit支持
- Win7/8双系统共用蓝牙鼠标
- XML是什么?有什么用?
- 35岁程序员,早到的中年危机
- cmd命令打开及切换目录路径