Android如何使用ViewPager2實現頁面滑動切換效果
1.引言
在很多應用中,我們經常會看到多個頁面之間滑動切換的場景,ViewPager2是ViewPager的升級版,本文將簡要介紹如何使用ViewPager2、FragmentStateAdapter和Fragment來實現頁面之間的滑動切換。
2.實現頁面滑動切換
2.1 引入ViewPager2庫
要使用ViewPager2,需要引入ViewPager2庫,引入方法如下:
implementation "androidx.viewpager2:viewpager2:1.0.0"
2.2 使用ViewPager2
在佈局中使用ViewPager2,示例如下:
<androidx.viewpager2.widget.ViewPager2 android:id="@+id/viewPager2" android:layout_width="match_parent" android:layout_height="match_parent"/>
2.3 構建Fragment
本Fragment隻為簡單演示使用,其佈局如下:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:gravity="center" android:orientation="vertical"> <TextView android:id="@+id/tv_content" android:layout_width="wrap_content" android:layout_height="wrap_content" android:textSize="18sp" android:textColor="@color/black"/> </LinearLayout>
ContentFragment類的實現如下:
public class ContentFragment extends Fragment { private String content; public ContentFragment(String content) { this.content = content; } private TextView tv_content; @Nullable @Override public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) { View view = inflater.inflate(R.layout.fragment_content, container, false); tv_content = view.findViewById(R.id.tv_content); tv_content.setText(content); return view; } public void setContent(String content) { this.content = content; tv_content.setText(content); } }
2.4 繼承FragmentStateAdapter
創建自定義的類ContentPagerAdapter,讓它繼承FragmentStateAdapter,並實現createFragment(int position)和getItemCount()方法,示例如下:
public class ContentPagerAdapter extends FragmentStateAdapter { private List<ContentFragment> datas; public ContentPagerAdapter(@NonNull FragmentActivity fragmentActivity,List<ContentFragment> datas) { super(fragmentActivity); this.datas = datas; } @NonNull @Override public Fragment createFragment(int position) { return datas.get(position); } @Override public int getItemCount() { return datas.size(); } }
2.5 將ViewPager2與適配器綁定
將ViewPager2與適配器綁定後,便可實現頁面滑動切換,示例如下:
datas = new ArrayList<>(); datas.add(new ContentFragment("頁面1")); datas.add(new ContentFragment("頁面2")); datas.add(new ContentFragment("頁面3")); datas.add(new ContentFragment("頁面4")); datas.add(new ContentFragment("頁面5")); contentPagerAdapter = new ContentPagerAdapter(this, datas); viewPager2.setAdapter(contentPagerAdapter);
2.6 垂直方向滑動切換
ViewPager2不僅支持水平方向的滑動,還支持垂直方向的滑動,實現垂直滑動也是相當簡單,在佈局文件中添加android:orientation="vertical"屬性即可,如下所示:
<androidx.viewpager2.widget.ViewPager2 android:id="@+id/viewPager2" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical"/>
或者在代碼中調用ViewPager2的setOrientation(ViewPager2.ORIENTATION_VERTICAL)方法也可以讓ViewPager2實現垂直方向的滑動。
2.7 Fragment更新
當Fragment集合發生變化需要更新時,使用FragmentStateAdapter進行更新也很便捷,由於ViewPager2是基於RecyclerView實現的,所以更新數據的時候可以調用notifyItemChanged(int position)、notifyItemInserted(int position)等方法進行更新。
3.總結
使用ViewPager2、FragmentStateAdapter和Fragment可以便捷地實現頁面之間的滑動切換,它不僅支持水平方向的滑動,還能通過簡單的設置就能實現垂直方向的滑動,靈活地運用ViewPager2能實現實際的需求。
到此這篇關於Android如何使用ViewPager2實現頁面滑動切換效果的文章就介紹到這瞭,更多相關Android ViewPager2頁面滑動切換內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- ViewPager+Fragment實現側滑導航欄
- Android用viewPager2實現UI界面翻頁滾動的效果
- Android BottomNavigationView結合ViewPager實現底部導航欄步驟詳解
- Android嵌套線性佈局玩法坑解決方法
- 詳解Android ViewPager2中的緩存和復用機制