Android项目基础规范
26 Apr 2016代码管理
- Git 使用 rebase 命令来合并分支,尽量不要直接 merge 导致分支代码日志混乱。
- 开发新功能时,自己在本地创建 feature 分支开发,功能开发完毕之后,参照上面合并流程操作功能的合并,并删除本地分支,注意不要将本地分支推送到服务器。
- 平时开发只在 develop 分支和自己的本地分支操作,不要操作 master 和 release 分支,这两个分支只有在功能稳定上线的时候才进行合并操作。当线上版本出现紧急 bug 时,直接基于 master 分支拉取 hotfix 分支,解决 bug 之后再合并到其它各个分支。具体流程可以参见 Git Flow 流程
- git 提交日志尽量将注释缩减为一句话,不需要包含非常详细的内容。
- Added ( 新加入的任务需求 )
- Fixed ( 修复 bug 标注禅道的bug id 或者 bugtags 的 id)
- Changed ( 修改的任务 )
- Updated ( 更新的任务,或者由于第三方模块变化而做的变化 )
代码编写规范
编译配置相关
- 所有用到的第三方库文件统一在项目根目录下的 dependecies.gradle 文件中管理,并在 thirdDependencies 标签中添加引用并注释,需要填写代码库地址,方便后续查看使用及更新。
- 项目编译用到的 sdk 版本及 app 版本信息统一在项目根目录下的gradle.properties 中管理,其它引用的第三方库工程代码也需要同步更新。
- 项目中用到的第三方 app id 等信息需要在项目的 build.gradle 中定义对应字段在项目中引用,不要直接在代码中写死,容易出错也不利于维护更新。
- 项目中用到的颜色规范根据 ued 给出的规范统一定义于项目的 colors 中,不要直接在 xml 布局文件中写死,对于只有一两个地方用到的颜色也需要抽取出来单独定义,能够注释一下更好。
- 公共风格的控件需要抽取相应的 theme 放到 styles 文件中统一使用。不要直接在页面布局文件中写死控件颜色值或者字号大小,需要用统一的风格 theme,并且加上注释。
- 布局中需要用到固定宽高的统一在 dimens 中定义好,之后在代码中引用。
命名规范
-
代码中变量的命名遵照驼峰命名法。
-
布局文件中的控件命名尽量使用控件缩写做前缀,如 TextView 简写为tv_xx,Imageview 简写为 iv_xx。(不强求,有统一的风格即可)
-
图片资源命名规范如下:
- 背景类图片(指图片比较大,一般作为 activity 或者 view 背景的图片),用 bg_ 为前缀,一般为bg_描述。如果背景是有状态的显示的,命名规则为 bg_描述_状态。
- 按钮类图片(可以用 shape 自己实现的就不要用图片了),用 btn_ 为前缀,一般为btn_描述,如果按钮有状态显示的,需要添加状态后缀,如 btn_描述_normal 、btn_描述_focus 、btn_描述_enabled 。
- 选择框等控件使用的图片用 chx_ 为前缀。
- Dialog 控件使用的图片用 dg_ 为前缀。
- Menu 用到的图片用 menu_ 为前缀。
- 自己用 shape 实现的图片效果用 shape_ 为前缀。
- 其中有状态切换的图片组,在 drawable 文件夹中用 selector_ 为前缀。
-
Layout 文件命名规范如下:
- 如果布局文件是用于 activity ,则用 activity_ 为前缀。
- 如果布局文件是用于 fragment ,则用 fragment_ 为前缀。
- 如果布局文件是用于 ListView GridView RecycleView等 ,则用 item_ 为前缀。
- 如果布局文件是用于自定义 View ,则用 view_ 为前缀。
- 如果布局文件有多处引用使用 ,需要抽取公共引用的布局文件,则用 include_ 为前缀。
-
字符串资源命名规范如下:
有一个规则就是如果字符串可能有多处地方需要使用时,尽量用通用的英文单词含义就可以了(如 ok cancel back 等),对于某些字符串资源只有某些特定的范围使用时准照下面的规则。
- 用于 toast 弹出展示的资源用 toast_ 为前缀。
- 用于 dialog 展示的资源用 dialog_ 为前缀。
- 用于页面上标签展示的资源用 label_ 为前缀。
代码编写
- 页面布局中对于需要填充字符串或者图片查看控件效果的,都用 tools 命名空间进行资源的填充,对于需要隐藏的空间也需要用 tools 命名空间把控件进行显示,这样方便调整 ui ,一句话就是,要善于使用 tools 命名空间来编写布局文件。
- 对于布局有间距需求的,统一在 root view 级别做统一的上下左右间隔,尽量不要在子控件去做整体布局的上下左右间距处理。
- 代码中涉及到字符串资源的全部需要提取出来放入 strings.xml 文件中,不要在代码中直接将文本写死,很难维护。
- 网络请求处理尽量放到 appnetworklibrary 模块下处理,包括 model 及 Rxjava 处理数据之后返回也放到这个模块下。
- 项目中用到 EventBus 事件的,事件消息都放到主项目下的 event 包下,不要直接定义字符串事件处理,如果需要发送字符串事件处理的,改用发送本地广播来处理,通过 LocalBroadcastManager 来发送。
- 页面涉及 ViewPager 的,可以使用 FZBaseViewPagerAdapter 来设置适配器,其中的 Fragment 需要继承 FZBaseViewPagerFragment 来实现懒加载,不要一次把全部页面的数据都加载出来,切记!!!
- RecycleView 的 view holder 需要继承 FZBaseViewHolder 来实现,在绑定数据的时候直接调用 bindViewData 即可。
- 其它相应的工具类在 appbaselibrary 模块中,有些有包含的可以直接使用,没有包含的如果是可以通用的直接在模块中添加即可,否则在主项目中添加。
- 数据模型中,如果没有需求需要页面级别传递数据的话,不需要实现数据的序列化(Parcelable / Serializable)。
- 其它欢迎补充。
附上基础库代码链接FZBaseLib