android studio 横向拖动条,Android ScrollView实现横向和竖向拖动回弹效果

本文实例为大家分享了Android ScrollView实现拖动回弹效果的具体代码,供大家参考,具体内容如下

原理

在android2.3版本中,View类中新增了一个方法:overScrollBy。通过覆盖该方法,就可以达到阻尼回弹的效果。

示例1、竖向滚动

public class ReboundScrollView extends ScrollView{

private static final int MAX_SCROLL = 200;

private static final float SCROLL_RATIO = 0.5f;// 阻尼系数

public ReboundScrollView(Context context)

{

super(context);

}

public ReboundScrollView(Context context, AttributeSet attrs)

{

super(context, attrs);

}

public ReboundScrollView(Context context, AttributeSet attrs, int defStyle)

{

super(context, attrs, defStyle);

}

@Override

protected boolean overScrollBy(int deltaX, int deltaY, int scrollX, int scrollY, int scrollRangeX, int scrollRangeY, int maxOverScrollX, int maxOverScrollY, boolean isTouchEvent)

{

int newDeltaY = deltaY;

int delta = (int) (deltaY * SCROLL_RATIO);

if((scrollY+deltaY)==0 || (scrollY-scrollRangeY+deltaY)==0){

newDeltaY = deltaY; //回弹最后一次滚动,复位

}else{

newDeltaY = delta; //增加阻尼效果

}

return super.overScrollBy(deltaX, newDeltaY, scrollX, scrollY, scrollRangeX, scrollRangeY, maxOverScrollX, MAX_SCROLL, isTouchEvent);

}

}

示例2、横向滚动

public class ReboundHScrollView extends HorizontalScrollView{

private static final int MAX_SCROLL = 200;

private static final float SCROLL_RATIO = 0.5f;// 阻尼系数

public ReboundHScrollView(Context context)

{

super(context);

}

public ReboundHScrollView(Context context, AttributeSet attrs)

{

super(context, attrs);

}

public ReboundHScrollView(Context context, AttributeSet attrs, int defStyle)

{

super(context, attrs, defStyle);

}

@Override

protected boolean overScrollBy(int deltaX, int deltaY, int scrollX, int scrollY, int scrollRangeX, int scrollRangeY, int maxOverScrollX, int maxOverScrollY, boolean isTouchEvent)

{

int newDeltaX = deltaX;

int delta = (int) (deltaX * SCROLL_RATIO);

if((scrollX+deltaX)==0 || (scrollX-scrollRangeX+deltaX)==0){

newDeltaX = deltaX; //回弹最后一次滚动,复位

}else{

newDeltaX = delta; //增加阻尼效果

}

return super.overScrollBy(newDeltaX, deltaY, scrollX, scrollY, scrollRangeX, scrollRangeY, MAX_SCROLL, maxOverScrollY, isTouchEvent);

}

}

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值