『多元日报』资讯阅读客户端

crazyleopard 发布于1年前 阅读5587次
0 条评论

目录

  1. 一、简介

  2. 二、特性

  3. 三、效果图

  4. 四、推广图

  5. 五、下载

  6. 六、最后

 

#简介

多元化阅读+深度阅读,为用户提供有价值的信息流,这是『多元日报』的定位和理念,产品从0到1的过程,学习了很多,收获了很多,如无意外地将会持续维护下去,未来的日子会增加一些有意思的功能,敬请期待。

 

#特性

 

1、Material Design设计风格

Toolbar、Snackbar、RecycleView、SwipeRefreshLayout、Activity跳转动画

2、MVP架构+单Activity多Fragment模式

参考Googole MVP Demo加上自己的一些思考,搭建了一个属于自己的项目架构,虽然不一定很准确无误,但起码是我目前水平所能做到比较满意的了

项目结构如下所示:

doingdaily_package_structure.png

- 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了

 

#效果图

 

doingdaily.gif

 

#推广图

 

doingdaily_banner.png

 

#下载

 

- Github

- Bugly

- 360Market

最后

开发的过程中曾遇到不少棘手的问题,参考阅读过大神牛人们的文章,在此无法一一列出其名字,在此感谢他们的经验分享与开源。

 

查看原文: 『多元日报』资讯阅读客户端

 

需要 登录 后回复方可回复, 如果你还没有账号你可以 注册 一个帐号。