Android如何使用ViewPager2實(shí)現(xiàn)頁(yè)面滑動(dòng)切換效果
1.引言
在很多應(yīng)用中,我們經(jīng)常會(huì)看到多個(gè)頁(yè)面之間滑動(dòng)切換的場(chǎng)景,ViewPager2是ViewPager的升級(jí)版,本文將簡(jiǎn)要介紹如何使用ViewPager2、FragmentStateAdapter和Fragment來(lái)實(shí)現(xiàn)頁(yè)面之間的滑動(dòng)切換。
2.實(shí)現(xiàn)頁(yè)面滑動(dòng)切換
2.1 引入ViewPager2庫(kù)
要使用ViewPager2,需要引入ViewPager2庫(kù),引入方法如下:
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只為簡(jiǎn)單演示使用,其布局如下:
<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類的實(shí)現(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,并實(shí)現(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與適配器綁定后,便可實(shí)現(xiàn)頁(yè)面滑動(dòng)切換,示例如下:
datas = new ArrayList<>(); datas.add(new ContentFragment("頁(yè)面1")); datas.add(new ContentFragment("頁(yè)面2")); datas.add(new ContentFragment("頁(yè)面3")); datas.add(new ContentFragment("頁(yè)面4")); datas.add(new ContentFragment("頁(yè)面5")); contentPagerAdapter = new ContentPagerAdapter(this, datas); viewPager2.setAdapter(contentPagerAdapter);
2.6 垂直方向滑動(dòng)切換
ViewPager2不僅支持水平方向的滑動(dòng),還支持垂直方向的滑動(dòng),實(shí)現(xiàn)垂直滑動(dòng)也是相當(dāng)簡(jiǎ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實(shí)現(xiàn)垂直方向的滑動(dòng)。
2.7 Fragment更新
當(dāng)Fragment集合發(fā)生變化需要更新時(shí),使用FragmentStateAdapter進(jìn)行更新也很便捷,由于ViewPager2是基于RecyclerView實(shí)現(xiàn)的,所以更新數(shù)據(jù)的時(shí)候可以調(diào)用notifyItemChanged(int position)、notifyItemInserted(int position)等方法進(jìn)行更新。
3.總結(jié)
使用ViewPager2、FragmentStateAdapter和Fragment可以便捷地實(shí)現(xiàn)頁(yè)面之間的滑動(dòng)切換,它不僅支持水平方向的滑動(dòng),還能通過(guò)簡(jiǎn)單的設(shè)置就能實(shí)現(xiàn)垂直方向的滑動(dòng),靈活地運(yùn)用ViewPager2能實(shí)現(xiàn)實(shí)際的需求。
到此這篇關(guān)于Android如何使用ViewPager2實(shí)現(xiàn)頁(yè)面滑動(dòng)切換效果的文章就介紹到這了,更多相關(guān)Android ViewPager2頁(yè)面滑動(dòng)切換內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Flutter利用ORM框架管理數(shù)據(jù)庫(kù)詳解
使用?ORM?框架最大的好處是簡(jiǎn)化了數(shù)據(jù)庫(kù)維護(hù)的代碼量,使得我們可以專注于業(yè)務(wù)代碼實(shí)現(xiàn)。本篇,我們看看如何使用ORM框架管理數(shù)據(jù)庫(kù)版本遷移,需要的可以參考一下2023-04-04Android?Studio實(shí)現(xiàn)登錄界面功能
這篇文章主要為大家詳細(xì)介紹了Android?Studio實(shí)現(xiàn)登錄界面功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-04-04Flutter Widget移動(dòng)UI框架使用Material和密匙Key實(shí)戰(zhàn)
這篇文章主要為大家介紹了Flutter Widget移動(dòng)UI框架使用Material和密匙Key實(shí)戰(zhàn),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12Android實(shí)現(xiàn)列表元素動(dòng)態(tài)效果
本文將利用AnimatedList組件實(shí)現(xiàn)列表元素的一些動(dòng)態(tài)效果,例如添加元素時(shí)的漸現(xiàn)效果,刪除元素逐漸消失的效果等,感興趣的小伙伴可以了解一下2022-03-03android6.0運(yùn)行時(shí)權(quán)限完美封裝方法
今天小編就為大家分享一篇android6.0運(yùn)行時(shí)權(quán)限完美封裝方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-07-07Android Toolbar自定義標(biāo)題標(biāo)題居中的實(shí)例代碼
這篇文章主要介紹了Android Toolbar自定義標(biāo)題 標(biāo)題居中的實(shí)例代碼,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-08-08Android中如何利用AIDL機(jī)制調(diào)用遠(yuǎn)程服務(wù)
這篇文章主要介紹了Android中如何利用AIDL機(jī)制調(diào)用遠(yuǎn)程服務(wù)的相關(guān)資料,需要的朋友可以參考下2016-03-03