Android 使用SwipeBackLayout實現滑動返回上一級頁面——實戰來襲

來源:互聯網
上載者:User

標籤:sea   nullable   ase   nis   wip   detail   建議   百度貼吧   img   

  我們知道。APP在設計上習慣性的把返回button放在螢幕的左上方,那麼,在非常多時候(尤其是大螢幕手機),操作改返回button,就會有諸多不便了。為了更加方便實現“返回”功能。如今的一些APP,如百度貼吧等。開始引入一種的新的互動方式,通過滑動螢幕。利用手勢事件來高速且友好的實現該功能。


  怎樣高速實現的效果呢。Github上提供了一個開源的庫SwipeBackLayout,地址:https://github.com/ikew0ng/SwipeBackLayout , 通過它,我們就能高速實現滑動返回上一級頁面了。

1. 建立項目。並匯入SwipeBackLayout庫(對於不熟悉的開源庫,我總建議引用庫。方便原始碼的閱讀和改動)


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);

如此這般,就可以解決衝突。


擴充:

  在github上。另一個能夠實現滑動返回上一級頁面的開源庫,我對照了下。感覺比SwipeBackLayout更方便,體驗上也更好些。有興趣的朋友能夠自己查看:https://github.com/liuguangqiang/SwipeBack


如此這般,就OK啦!歡迎互相學習!
如有疑問,歡迎留言探討。

Android 使用SwipeBackLayout實現滑動返回上一級頁面——實戰來襲

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.