[android|ViewPager]关于ViewPager如何阻止其滑动和一次切换多页闪烁的问题

转自:http://blog.sina.com.cn/s/blog_8a86f4dd0102vlx1.html  ,感谢这位前辈,项目中用的是平板,先前是使用了viewpager进行的fragment进行切换,后期需求方说没必要进行滑动,又不能修改很多原来的代码,所以只能禁止掉viewpager的左右滑动来解决,看到这篇文章,看到了希望,就转载来了,再次感谢


[android|ViewPager]关于ViewPager如何阻止其滑动和一次切换多页闪烁的问题

(2015-01-22 18:24:55)
唉,技术是为需求而生的!!!!

最近做项目,框架模仿的是微信的刻画动的结构,但是要求ViewPager不可滑动,于是头疼的找了一通google和百度,终于找到了正解:
import android.content.Context;
import android.support.v4.view.ViewPager;
import android.util.AttributeSet;
import android.view.MotionEvent;

public class CustomViewPager extends ViewPager{
     private boolean isCanScroll = true;
     
       public CustomViewPager(Context context, AttributeSet attrs) {
              super(context, attrs);
              // TODO Auto-generated constructor stub
       }

       public CustomViewPager(Context context) {
              super(context);
              // TODO Auto-generated constructor stub
       }
     
       public void setCanScroll(boolean isCanScroll){ 
               this.isCanScroll = isCanScroll; 
       }
     @Override
       public boolean onTouchEvent(MotionEvent arg0) {
              // TODO Auto-generated method stub
              if(isCanScroll){
                     return super.onTouchEvent(arg0);
              }else{
                     return false;
              }
       }

     @Override
       public boolean onInterceptTouchEvent(MotionEvent arg0) {
              // TODO Auto-generated method stub
              if(isCanScroll){
                     return super.onInterceptTouchEvent(arg0);
              }else{
                     return false;
              }
            
       }
}

问题是解决,但是如果点击标签横切多个page页面是,会出现闪烁,影响用户体验,又要改,又辛苦的搜索了一通,还好,很快又有了结果:
在上面的代码里加入:

       @Override
       public void setCurrentItem(int item, boolean smoothScroll) {
              // TODO Auto-generated method stub
              super.setCurrentItem(item, smoothScroll);
       }

       @Override
       public void setCurrentItem(int item) {
              // TODO Auto-generated method stub
              super.setCurrentItem(item, false);
       }
其中,super.setCurrentItem(item, false);,表示切换的时候,不需要切换时间。

问题解决了还是很欣慰的!
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现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自动滑动和手动滑动加点击切换的基本步骤,具体实现可以根据需求进行调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值