在android开发中,我们常常需要搭建自己的应用框架,以便于快速、高效的进行项目开发。但对于初学者而言,android应用框架到底应该怎么搭建,搭建的步骤是什么,搭建过程中需要注意些什么呢?可能大家在日常学习、工作中,有一些了解,但都比较粗略,也没相关经验,搭建起来还是有一些问题。
在搭建android应用框架前,我们首先应该清楚的就是,这个框架需要达到什么效果,主要有以下三点:
1) 降低项目的复杂性;
2) 易扩展、易修改、可重用性强、可维护性强;
3) 职责单一,功能清晰;
-
明确了要达到的效果后,就着手开始搭建应用框架吧,主要有以下几个步骤:
android项目工程搭建
在搭建工程结构的时候可以尽量抽取一些共用的东西,例如,数据库操作、base、task、事件观察者、通用的工具类、android UI公共组件等等,这些东西应该表现在代码结构中。
这些包名的作用一目了然,在别人接手这个项目的时候就会相对简单。
adapter适配器,如果业务复杂,根据不同的业务可以添加子包来进行分类;
base用来存放View的基类,例如BaseAcitivity、BaseFragment,甚至可以添加某些不同actionbar主题的Base类;
common当然是存放一些共用的配置类信息,常量等等;
controller控制器,将一部分的业务类需求放到里面,充当db和View交互的中间层,减少Activity中业务的复杂性;
event观察者模式,事件通知;
task一些AsyncTask任务类;
view一些自定义组件;
vo值对象,其实就是给各个组件使用的对象,比如ListView的Item对象等等。
另外,根据自己的一些业务需求,我们可能需要单独的抽取一些核心的包类。比如,理财类软件在搭建工程结构的时候,可以单独抽出了2个JS相关的核心包类:
AppContext的处理
Application本身在一个应用中只会存在一个实例,所以它一般用来存储一些全局的变量和一些只需要处理一次的数据。
context的管理 ,和BaseActivity组合使用,将每一个Activity放到一个列表中,需要的时候直接使用即可;
初始化和记录一些app信息,例如app的版本信息、设备信息等等;
初始化特定的业务需求,例如有盟统计类、分享SDK、推送等等;
记录应用启动次数、是否第一次安装等等,如果在第一个版本不加,到后面版本使用次记录会很麻烦;
记录是否开启处于调试模式,在输出日志、错误消息的时候有用。
public final static boolean DEBUG=BuildConfig.DEBUG;
Base的处理
对BaseActivity的处理好坏一定程度上会影响项目的代码可读性,在Base里面做一些规范化处理将会大大减少代码的书写量和提高可读性。
将其Base类定义成抽象类,增加一些抽象方法,例如findView的处理、onClick的处理、初始化数据的处理。例如可以重载setContentView方法来规范子类的行为:
@Override
public void setContentView(int layoutResID) {
super.setContentView(layoutResID);
findView();
initView();
setOnClick();
}
/**
* 获取布局控件
*/
protected abstract void findView();
/**
* 初始化View的一些数据
*/
protected abstract void initView();
/**
* 设置点击监听
*/
protected abstract void setOnClick();
通过这种规范可以大大减少后期代码的混乱,onCreat方法中存在大量杂乱无章的代码;
定义一些ActionBar上面的保护类方法,比如返回按钮、下拉事件等等;
数据库的处理
可以在处理数据库的时候采用ContentProvider的方式,这个方式有2个优点:
1)采用URI的方式访问,更加符合我们的使用习惯;
2)随时可以提供给其它应用访问数据库;
图片的处理
对图片处理的文章很多,其实你只要把基本的一些开源框架原理搞清楚,对普通应用其实足够了。这里就不在赘述。