Android SwipeBackLayout实现滑动返回上一级页面

本文介绍了一种在Android应用中实现类似iOS侧滑返回功能的方法。通过使用SwipeBackLayout库,开发者可以轻松地在项目中加入这一特性,并解决了背景黑屏及与SystemBarTint库兼容性等问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这是高仿ios侧滑返回上级页面 ,

类似效果如上图所示。如何快速实现上图的效果呢,Github上提供了一个开源的库SwipeBackLayout,地址:https://github.com/ikew0ng/SwipeBackLayout , 通过它,我们就能快速实现滑动返回上一级页面了。

1. 新建项目,直接依赖compile 'me.imid.swipebacklayout.lib:library:1.0.0'

2. 新建Activity,要求继承SwipeBackActivity

public class SecondActivity extends SwipeBackActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_second);
    }
}
对,就这么简单,不需要在做任何操作,该Activity就已经可以支持“从左向右滑动返回上一级页面”了。

当然,仅仅这样还是不够的,在页面滑动过程中,会遇到些问题:


问题1:页面滑动过程中背景黑屏:

  解决该问题,我们则要为需要滑动的Activity设置背景透明的主题,不需要滑动的,自然也就无需设置了:

 <activity
            android:name=".DemoActivity"
            android:label="@string/app_name"/>
 <activity
            android:name=".SecondActivity"
            android:theme="@style/otherPageStyle" />


 <!--
        Base application theme, dependent on API level. This theme is replaced
        by AppBaseTheme from res/values-vXX/styles.xml on newer devices.
    -->
    <style name="AppBaseTheme" parent="@style/Theme.AppCompat.Light.NoActionBar">

    </style>

    <!-- Application theme. -->
    <style name="AppTheme" parent="@style/AppBaseTheme">
    </style>

    <!-- 首页(第一级页面不让Activity透明) -->
    <style name="mainPageStyle" parent="AppTheme">
        <item name="android:windowIsTranslucent">false</item>
    </style>

    <!-- 非首页(非第一级页面让Activity透明) -->
    <style name="otherPageStyle" parent="AppTheme">
        <item name="android:windowIsTranslucent">true</item>
    </style>


问题2:实战项目中,常常会出现已有基类BaseActivity,如何集成在一起呢?

 1. 创建一个基类,BaseActivity

public class BaseActivity extends FragmentActivity {

    @Override
    protected void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
    }
}

 2. 拷贝一份SwipeBackActivity.java源码,修改下,继承自BaseActivity:

import android.os.Bundle;
import android.view.View;

import me.imid.swipebacklayout.lib.SwipeBackLayout;
import me.imid.swipebacklayout.lib.Utils;
import me.imid.swipebacklayout.lib.app.SwipeBackActivityBase;
import me.imid.swipebacklayout.lib.app.SwipeBackActivityHelper;


public class MySwipeBackActivity extends BaseActivity implements SwipeBackActivityBase {
    private SwipeBackActivityHelper mHelper;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        mHelper = new SwipeBackActivityHelper(this);
        mHelper.onActivityCreate();
    }

    @Override
    protected void onPostCreate(Bundle savedInstanceState) {
        super.onPostCreate(savedInstanceState);
        mHelper.onPostCreate();
    }

    @Override
    public View findViewById(int id) {
        View v = super.findViewById(id);
        if (v == null && mHelper != null)
            return mHelper.findViewById(id);
        return v;
    }

    @Override
    public SwipeBackLayout getSwipeBackLayout() {
        return mHelper.getSwipeBackLayout();
    }

    @Override
    public void setSwipeBackEnable(boolean enable) {
        getSwipeBackLayout().setEnableGesture(enable);
    }

    @Override
    public void scrollToFinishActivity() {
        Utils.convertActivityToTranslucent(this);
        getSwipeBackLayout().scrollToFinishActivity();
    }
}

这样,当你需要页面滑动返回的时候,则该页面的Activity就继承MySwipeBackActivity,不需要的话(比如首页),则直接继承自BaseActivity即可。


问题3:如何同时兼容SystemBarTint和SwipeBackLayout两个库。

  之前写过《Android 使用SystemBarTint设置状态栏颜色》,如果什么都不做修改,直接在你的项目中引用这两个库,则会发生冲突。在4.4上,如果使用SwipeBackLayout,就不能用SystemBarTint来改变状态栏颜色。 

  解决该问题,可以通过修改SwipeBackLayout源码来解决,打开SwipeBackLayout.java类,找到public void attachToActivity(Activity activity)方法,找到:

ViewGroup decor = (ViewGroup) activity.getWindow().getDecorView();

把它修改成:

ViewGroup decor = (ViewGroup) activity.getWindow().getDecorView().findViewById(Window.ID_ANDROID_CONTENT);

如此这般,即可解决冲突!

SwipeBackLayout 是一个支持屏幕上下左右滑动返回上层 Activity, 关闭当前 Activity, 类似简书 App。效果图:示例代码:public class DemoActivity extends SwipeBackActivity implements View.OnClickListener {     private int[] mBgColors;     private static int mBgIndex = 0;     private String mKeyTrackingMode;     private RadioGroup mTrackingModeGroup;     private SwipeBackLayout mSwipeBackLayout;     @Override     protected void onCreate(Bundle savedInstanceState) {         super.onCreate(savedInstanceState);         setContentView(R.layout.activity_demo);         changeActionBarColor();         findViews();         mKeyTrackingMode = getString(R.string.key_tracking_mode);         mSwipeBackLayout = getSwipeBackLayout();         mTrackingModeGroup.setOnCheckedChangeListener(new RadioGroup.OnCheckedChangeListener() {             @Override             public void onCheckedChanged(RadioGroup group, int checkedId) {                 int edgeFlag;                 switch (checkedId) {                     case R.id.mode_left:                         edgeFlag = SwipeBackLayout.EDGE_LEFT;                         break;                     case R.id.mode_right:                         edgeFlag = SwipeBackLayout.EDGE_RIGHT;                         break;                     case R.id.mode_bottom:                         edgeFlag = SwipeBackLayout.EDGE_BOTTOM;                         break;                     default:                         edgeFlag = SwipeBackLayout.EDGE_ALL;                 }                 mSwipeBackLayout.setEdgeTrackingEnabled(edgeFlag);                 saveTrackingMode(edgeFlag);             }         });     }
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值