android自定义滚动上下回弹scollView

 更新时间:2022年04月19日 10:04:41   作者:梦天2015  
这篇文章主要为大家详细介绍了android自定义滚动上下回弹scollView,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了android自定义滚动上下回弹scollView的具体代码,供大家参考,具体内容如下

这是一个自定义view,在xml布局中用这个view嵌套要使之可以上下回弹的view

就能实现布局可以滚动上下回弹了,自定义view代码如下:

package com.loopfire.meitaotao.view.scrollView;
 
import android.content.Context;
import android.graphics.Rect;
import android.util.AttributeSet;
import android.view.MotionEvent;
import android.view.View;
import android.view.animation.Animation;
import android.view.animation.Animation.AnimationListener;
import android.view.animation.TranslateAnimation;
import android.widget.ScrollView;
 
/**
 * 上下回弹 scollView
 * 
 * @author Administrator
 * 
 */
public class MyScrollView extends ScrollView {
    private View inner;
    private float y;
    private Rect normal = new Rect();
    private boolean animationFinish = true;
 
    public MyScrollView(Context context) {
        super(context);
    }
 
    public MyScrollView(Context context, AttributeSet attrs) {
        super(context, attrs);
    }
 
    @Override
    protected void onFinishInflate() {
        if (getChildCount() > 0) {
            inner = getChildAt(0);
        }
    }
 
    @Override
    public boolean onInterceptTouchEvent(MotionEvent ev) {
        return super.onInterceptTouchEvent(ev);
    }
 
    @Override
    public boolean onTouchEvent(MotionEvent ev) {
        if (inner == null) {
            return super.onTouchEvent(ev);
        } else {
            commOnTouchEvent(ev);
        }
        return super.onTouchEvent(ev);
    }
 
    private void commOnTouchEvent(MotionEvent ev) {
        if (animationFinish) {
            int action = ev.getAction();
            switch (action) {
            case MotionEvent.ACTION_DOWN:
                // System.out.println("ACTION_DOWN");
                y = ev.getY();
                super.onTouchEvent(ev);
                break;
            case MotionEvent.ACTION_UP:
                // System.out.println("ACTION_UP");
                y = 0;
                if (isNeedAnimation()) {
                    animation();
                }
                super.onTouchEvent(ev);
                break;
            case MotionEvent.ACTION_MOVE:
                // System.out.println("ACTION_MOVE");
                final float preY = y == 0 ? ev.getY() : y;
                float nowY = ev.getY();
                int deltaY = (int) (preY - nowY);
                // 滚动
                // scrollBy(0, deltaY);
 
                y = nowY;
                // 当滚动到最上或者最下时就不会再滚动,这时移动布局
                if (isNeedMove()) {
                    if (normal.isEmpty()) {
                        // 保存正常的布局位置
                        normal.set(inner.getLeft(), inner.getTop(), inner.getRight(), inner.getBottom());
                    }
                    // 移动布局
                    inner.layout(inner.getLeft(), inner.getTop() - deltaY / 2, inner.getRight(), inner.getBottom() - deltaY / 2);
                } else {
                    super.onTouchEvent(ev);
                }
                break;
            default:
                break;
            }
        }
    }
 
    // 开启动画移动
 
    private void animation() {
        // 开启移动动画
        TranslateAnimation ta = new TranslateAnimation(0, 0, 0, normal.top - inner.getTop());
        ta.setDuration(200);
        ta.setAnimationListener(new AnimationListener() {
            @Override
            public void onAnimationStart(Animation animation) {
                animationFinish = false;
 
            }
 
            @Override
            public void onAnimationRepeat(Animation animation) {
 
            }
 
            @Override
            public void onAnimationEnd(Animation animation) {
                inner.clearAnimation();
                // 设置回到正常的布局位置
                inner.layout(normal.left, normal.top, normal.right, normal.bottom);
                normal.setEmpty();
                animationFinish = true;
            }
        });
        inner.startAnimation(ta);
    }
 
    // 是否需要开启动画
    private boolean isNeedAnimation() {
        return !normal.isEmpty();
    }
 
    // 是否需要移动布局
    private boolean isNeedMove() {
        int offset = inner.getMeasuredHeight() - getHeight();
        int scrollY = getScrollY();
        if (scrollY == 0 || scrollY == offset) {
            return true;
        }
        return false;
    }
 
}

在xml中使用如下:

<com.loopfire.meitaotao.view.scrollView.MyScrollView>
           <TextView
              style="@style/form_left_text_style"
              android:layout_width="wrap_content"
              android:layout_height="wrap_content"
              android:layout_marginLeft="@dimen/text_margin_left2"
              android:text="@string/about" />
</com.loopfire.meitaotao.view.scrollView.MyScrollView>

那么包含的这个textview可以上下滚动并且回弹了

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • Android自定义相机实现自动对焦和手动对焦

    Android自定义相机实现自动对焦和手动对焦

    这篇文章主要为大家详细介绍了android手动实现相机自动和手动对焦功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-12-12
  • Android 实现云知声版离线语音合成

    Android 实现云知声版离线语音合成

    这篇文章主要介绍了Android 实现云知声版离线语音合成,目前云知声提供免费的离线TTS,功能也比较简单,合成的语音也比较生硬,如果对合成的语音要求不高的话可以考虑接入。具体合成需要的小伙伴可以参考下面文章内容
    2022-06-06
  • Android中Bitmap、File与Uri之间的简单记录

    Android中Bitmap、File与Uri之间的简单记录

    这篇文章主要给大家介绍了关于Android中Bitmap、File与Uri之间的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-02-02
  • android多种滑动冲突的解决方案

    android多种滑动冲突的解决方案

    本篇文章主要介绍了android多种滑动冲突的解决方案,解决方案主要有2种,外部拦截法 和内部拦截法,有兴趣的可以了解一下。
    2017-02-02
  • Flutter 全局点击空白处隐藏键盘实战

    Flutter 全局点击空白处隐藏键盘实战

    这篇文章主要介绍了Flutter 全局点击空白处隐藏键盘实战,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09
  • Android实现拼图游戏

    Android实现拼图游戏

    这篇文章主要为大家详细介绍了Android实现拼图小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • Android Service控件用法实例分析

    Android Service控件用法实例分析

    这篇文章主要介绍了Android Service控件用法,较为详细的分析了Service控件的功能、定义、使用方法与注意事项,需要的朋友可以参考下
    2016-06-06
  • Android中TimePicker与DatePicker时间日期选择组件的使用实例

    Android中TimePicker与DatePicker时间日期选择组件的使用实例

    这篇文章主要介绍了Android中TimePicker时间选择与DatePicker日期选择组件的使用实例,这两个组件加上去的效果就是我们平时在iOS上设置闹钟时调整时间类似的滚动选项,需要的朋友可以参考下
    2016-04-04
  • Android实现键盘弹出界面上移的实现思路

    Android实现键盘弹出界面上移的实现思路

    这篇文章主要介绍了Android实现键盘弹出界面上移的实现思路,需要的朋友可以参考下
    2018-04-04
  • Android OpenGL ES 实现抖音传送带特效(原理解析)

    Android OpenGL ES 实现抖音传送带特效(原理解析)

    这篇文章主要介绍了Android OpenGL ES 实现抖音传送带特效,抖音传送带特效推出已经很长一段时间了,前面也实现了下,最近把它整理出来了,如果你有仔细观测传送带特效,就会发现它的实现原理其实很简单,需要的朋友可以参考下
    2022-07-07

最新评论