去除ViewPager页面切换动画和禁止滑动

直接定义一个类继承ViewPager:

去除页面切换时的滑动翻页效果

  1. public class CustomViewPager extends ViewPager {  
  2.   
  3.   
  4.     public CustomViewPager(Context context, AttributeSet attrs) {  
  5.         super(context, attrs);  
  6.     }  
  7.   
  8.     public CustomViewPager(Context context) {  
  9.         super(context);  
  10.     }  
  11.       
  12.     //去除页面切换时的滑动翻页效果  
  13.         @Override  
  14.         public void setCurrentItem(int item, boolean smoothScroll) {  
  15.             // TODO Auto-generated method stub  
  16.             super.setCurrentItem(item, smoothScroll);  
  17.         }  
  18.   
  19.         @Override  
  20.         public void setCurrentItem(int item) {  
  21.             // TODO Auto-generated method stub  
  22.             super.setCurrentItem(item, false);  
  23.         }  
  24.   
  25. }  

禁止ViewPager滑动


 
 
  1. @Override

 
 
  1. public boolean dispatchTouchEvent(MotionEvent ev) {
        return super.dispatchTouchEvent(ev);
    }
    
    @Override
    public boolean onInterceptTouchEvent(MotionEvent ev) {
        return false;
    }
    
    @Override
    public boolean onTouchEvent(MotionEvent ev) {
        return false;
    }
    
     
     

解决viewPager与百度地图滑动冲突 


  1. /** 
  2.      * 解决viewPager与百度地图滑动冲突 
  3.      * */  
  4.     @Override  
  5.     protected boolean canScroll(View v, boolean checkV, int dx, int x, int y) {  
  6.         if(v.getClass().getName().equals("com.baidu.mapapi.map.MapView")) {  
  7.             return true;  
  8.         }  
  9.         //if(v instanceof MapView){  
  10.         //    return true;  
  11.         //}  
  12.         return super.canScroll(v, checkV, dx, x, y);  
  13.     }  

ViewPager的几个属性:

//设置缓存view 的个数(实际有5个,缓存4个+正在显示的1个)
container.setOffscreenPageLimit(5);
//设置viewpager每个页卡的间距,与gallery的spacing属性类似
//viewpager.setPageMargin((int)getResources().getDimensionPixelOffset(R.dimen.ui_5_dip))
container.setPageMargin(10);
 
 
 
  1. //去除页面切换时的滑动翻页效果  
  2.         @Override  
  3.         public void setCurrentItem(int item, boolean smoothScroll) {  
  4.             // TODO Auto-generated method stub  
  5.             super.setCurrentItem(item, smoothScroll);  
  6.         }  
  7.   
  8.         @Override  
  9.         public void setCurrentItem(int item) {  
  10.             // TODO Auto-generated method stub  
  11.             super.setCurrentItem(item, false);  
  12.         }  

滑动到尽头时去掉阴影效果

ViewPager      ScrollView   ListView

		android:overScrollMode="never"

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
要实现ViewPager的自动滑动和手动滑动加点击切换,可以按以下步骤进行操作: 1. 在layout文件中添加ViewPager控件: ``` <android.support.v4.view.ViewPager android:id="@+id/view_pager" android:layout_width="match_parent" android:layout_height="wrap_content"/> ``` 2. 在Activity或Fragment中初始化ViewPager并设置Adapter: ``` ViewPager viewPager = findViewById(R.id.view_pager); viewPager.setAdapter(new MyPagerAdapter(getSupportFragmentManager())); ``` 3. 实现自动滑动功能,可以使用Handler和Runnable来实现: ``` private Handler handler = new Handler(); private Runnable runnable = new Runnable() { @Override public void run() { int currentItem = viewPager.getCurrentItem(); int count = viewPager.getAdapter().getCount(); if (currentItem < count - 1) { viewPager.setCurrentItem(currentItem + 1); } else { viewPager.setCurrentItem(0); } handler.postDelayed(runnable, 3000); } }; // 在onResume()方法中启动自动滑动 @Override protected void onResume() { super.onResume(); handler.postDelayed(runnable, 3000); } // 在onPause()方法中停止自动滑动 @Override protected void onPause() { super.onPause(); handler.removeCallbacks(runnable); } ``` 4. 实现手动滑动和点击切换功能,可以在ViewPager的OnPageChangeListener中处理: ``` viewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() { @Override public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {} @Override public void onPageSelected(int position) { // 处理页面切换事件 } @Override public void onPageScrollStateChanged(int state) { // 处理滑动状态变化事件 } }); ``` 在onPageSelected()方法中可以处理页面切换事件,比如更新页面指示器的状态。在onPageScrollStateChanged()方法中可以处理滑动状态变化事件,比如停止自动滑动或重新开始自动滑动。 以上就是实现ViewPager自动滑动和手动滑动加点击切换的基本步骤,具体实现可以根据需求进行调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值