目錄
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);會報錯,因為類型不匹配:
———————————————————————————————————
本文為博主原創文章,轉載請注明出處!
若本文對您有幫助,輕抬您發財的小手,關注/評論/點贊/收藏,就是對我最大的支持!
祝君升職加薪,鵬程萬里!
文章來源: blog.csdn.net,作者:Winter_world,版權歸原作者所有,如需轉載,請聯系作者。
原文鏈接:blog.csdn.net/w464960660/article/details/109387520