Android如何使用ViewPager2實現(xiàn)頁面滑動切換效果
1.引言
在很多應用中,我們經(jīng)常會看到多個頁面之間滑動切換的場景,ViewPager2是ViewPager的升級版,本文將簡要介紹如何使用ViewPager2、FragmentStateAdapter和Fragment來實現(xiàn)頁面之間的滑動切換。
2.實現(xiàn)頁面滑動切換
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 構(gòu)建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類的實現(xiàn)如下:
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
創(chuàng)建自定義的類ContentPagerAdapter,讓它繼承FragmentStateAdapter,并實現(xiàn)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與適配器綁定后,便可實現(xiàn)頁面滑動切換,示例如下:
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不僅支持水平方向的滑動,還支持垂直方向的滑動,實現(xiàn)垂直滑動也是相當簡單,在布局文件中添加android:orientation="vertical"屬性即可,如下所示:
<androidx.viewpager2.widget.ViewPager2
android:id="@+id/viewPager2"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"/>或者在代碼中調(diào)用ViewPager2的setOrientation(ViewPager2.ORIENTATION_VERTICAL)方法也可以讓ViewPager2實現(xiàn)垂直方向的滑動。
2.7 Fragment更新
當Fragment集合發(fā)生變化需要更新時,使用FragmentStateAdapter進行更新也很便捷,由于ViewPager2是基于RecyclerView實現(xiàn)的,所以更新數(shù)據(jù)的時候可以調(diào)用notifyItemChanged(int position)、notifyItemInserted(int position)等方法進行更新。
3.總結(jié)
使用ViewPager2、FragmentStateAdapter和Fragment可以便捷地實現(xiàn)頁面之間的滑動切換,它不僅支持水平方向的滑動,還能通過簡單的設置就能實現(xiàn)垂直方向的滑動,靈活地運用ViewPager2能實現(xiàn)實際的需求。
到此這篇關于Android如何使用ViewPager2實現(xiàn)頁面滑動切換效果的文章就介紹到這了,更多相關Android ViewPager2頁面滑動切換內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Flutter利用ORM框架管理數(shù)據(jù)庫詳解
使用?ORM?框架最大的好處是簡化了數(shù)據(jù)庫維護的代碼量,使得我們可以專注于業(yè)務代碼實現(xiàn)。本篇,我們看看如何使用ORM框架管理數(shù)據(jù)庫版本遷移,需要的可以參考一下2023-04-04
Flutter Widget移動UI框架使用Material和密匙Key實戰(zhàn)
這篇文章主要為大家介紹了Flutter Widget移動UI框架使用Material和密匙Key實戰(zhàn),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-12-12
Android中如何利用AIDL機制調(diào)用遠程服務
這篇文章主要介紹了Android中如何利用AIDL機制調(diào)用遠程服務的相關資料,需要的朋友可以參考下2016-03-03

