DoingDaily多元日报资讯阅读客户端
多元化阅读+深度阅读,为用户提供有价值的信息流,这是“多元日报”的定位和理念,产品从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了
