本文主要是介绍Fragment之我的解决方案:Fragmentation,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
Fragment之我的解决方案:Fragmentation
Fragment系列文章:
1、Fragment全解析系列(一):那些年踩过的坑
2、Fragment全解析系列(二):正确的使用姿势
3、Fragment之我的解决方案:Fragmentation
附:SwipeBackFragment的实现分析
如果你通读了本系列的前两篇,我相信你可以写出大部分场景都能正常运行的Fragment了。如果你想了解更多,那么你可以看看我封装的这个库:Fragmentation。
本篇主要介绍这个库,解决了一些BUG,使用简单,提供实时查看栈视图等实用功能。
源码地址:Github,欢迎Star,Fork。
Demo网盘下载
Demo演示:
单Activity + 多Fragment,项目中有3个Demo。
流式的单Activity+多Fragment:

类似微信交互方式的单Activity+多Fragment:(全页面支持滑动返回)

类似新版仿知乎交互方式的单Activity+多Frgment:

Fragmentation
为"单Activity + 多Fragment的架构","多模块Activity + 多Fragment的架构"而生,帮你简化使用过程,轻松解决各种复杂嵌套等问题,修复了官方Fragment库存在的一些BUG。

特性
1、有效解决各种复杂嵌套、同级等Fragment重叠问题
2、实时查看Fragment的(包括嵌套Fragment)栈视图的对话框和Log,方便调试
3、增加启动模式、startForResult等类似Activity的方法
4、类似Android事件分发机制的Fragment回退方法:onBackPressedSupport(),轻松为每个Fragment实现Back按键事件
5、完美的防抖动解决方案(防止用户点击速度过快,导致启动多个Fragment)
6、提供可轻松 设定Fragment转场动画 的解决方案
7、修复官方库里pop(tag/id)出栈多个Fragment时的一些BUG
8、支持SwipeBack滑动边缘退出(需要使用Fragmentation_SwipeBack库,详情README)

重大更新日志
0.7.X 来了!!!
1、2个新demo: 仿知乎交互 + 仿微信交互的新Demo,展示复杂嵌套Fragment的交互场景
2、全新的Fragment恢复机制
3、更容易编写各种嵌套Fragment的代码
4、支持同级Fragment的处理
5、实验性支持SharedElement-Material过渡动画
6、全新的类似Android事件分发机制的onBackPressedSupport()
如何使用
1. 项目下app的build.gradle中依赖:
// appcompat v7包是必须的
compile 'me.yokeyword:fragmentation:0.7.7'
// 如果想使用SwipeBack 滑动边缘退出Fragment/Activity功能,请再添加下面的库
// compile 'me.yokeyword:fragmentation-swipeback:0.3.1'
2. Activity继承SupportActivity:
public class MainActivity extends SupportActivity {@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(...);if (savedInstanceState == null) {loadRootFragment(R.id.fl_container, HomeFragment.newInstance()); }}
3. Fragment继承SupportFragment:
public class HomeFragment extends SupportFragment {private void xxx() {// 启动新的Fragment, 同时还有start(fragment,SINGTASK)、startForResult、startWithPop等启动方法start(DetailFragment.newInstance(HomeBean));// ... 其他方法请自行查看 API}
进一步使用,查看wiki
这篇关于Fragment之我的解决方案:Fragmentation的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!