自定义scrollview 回弹效果

前言

自定义scrollview 下拉回弹效果

效果图

自定义scrollview 回弹效果_第1张图片

获取内部控件

    //获取初始控件
    @Override
    protected void onFinishInflate() {
        super.onFinishInflate();
        //由于是scrollview 内部只能有一个控件
        convertView = getChildAt(0);
    }

记录初始位置


    @Override
    protected void onLayout(boolean changed, int l, int t, int r, int b) {
        super.onLayout(changed, l, t, r, b);
        //用rect记录 scrollview的子控件的上下左右
        originalRect.set(convertView.getLeft(), convertView.getTop(), convertView.getRight(), convertView.getBottom());

    }

事件分发

//
@Override
    @Override
    public boolean dispatchTouchEvent(MotionEvent ev) {
        switch (ev.getAction()) {
            case MotionEvent.ACTION_DOWN:
                startY = (int) ev.getY();
                startX = (int) ev.getX();
                break;

            case MotionEvent.ACTION_UP:
                //还原位置,回弹动画, 可以自己定于需要的动画
                TranslateAnimation animation = new TranslateAnimation(0, 0, convertView.getTop(), originalRect.top);
                animation.setDuration(200);
                convertView.setAnimation(animation);
                convertView.layout(originalRect.left, originalRect.top, originalRect.right, originalRect.bottom);

                break;

            case MotionEvent.ACTION_MOVE:

                int detalY = (int) (ev.getY() - startY);
                int detalX = (int) (ev.getX() - startX);

                if (Math.abs(detalX) < Math.abs(detalY)) {
                    //detalY 乘以0.2 使得很难的效果
                    convertView.layout(originalRect.left, (int) (originalRect.top + detalY * 0.2),
                            originalRect.right, (int) (originalRect.bottom + detalY * 0.2));
                }
                break;

        }

        return super.dispatchTouchEvent(ev);
    }

end

整体代码量挺少,主要是记录了控件的初始位置,和事件分发dispatchTouchEvent的重写。

你可能感兴趣的:(android)