现在的位置: 首页 > web前端 > 正文

Android快速开发框架,基础库,样式库,组件化,组件集成

2020年02月12日 web前端 ⁄ 共 1798字 ⁄ 字号 评论关闭
文章目录

概述

快速开发框架,并不是现成的框架。它是一种架构,它集成了基础库,网络库,尺寸颜色主题定义,并提出了一种组件化设计。它更像是一种sdk+架构设计抽象。本文也提供了组件设计规范和集成demo,开发者使用时,还需要做定义工作。

目标

快速接入基础库和组件,大大缩短新应用开发周期。统一开发模式,能带来快速开发,快速维护,功能稳定的体验。

组件化

封装基础库组件,包括基本的架构基础类,activity,dialog,动态权限,沉浸式,工具类等

封装一套design组件,包含规定的多套尺寸,样式,以及主题

按照规范定义功能组件,网络组件,分享组件等

封装组件集成,通过统一入口链接各个组件。

App架构

1 、整体架构图

架构主要是业务模块化,以及通用功能组件化。但不限于此,有需要还能继续分拆,业务模块组件化,插件化,或进程化

模块依赖baselib组件和easyComponent组件

easyComponent组件依赖其他功能组件

 

 模块化组件

2、应用层模块化业务模块使用livedata的架构模式。模块内基本架构:

 

 

final-architecture

livedata基本结构图:

 

 

viewmodel-replace-loader

基本组件介绍

基础库 baselib

包含:1 life-arch,livedata基本封装2 基础SharePerference封装3 环境设置,包括接口环境,debug环境(可控制日志输出)4 基础Activity/Fragment5 dialog, tab, statusbar6 recyclerview快速开发7 viewtools8 动态权限9 工具类10 多任务处理Rxjava11 Eventbus事件总线

网络组件 networklib

OKhttp3+Rxjava2+Retrofit2的解决方案,并设计了6种缓存策略,只读缓存(无视过期时间),自定义缓存时间,读网络,固定缓存1天,读网络并刷新缓存,读缓存同时请求网络并写缓存。

UI尺寸颜色规范库 design_style

包含一组尺寸,颜色规范,可推动设计师们按规范设计。主要目的是撸UI尽量不用思考,提高开发效率和统一的尺寸和颜色体验。

通过重新修改尺寸,颜色值,主题样式即可快速使用。

内容包含:文字size,大中小几种规范;组件外距/内距(margin/padding) 统一只有几种规格;分界线长度,宽度,颜色;文字颜色,主颜色,次要颜色,最次要颜色;activity主题,状态栏,标题栏,背景颜色,光标颜色,问题颜色等等;dialog主题,圆角,边距,底色;

快速访问组件 easyComponent

easyComponent实现了对组件的接入

模块通过easyComponent组件,以责任链的方式调用。如 Easys.network().api().getUser(observer)

组件设计规范

应包含:1、尽量减少对其他组件的依赖2、组件初始化过程(比如设置Application)3、调用组件的过程4、生命周期管理

集成步骤

下载源码demohttps://github.com/superroye/lefastdev

基础库组件使用基础库收录了大部分常用功能,后续继续完善。

 

基础库组件

定义组件按上述组件规范,定义新组件。以networklib为例,见源码。

补充easycomponent集成新组件的实现,源码有相关demo,使用责任链的设计模式。以网络库为例,见:

 

 

网路库的builder外观接口

接入网络库实现

网络库调用入口

重新设置design_style组件主题,尺寸,颜色,需要定义成适合本应用的一套样式。修改colors.xml文件:

colors.xml

修改dimens.xml文件:

dimens.xml

测试组件调用,并开始你的开发之旅。初始化Application:

初始化Application

你的app工程依赖:

组件依赖

调用网络组件(初始化,和调用):

初始化和调用api过程

 

提供一份安卓学习思维导图及架构视频资料,需要的关注+加群:185873940 免费获取!

学习思维导图

 

 

 高阶安卓视频资料

 

 想获取更多免费高阶安卓资料吗?想提升自己的技术吗?关注+加群:185873940 免费获取!

以上就上有关Android快速开发框架,基础库,样式库,组件化,组件集成的全部内容,学步园全面介绍编程技术、操作系统、数据库、web前端技术等内容。

抱歉!评论已关闭.