本文用代码描述了ViewPager内部嵌套ViwePager的使用方法,经过测试没有问题,如在使用过程中有问题可及时沟通
首先在自己创建的项目中任选一个包来创建一个类继承ViewPager
package cn.weilan.App;
import android.content.Context;
import android.graphics.PointF;
import android.support.v4.view.ViewPager;
import android.util.AttributeSet;
import android.view.MotionEvent;
import android.view.View;
public class TuanGoBasePager extends ViewPager{
public TuanGoBasePager(Context context, AttributeSet attrs) {
super(context, attrs);
// TODO Auto-generated constructor stub
}
public TuanGoBasePager(Context context) {
super(context);
// TODO Auto-generated constructor stub
}
/**
* 触摸时按下的点
*/
PointF downPoinf=new PointF();
/**
* 触摸时当时的点
*/
PointF curF=new PointF();
OnSingleTouchListener onSingleTouchListener;
@Override
public boolean onTouchEvent(MotionEvent evt) {
int action = evt.getAction();
/**
*注释的这段与下面使用代码块基本相同,但不绝对,可做参考
*/
// if (getChildCount() <= 1) {// return super.onTouchEvent(evt);
// }
// curF.x = evt.getX();
// curF.y = evt.getY();
// if (evt.getAction() == MotionEvent.ACTION_DOWN) {
// downPoinf.x = evt.getX();
// downPoinf.y = evt.getY();
// this.getParent().requestDisallowInterceptTouchEvent(true);
// }
// if (evt.getAction() == MotionEvent.ACTION_MOVE) {
// /**在第一页向后一页滑动*/
// if (downPoinf.x>=curF.x) {
// if (getCurrentItem()==0||getCurrentItem()<getAdapter().getCount()-1) {
// this.getParent().requestDisallowInterceptTouchEvent(true);
// }
// /**在最后一页*/
// if(getCurrentItem()==getAdapter().getCount()-1){
// this.getParent().requestDisallowInterceptTouchEvent(false);
// }
// }
// /**在最后一页向前一页滑动*/
// if (downPoinf.x<=curF.x) {
// if (getCurrentItem()<=getAdapter().getCount()-1) {
// this.getParent().requestDisallowInterceptTouchEvent(true);
// }
// /**在第一页*/
// if (getCurrentItem()==0) {
// this.getParent().requestDisallowInterceptTouchEvent(false);
// }
// }
//
// }
// if (evt.getAction() == MotionEvent.ACTION_UP
// || evt.getAction() == MotionEvent.ACTION_CANCEL) {
// if (downPoinf.x == curF.x && downPoinf.y == curF.y) {
// /** 这是一个点击事件 */
// return true;
// }
// this.getParent().requestDisallowInterceptTouchEvent(true);
// }
//
// super.onTouchEvent(evt);
// return true;
switch (action) {
case MotionEvent.ACTION_DOWN:
// 记录按下时候的坐标
downPoinf.x = evt.getX();
downPoinf.y = evt.getY();
if (this.getChildCount() > 1) { //有内容,多于1个时
// 通知其父控件,现在进行的是本控件的操作,不允许拦截
getParent().requestDisallowInterceptTouchEvent(true);
}
break;
case MotionEvent.ACTION_MOVE:
if (this.getChildCount() > 1) { //有内容,多于1个时
// 通知其父控件,现在进行的是本控件的操作,不允许拦截
getParent().requestDisallowInterceptTouchEvent(true);
}
break;
case MotionEvent.ACTION_UP:
// 在up时判断是否按下和松手的坐标为一个点
if (PointF.length(evt.getX() - downPoinf.x, evt.getY()
- downPoinf.y) < (float) 5.0) {
onSingleTouch(this);
return true;
}
break;
}
return super.onTouchEvent(evt);
//下面两行与上面一行是一个道理
/**
* 这里注意一下,返回值不同时的不同作用
*/
// return true;
}
public void onSingleTouch(View v) {
if (onSingleTouchListener != null) {
onSingleTouchListener.onSingleTouch(v);
}
}
public interface OnSingleTouchListener {
public void onSingleTouch(View v);
}
public void setOnSingleTouchListener(
OnSingleTouchListener onSingleTouchListener) {
this.onSingleTouchListener = onSingleTouchListener;
}
}
把这个类布局在内部嵌套的ViewPager处即可,如:
<ImageView
android:id="@+id/iv_image"
android:layout_width="30dp"
android:layout_height="5dp"
android:background="#00ff00"
android:contentDescription="@null" />
</LinearLayout>
</HorizontalScrollView>
<LinearLayout
android:id="@+id/ll_Tuango_id"
android:layout_width="match_parent"
android:layout_height="0dp"
android:layout_weight="1"
android:orientation="horizontal"
>
这边布局的就是上面所写的类,内部ViewPager
<cn.weilan.App.TuanGoBasePager
android:id="@+id/TuanGo_vp_id"
android:layout_width="match_parent"
android:layout_height="match_parent"
>
</cn.weilan.App.TuanGoBasePager>
</LinearLayout>
</LinearLayout>
然后在要用的Fragment中使用即可