目錄
1 背景
2 自定義ViewPager實作
3 使用方法
1 背景
用ViewPager+BottomNavigationView+多個Fragment快速搭建的頁面切換架構,一個有四個頁面,因為測驗需要,需要屏蔽掉中間的兩個,做法是:
-
設定不可點擊選擇:xml布局檔案中,BottomNavigationView的app:menu屬性為各頁的item,將不想顯示的頁面item的android:enabled屬性設定為false,此時對應的頁面就無法顯示了;
-
設定BottomNavigationView不可滑動:但是BottomNavigationView沒有對應的方法支持這個功能,
2 自定義ViewPager實作
【原理】:寫一個CustomViewPager類繼承ViewPager,然后重寫onTouchEvent、onInterceptTouchEvent,另外添加了setSlidingEnable方法,外部傳參開啟或禁止滑動,這里簡單解釋下onInterceptTouchEvent方法:
- 作用:判斷是否攔截上面touch的事件;
- 引數:
——return false: 不對事件進行攔截,放行該事件,事件會被傳遞到當前的View的子控制元件中,由子控制元件中的dispatchTouchEvent方法進行分發處理;
——return true: 攔截該事件,將該事件交給當前View的onTouchEvent方法進行處理;
【代碼】:
public class CustomViewPager extends ViewPager {
// the sliding page switch
private boolean isSlidingEnable = true ;
public CustomViewPager(Context context) {
super(context);
}
public CustomViewPager(Context context, AttributeSet attrs) {
super(context, attrs);
}
//重寫此函式
@Override
public boolean onTouchEvent(MotionEvent ev) {
return this.isSlidingEnable;
}
//重寫此函式
@Override
public boolean onInterceptTouchEvent(MotionEvent ev) {
return this.isSlidingEnable;
}
public void setSlidingEnable(boolean slidingEnable) {
isSlidingEnable = slidingEnable;
}
}
3 使用方法
private CustomViewPager homeViewPager = null;
homeViewPager = (CustomViewPager) findViewById(R.id.view_pager_home);
//中間涉及的其他步驟就不贅述了
???????homeViewPager.setSlidingEnable(false); //禁止左右滑動
這里需要注意的一個問題:CustomViewPager是自定義的一個類,我們定義布局檔案xml時就要用這個CustomViewPager,否則還用原來的androidx.viewpager.widget.ViewPager話,在這里homeViewPager = (CustomViewPager) findViewById(R.id.view_pager_home);會報錯,因為型別不匹配:

———————————————————————————————————
本文為博主原創文章,轉載請注明出處!
若本文對您有幫助,輕抬您發財的小手,關注/評論/點贊/收藏,就是對我最大的支持!
祝君升職加薪,鵬程萬里!
CSDN認證博客專家
嵌入式開發
Android
JavaWeb
轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/198203.html
標籤:其他
下一篇:Android自定義Toast
