android----ViewDragHelper的使用 引入动画 实现侧滑菜单

implementation 'com.nineoldandroids:library:2.4.0'

让元素不移动

 @Override
        public int clampViewPositionHorizontal(@NonNull View child, int left, int dx) {
            return  left-dx; //减掉偏移量
        }

模板代码

@Override
    public void computeScroll() {
        if (dragHelper.continueSettling(true)) { //模板代码
            ViewCompat.postInvalidateOnAnimation(this);
        }
    }

实现侧滑菜单

package com.yifei.myapplication;

import android.content.Context;
import android.os.Build;
import android.support.annotation.NonNull;
import android.support.annotation.RequiresApi;
import android.support.v4.view.ViewCompat;
import android.support.v4.widget.ViewDragHelper;
import android.util.AttributeSet;
import android.view.MotionEvent;
import android.view.View;
import android.widget.FrameLayout;

public class MyDrawViewGroup extends FrameLayout {

    private View menu;
    private View main;
    private ViewDragHelper dragHelper;

    public MyDrawViewGroup(Context context) {
        super(context);
        initView();
    }
    public MyDrawViewGroup(Context context, AttributeSet attrs) {
        super(context, attrs);
        initView();
    }
    public MyDrawViewGroup(Context context, AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
        initView();
    }
    @RequiresApi(api = Build.VERSION_CODES.LOLLIPOP)
    public MyDrawViewGroup(Context context, AttributeSet attrs, int defStyleAttr, int defStyleRes) {
        super(context, attrs, defStyleAttr, defStyleRes);
        initView();
    }

    //
    @Override
    public void computeScroll() {
        if (dragHelper.continueSettling(true)) { //模板代码
            ViewCompat.postInvalidateOnAnimation(this);
        }
    }

    //事件的分发
    @Override
    public boolean dispatchTouchEvent(MotionEvent ev) {
        return super.dispatchTouchEvent(ev);
    }

    //事件的拦截
    @Override
    public boolean onInterceptTouchEvent(MotionEvent ev) {
        return dragHelper.shouldInterceptTouchEvent(ev); //把事件交给 dragHelper 处理
    }

    //事件的处理
    @Override
    public boolean onTouchEvent(MotionEvent event) {
        dragHelper.processTouchEvent(event); //把事件叫给dragHelper 处理
        return true;
    }

    private ViewDragHelper.Callback callback = new ViewDragHelper.Callback() {
        //用于判断,是否捕获当前child的触摸事件
        // child:当前的子View
        // return : true; 就获得并解析  false不处理
        @Override
        public boolean tryCaptureView(View child, int pointerId) {
            return main == child;
        }

        //控制child 在水平方向的滚动
        //left 表示ViewDragHelper 认为你想让当前child的left改变的值 left = child.getLeft+dx
        //dx 本次child在水平方向的距离
        //return 表示你真正想让child的left 变成的值
        @Override
        public int clampViewPositionHorizontal(@NonNull View child, int left, int dx) {
            return left;
        }

        //手指抬起的方法 相当与 Motion.Action_Up
        //Params releasedChild 当前抬起的view
        //xvel x 方向移动的速度    正 为向右移动 负 为向左移动
        // yvel y 方向 移动的速度  正 为向下移动 负 为向 上移动
        @Override
        public void onViewReleased(@NonNull View releasedChild, float xvel, float yvel) {
            super.onViewReleased(releasedChild, xvel, yvel);
            if (main.getLeft() < 500) {
                //关闭菜单的效果
                dragHelper.smoothSlideViewTo(main,0,0);
                ViewCompat.postInvalidateOnAnimation(MyDrawViewGroup.this);

            } else {
                //打开查单
                dragHelper.smoothSlideViewTo(main,260,0);
                ViewCompat.postInvalidateOnAnimation(MyDrawViewGroup.this); //实现一个重绘的功能
            }

        }
    };

    //初始化子View的引用 当ViewGroup 的xml结束标签被读取完成,会执行该方法
    //此时会知道自己有几个子控件
    //onFinishInflate() 方法一般用来初始化子控件
    @Override
    protected void onFinishInflate() {
        super.onFinishInflate();
        menu = getChildAt(0);
        main = getChildAt(1);

    }

    private void initView() {
        dragHelper = ViewDragHelper.create(this, callback);
    }

    @Override
    protected void onLayout(boolean changed, int l, int t, int r, int b) {
        super.onLayout(changed, l, t, r, b);
    }


}

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值