android ViewPager嵌套的使用方法

本文用代码描述了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);

//下面两行与上面一行是一个道理

/**
 * 这里注意一下,返回值不同时的不同作用
 */


// 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中使用即可

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值