目录
一、简介
二、特性
三、效果图
四、推广图
五、下载
六、最后
简介
多元化阅读+深度阅读,为用户提供有价值的信息流,这是『多元日报』的定位和理念,产品从0到1的过程,学习了很多,收获了很多,如无意外地将会持续维护下去,未来的日子会增加一些有意思的功能,敬请期待。
特性
1、Material Design设计风格
Toolbar、Snackbar、RecycleView、SwipeRefreshLayout、Activity跳转动画
2、MVP架构+单Activity多Fragment模式
参考Googole MVP Demo加上自己的一些思考,搭建了一个属于自己的项目架构,虽然不一定很准确无误,但起码是我目前水平所能做到比较满意的了
项目结构如下所示:
- application :自定义的全局application类
- commom :公共类库
- constants :常量类
- data : 数据源,包括本地和远程
- network :网络请求封装,使用Retrofit+rxJava
- share :分享管理类
- utlis :常用工具类
- widgets :自定义的View,如TabLayout、RowView
- framework :全局框架,使用时必须继承相关基类,如BaseActivity、BaseFragment、RxBus
- module :业务逻辑层,按照相关功能划分模块
- wxapi :微信分享回调所必须的集成类
3、首页仿知乎上下滑动隐藏菜单栏
滑动隐藏顶部Toolbar这种效果网上大多数Demo都可以看到,但隐藏底部的Tab就需要用到自定义Behavior了,注意这个Behavior是依赖于AppBarLayout的,当AppBarLayout里的Toolbar发生位移的时候底部的Tab也跟随着向下隐藏,在此附上自定义的TabBehavior:
public class TabBehavior extends CoordinatorLayout.Behavior<View> {
public TabBehavior(Context context, AttributeSet attrs) {
super(context, attrs);
}
@Override
public boolean layoutDependsOn(CoordinatorLayout parent, View child, View dependency) {
return dependency instanceof AppBarLayout;
}
@Override
public boolean onDependentViewChanged(CoordinatorLayout parent, View child, View dependency) {
float translationY = Math.abs(dependency.getTop());
child.setTranslationY(translationY);
return true;
}
}
使用的时候引入这个Behavior即可
4、封装底部Tab、常用RowView、PullRecycleView
底部Tab封装成TabLayout,添加一个Tab几行代码搞定:
ArrayList<TabLayout.Tab> tabs = new ArrayList<>();
tabs.add(new TabLayout.Tab(R.drawable.ic_bottomtabbar_news, R.string.tab_news, NewsFragment.class));
tabs.add(new TabLayout.Tab(R.drawable.ic_bottomtabbar_wechat, R.string.tab_wechat, WechatFragment.class));
tabs.add(new TabLayout.Tab(R.drawable.ic_bottomtabbar_about, R.string.tab_about, AboutFragment.class));
mTabLayout.setUpData(tabs, this);
mTabLayout.setCurrentTab(0);
5、集成第三方:社会化分享、检测更新、埋点统计
主要是用到了友盟社会化分享,Bugly异常上报与应用升级,LeanCloud用户反馈这些SDK,基本没有什么大的技术含量,照着文档集成就Ok了
效果图
推广图
下载
最后
开发的过程中曾遇到不少棘手的问题,参考阅读过大神牛人们的文章,在此无法一一列出其名字,在此感谢他们的经验分享与开源。