我写了一个自定义ViewPager
来禁用Swipe Scroll
,但我想以编程方式进行滑动。我的视图寻呼机中有三个Tab
,但当我在第一个viewPager.setCurrentItem(viewPager.getCurrentItem()+1)
上呼叫Fragment
时,它会移至第三个Fragment
而不是第二个Fragment
。如果我在第二个Fragment
中调用相同的函数,它将转到第三个函数。如果我在第三个片段中调用(viewPager.getCurrentItem() - 1)`,它可以通过向后移动来正常工作。任何帮助,将不胜感激。我的代码如下:
NonSwipeAbleViewPager
public class NonSwipeableViewPager extends ViewPager {
private boolean swipeable;
public NonSwipeableViewPager(Context context, AttributeSet attrs) {
super(context, attrs);
TypedArray a = context.obtainStyledAttributes(attrs, R.styleable.MyViewPager);
try {
swipeable = a.getBoolean(R.styleable.MyViewPager_swipeable, true);
} finally {
a.recycle();
}
}
@Override
public boolean onInterceptTouchEvent(MotionEvent event) {
return swipeable ? super.onInterceptTouchEvent(event) : false;
}
@Override
public boolean onTouchEvent(MotionEvent event) {
return swipeable ? super.onTouchEvent(event) : false;
}
}
XML声明
<co.example.customview.NonSwipeableViewPager
android:id="@+id/pager"
android:layout_width="match_parent"
android:layout_height="0dp"
android:layout_weight="1"
app:swipeable="false" />
致电
@Override
public boolean onOptionsItemSelected(MenuItem item) {
switch (item.getItemId()) {
case R.id.menuNext:
NonSwipeableViewPager pages = (NonSwipeableViewPager) getActivity().findViewById(R.id.pager);
pages.setCurrentItem(pages.getCurrentItem()+1, true);
break;
default:
return super.onOptionsItemSelected(item);
}
return super.onOptionsItemSelected(item);
}
答案 0 :(得分:27)
viewPager.setCurrentItem(idx);
其中idx是基于0的整数。
答案 1 :(得分:14)
在PagerActivity中使用
viewPager = (ViewPager) findViewById(R.id.view_pager);
viewPager.setOnPageChangeListener(new ViewPager.OnPageChangeListener() {
@Override
public void onPageSelected(int position) {
int pagei = position + 1;
pages=pagei + "";
Toast.makeText(PagerActivity.this, getString(R.string.changeinfopage) + " " + pages, Toast.LENGTH_SHORT).show();
}
@Override
public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
}
@Override
public void onPageScrollStateChanged(int state) {
}
});
和
@Override
public boolean onOptionsItemSelected(MenuItem item) {
switch (item.getItemId()) {
case R.id.action_previous:
viewPager.setCurrentItem(viewPager.getCurrentItem() - 1);
return true;
case R.id.action_next:
viewPager.setCurrentItem(viewPager.getCurrentItem() + 1);
return true;
}
return super.onOptionsItemSelected(item);
}
答案 2 :(得分:2)
试试这个:
viewPager.postDelayed(new Runnable() {
@Override
public void run() {
viewPager.setCurrentItem(position);
}
}, 10);
有时,viewpager上的setCurrentItem不起作用。寻呼机的内容由微调器控制。旋转器和寻呼机状态都恢复为onResume,因此在下一个事件传播周期中调用了旋转器onItemSelected侦听器。
通过使用处理程序,我们可以使这个工作,因为它在onItemSelected事件触发后设置了寻呼机的当前位置。