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);    
    }
}





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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值