SwipeBackFragment
Introduction: 滑动退出 Fragment&Activity 二合一
Tags:
Fragment-An Android library that can finish a Fragment&Activity with swipe-back gesture.
滑动 Fragment&Activity 边缘即可类似 IOS 一样,拖动返回。
原理分析:传送门, 如果你重度使用 Fragment,不妨看看这个库Fragmentation
特性
注: 滑动返回仅支持通过 add 方式加载的 Fragment, replace 不支持
1、Activity 内 Fragment 数大于 1 时,滑动返回的是 Fragment,否则滑动返回的是 Activity
2、支持左、右、左&右滑动(未来可能会增加更多滑动区域)
3、支持 Swipe 时的滑动监听
4、帮你处理了 Fragment 重叠的情况
Demo 演示
如何使用
1、项目下 app 的 build.gradle 中依赖:
// appcompat v7 包是必须的
compile 'me.yokeyword:swipebackfragment:0.4.0'
2、如果 Activity 也需要支持 SwipeBack,则继承 SwipeBackActivity:
public class SwipeBackSampleActivity extends SwipeBackActivity {}
同时该 Activity 的 theme 添加如下属性:
<item name="android:windowIsTranslucent">true</item>
3、如果 Fragment 需要支持 SwipeBack,则继承 SwipeBackFragment:
public class SwipeBackSampleFragment extends SwipeBackFragment {
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.xxx, container, false);
// 需要支持 SwipeBack 则这里必须调用 toSwipeBackFragment(view);
return attachToSwipeBack(view);
}
}
更多方法:
// 设置滑动方向
getSwipeBackLayout().setEdgeOrientation(SwipeBackLayout.EDGE_RIGHT); // EDGE_LEFT(默认),EDGE_ALL
// 设置侧滑触摸生效区域 MAX,MED,MIN,custom
setEdgeLevel(SwipeBackLayout.EdgeLevel edgeLevel)
// 滑动过程监听
getSwipeBackLayout().addSwipeListener(new SwipeBackLayout.OnSwipeListener() {
@Override
public void onDragStateChange(int state) {
// Drag state
}
@Override
public void onEdgeTouch(int edgeFlag) {
// 触摸的边缘 flag
}
@Override
public void onDragScrolled(float scrollPercent) {
// 滑动百分比
}
});
// 对于 SwipeBackActivity 有下面控制 SwipeBack 优先级的方法:
/**
* 限制 SwipeBack 的条件,默认栈内 Fragment 数 <= 1 时 , 优先滑动退出 Activity , 而不是 Fragment
*
* 可以通过复写该方法, 自由控制优先级
*
* @return true: Activity 可以滑动退出, 并且总是优先; false: Activity 不允许滑动退出
*/
@Override
public boolean swipeBackPriority() {
return super.swipeBackPriority();
// 下面是默认实现:
// return getSupportFragmentManager().getBackStackEntryCount() <= 1;
}