首页 > 学院 > 开发设计 > 正文

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

2019-11-07 23:58:45
字体:
来源:转载
供稿:网友

简介

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

推广图

推广图

下载

GithubBugly360Market

最后

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


发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表