中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Android view怎么實現滑動懸浮固定效果

發布時間:2022-04-07 17:29:16 來源:億速云 閱讀:211 作者:iii 欄目:編程語言

這篇文章主要介紹“Android view怎么實現滑動懸浮固定效果”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“Android view怎么實現滑動懸浮固定效果”文章能幫助大家解決問題。

1.背景

在項目開發過程中,有時候會碰到這樣的需求:在滑動的過程中,在某時要將子view固定在頂部(常見的是將界面中的tab在滑動到頂部的時候進行固定)。

效果圖:

Android view怎么實現滑動懸浮固定效果

2.思路

(CoordinatorLayout+AppBarLayout+CollapsingToolbarLayout)+TabLayout+ViewPager

3.代碼實現

a.主布局代碼

<?xml version="1.0" encoding="utf-8"?> 
<android.support.design.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android" 
  xmlns:app="http://schemas.android.com/apk/res-auto" 
  xmlns:tools="http://schemas.android.com/tools" 
  android:layout_width="match_parent" 
  android:layout_height="match_parent" 
  android:fitsSystemWindows="true" 
  tools:context="com.ganshenml.slideholdsmoothdemo.ScrollingActivity"> 
 
  <android.support.design.widget.AppBarLayout 
    android:id="@+id/app_bar" 
    android:layout_width="match_parent" 
    android:layout_height="wrap_content" 
    android:fitsSystemWindows="true" 
    android:theme="@style/AppTheme.AppBarOverlay"> 
 
    <android.support.design.widget.CollapsingToolbarLayout 
      android:id="@+id/toolbar_layout" 
      android:layout_width="match_parent" 
      android:layout_height="wrap_content" 
      android:fitsSystemWindows="true" 
      app:contentScrim="?attr/colorPrimary" 
      app:layout_scrollFlags="scroll|exitUntilCollapsed" 
      app:titleEnabled="false"> 
 
      <android.support.v7.widget.Toolbar 
        android:id="@+id/toolbar" 
        android:layout_width="match_parent" 
        android:layout_height="30dp" 
        app:popupTheme="@style/AppTheme.PopupOverlay"></android.support.v7.widget.Toolbar> 
 
      <ImageView 
        android:layout_width="match_parent" 
        android:layout_height="280dp" 
        android:scaleType="centerCrop" 
        android:src="@drawable/bg" /> 
 
      <android.support.design.widget.TabLayout 
        android:id="@+id/tabLayout" 
        android:layout_width="match_parent" 
        android:layout_height="30dp" 
        android:layout_gravity="bottom" 
        android:background="@color/colorAccent"></android.support.design.widget.TabLayout> 
 
    </android.support.design.widget.CollapsingToolbarLayout> 
  </android.support.design.widget.AppBarLayout> 
 
  <include layout="@layout/content_scrolling" /> 
</android.support.design.widget.CoordinatorLayout>

需要注意的是:

  1. app:layout_scrollFlags="scroll|exitUntilCollapsed"——>設置可以滑動且當前view可以一直退出直到折疊視圖顯現。

  2. <include layout="@layout/content_scrolling" />——>引用的子view布局其實就是一個ViewPager(需要注意的是要在布局中設置:app:layout_behavior="@string/appbar_scrolling_view_behavior")

b.主界面Activity代碼

public class ScrollingActivity extends AppCompatActivity { 
  private TabLayout tabLayout; 
  private ViewPager viewPager; 
 
  @Override 
  protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_scrolling); 
    initViews(); 
  } 
 
  private void initViews() { 
    tabLayout = (TabLayout) findViewById(R.id.tabLayout); 
    viewPager = (ViewPager) findViewById(R.id.viewPager); 
 
    viewPager.setOffscreenPageLimit(2); 
    viewPager.setAdapter(new MPagerAdapter(getSupportFragmentManager())); 
    tabLayout.setupWithViewPager(viewPager); 
  } 
 
}

c.適配器MPagerAdapter代碼

public class MPagerAdapter extends FragmentStatePagerAdapter { 
  private String[] tabTitle = new String[]{"tab01", "tab02"}; 
  private FirstFragment firstFragment; 
  private SecondFragment secondFragment; 
 
  public MPagerAdapter(FragmentManager fm) { 
    super(fm); 
  } 
 
  @Override 
  public Fragment getItem(int position) { 
    if (position == 0) { 
      if (firstFragment == null) { 
        firstFragment = new FirstFragment(); 
      } 
      return firstFragment; 
    } else if (position == 1) { 
      if (secondFragment == null) { 
        secondFragment = new SecondFragment(); 
      } 
      return secondFragment; 
    } 
    return null; 
  } 
 
  @Override 
  public int getCount() { 
    return tabTitle.length; 
  } 
 
  @Override 
  public CharSequence getPageTitle(int position) { 
    return tabTitle[position]; 
  } 
 
}

兩個Fragment的代碼非常簡單。僅僅加載布局而已,所以在此就不貼出來了。

4.擴展

a.關于CollapsingToolbarLayout中子view的排列順序對顯示結果造成的影響

如圖:

Android view怎么實現滑動懸浮固定效果

可以看到圖中黑色邊框顯示的內容不一致,因此ToolBar和ImageView的排列順序會對視圖的顯示結果造成影響。

推測——>CollapsingToolbarLayout中以上三種view不同排序的剖面展示效果為:

順序:Toolbar——>ImageView——>TabLayout(設置layout_gravity="bottom")

Android view怎么實現滑動懸浮固定效果

順序:ImageView——>Toolbar——>TabLayout(設置layout_gravity="bottom")

Android view怎么實現滑動懸浮固定效果

不負責任滴猜測:把Toolbar看做一張畫布,只有覆蓋在畫布投射區域范圍內的內容才顯示出來在該畫布內。
(因此,1.在畫布下的內容就無法顯示出來;2.無法覆蓋畫布的內容就顯示為畫布默認的樣式)
所以,如果不想要有視差效果的話,那么就將Toolbar與TabLayout的高度設置一致。如果將Toolbar去掉,那么所有的CollapsingToolbarLayout中的View都會滑出界面,此時布局就變成了普通布局了(相當于CollapsingToolbarLayout變成了CollapsingLayout)。

b.去掉Toolbar實現固定效果

<android.support.design.widget.AppBarLayout 
    android:id="@+id/app_bar" 
    android:layout_width="match_parent" 
    android:layout_height="wrap_content" 
    android:fitsSystemWindows="true" 
    android:theme="@style/AppTheme.AppBarOverlay"> 
 
    <android.support.design.widget.CollapsingToolbarLayout 
      android:id="@+id/toolbar_layout" 
      android:layout_width="match_parent" 
      android:layout_height="wrap_content" 
      android:fitsSystemWindows="true" 
      app:contentScrim="?attr/colorPrimary" 
      app:layout_scrollFlags="scroll|exitUntilCollapsed" 
      app:titleEnabled="false"> 
 
      <ImageView 
        android:layout_width="match_parent" 
        android:layout_height="280dp" 
        android:scaleType="centerCrop" 
        android:src="@drawable/bg" /> 
 
    </android.support.design.widget.CollapsingToolbarLayout> 
 
    <android.support.design.widget.TabLayout 
      android:id="@+id/tabLayout" 
      android:layout_width="match_parent" 
      android:layout_height="30dp" 
      android:layout_gravity="top" 
      android:background="@color/colorAccent"></android.support.design.widget.TabLayout> 
 
  </android.support.design.widget.AppBarLayout>

只要將TabLayout從CollapsingToolbarLayout中移到AppBarLayout的一級子View即可。

(這樣也避免了:在CollapsingToolbarLayout中,因為視圖折疊覆蓋的問題,會導致整個ImageView被TabLayout覆蓋一部分而顯示不完全的問題。)

關于“Android view怎么實現滑動懸浮固定效果”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

呼伦贝尔市| 蓬安县| 武穴市| 抚松县| 延庆县| 德江县| 河池市| 涟源市| 时尚| 石城县| 靖州| 武陟县| 富平县| 北安市| 墨脱县| 福鼎市| 宜川县| 厦门市| 商洛市| 惠水县| 板桥市| 抚宁县| 察哈| 襄垣县| 左权县| 荣成市| 桂平市| 平远县| 丰镇市| 洛扎县| 黄陵县| 万年县| 长治市| 九寨沟县| 青浦区| 民和| 彭州市| 长汀县| 达孜县| 兴安盟| 福州市|