亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Android仿iOS實(shí)現(xiàn)側(cè)滑返回功能(類似微信)

 更新時(shí)間:2017年12月02日 14:21:43   作者:陳銘卓  
這篇文章主要為大家詳細(xì)介紹了Android仿iOS實(shí)現(xiàn)側(cè)滑返回功能,類似微信功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

我們都知道側(cè)滑返回操作是 iOS 里面比較常見的功能,一般是手指在靠近手機(jī)屏幕左邊緣向右滑動(dòng)就可以關(guān)閉當(dāng)前的界面,iOS 系統(tǒng)提供了這樣的 API,但是 Android 怎么實(shí)現(xiàn)呢?網(wǎng)上找了許多方法,比較了一下,個(gè)人覺得還是這個(gè)比較方便也容易理解,

先上個(gè)效果再說:

原理

Activity 本身是不可以滑動(dòng)的,但是我們可以制造一個(gè)正在滑動(dòng) Activity 的假象,使得看起來這個(gè) Activity 正在被手指滑動(dòng)。其原理其實(shí)很簡單,我們滑動(dòng)的其實(shí)是 Activity 里面的可見View元素,而我們將 Activity 設(shè)置為透明的,這樣當(dāng) View 滑過的時(shí)候,由于 Activity 的底部是透明的,我們就可以在滑動(dòng)過程中看到下面的Activity,這樣看起來就是在滑動(dòng) Activity。所以 Activity 滑動(dòng)效果分兩步:

設(shè)置 Activity 透明
滑動(dòng) View

實(shí)現(xiàn)

1、設(shè)置透明:

資源文件 values -> styles.xml 添加如下代碼,搞一個(gè)透明的主題。

<style name="Transparent" parent="Theme.AppCompat.Light.NoActionBar">
  <item name="android:windowBackground">@android:color/transparent</item>
  <item name="android:windowIsTranslucent">true</item>
</style>

然后在 AndroidManifest.xml 文件里面給相應(yīng)的 Activity 設(shè)置透明的主題。比如 MainActivity :

<activity
  android:name="com.example.test.MainActivity"
  android:theme="@style/Transparent" >
</activity>

2、滑動(dòng)View:

先看看 Activity 的層次結(jié)構(gòu):我們用的 Activity 的 xml 的根 View 并不是 Activity 的根 View ,在它上面還有一個(gè)父 View, id 是 android.R.id.content,再向上一層,還有一個(gè)view,它是一個(gè) LinearLayout,它除了放置我們創(chuàng)建的 View 之外,還放置我們的 xml 之外的一些東西比如放 ActionBar 或者標(biāo)題欄什么的。而再往上一級,就到了 Activity 的根 View —— DecorView,結(jié)構(gòu)

如下圖所示:

要做到像 iOS 那樣可以滑動(dòng)整個(gè) Activity ,只滑動(dòng)我們在xml里面創(chuàng)建的 View 顯然是不對的,因?yàn)槲覀冞€有標(biāo)題欄、ActionBar 什么的,所以我們要滑動(dòng)的應(yīng)該是 DecorView 或者倒數(shù)第二層的那個(gè) View。

而要滑動(dòng) View的話,我們要重寫其父窗口的 onInterceptTouchEvent 以及 onTouchEvent(當(dāng)然使用 setOnTouchListener 不是不可能,但是如果子 View 里面有一個(gè)消費(fèi)了 onTouch 事件,那么也就接收不到了),但是窗口的創(chuàng)建過程不是我們能控制的,DecorView 的創(chuàng)建都不是我們能干預(yù)的。

解決辦法就是,我們自己創(chuàng)建一個(gè) SwipeLayout,然后人為地插入頂層 View 中,放置在 DecorView 和其下面的 LinearLayout 中間,隨著手指的滑動(dòng),不斷改變 SwipeLayout 的子 View ——曾經(jīng)是 DecorView 的子 View——的位置,這樣我們就可以控制 Activity 的滑動(dòng)啦。我們在 Activity 的 onPostCreate 方法中調(diào)用swipeLayout.replaceLayer 替換我們的 SwipeLayout,代碼如下:

public void replaceLayer(Activity activity) {

  mActivity = activity;
  screenWidth = getScreenWidth(activity);
  setClickable(true);
  //獲取 Activity 的 根 View
  ViewGroup root = (ViewGroup) activity.getWindow().getDecorView();
  //獲取 根 View 下面的第一個(gè) View,并保存到 content
  content = root.getChildAt(0);
  ViewGroup.LayoutParams params = content.getLayoutParams();
  ViewGroup.LayoutParams params2 = new ViewGroup.LayoutParams(-1, -1);
  //把根 View 下面原來的第一個(gè) View 刪除
  root.removeView(content);
  //把 content 添加到 SwipeLayout
  this.addView(content, params2);
  //再把 SwipeLayout 添加到根 View 里面
  root.addView(this, params);
  sideWidth = (int) (sideWidthInDP * activity.getResources().getDisplayMetrics().density);
}


然后把這些寫成一個(gè) SwipeActivity 要求實(shí)現(xiàn)側(cè)滑返回的 Activity 繼承 SwipeActivity , SwipeActivity 繼承 FragmentActivity 或者 Activity 。比如 MainActivity:

public class SwipeActivity extends FragmentActivity {
  ...
  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
  }
  ...
}

public class MainActivity extends SwipeActivity {
  ...
  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
  }
  ...
}

總結(jié)

其實(shí)在工作中,開發(fā)一個(gè)項(xiàng)目基本都會封裝一個(gè) BaseActivity,只要 BaseActivity 繼承 SwipeActivity ,然后所有繼承 BaseActivity 的 Activity 就都可以實(shí)現(xiàn)側(cè)滑返回了, 如果有不需要實(shí)現(xiàn)這個(gè)功能的只需要調(diào)用 SwipeActivity 里面的一個(gè)方法:
public void setSwipeEnabled(boolean swipeEnabled) 參數(shù)傳一個(gè) false 就好了。是不是很方便!

其實(shí)另外還暴露出來一個(gè)方法:
public void setSwipeAnyWhere(boolean swipeAnyWhere) 設(shè)置是否屏幕任意位置右滑關(guān)閉,因?yàn)槟J(rèn)是只能左邊緣右滑返回。

最后

附上原github: https://github.com/NashLegend/SwipetoFinishActivity

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論