listView 的回弹overScrollBy

本文介绍如何通过重写ListView的overScrollBy()方法来实现带有弹性效果的ListView。通过设置自定义的最大偏移距离mMaxOverDistance,可以控制ListView在达到边界时的滑动行为。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


ListView有一个控制滑动到边缘的处理方法

代码:

@Override
	protected boolean overScrollBy(int deltaX,int deltaY,int scrollX, int scrollY, int scrollRangeX,int scrollRangeY, int maxOverScrollX,
			int maxOverScrollY, boolean isTouchEvent){ 
		//maxOverScrollY---Number of pixels to overscroll by in either direction along the Y axis 即:默认值为0
		return super.overScrollBy(deltaX, deltaY, scrollX, scrollY,scrollRangeX, scrollRangeY, maxOverScrollX,maxOverScrollY,isTouchEvent);  
	}


重写ListView的overScrollBy()实现 具有弹性的ListView,

代码如下:

<pre name="code" class="java">public class MyListView extends ListView{
	private Context context;

	public MyListView(Context context, AttributeSet attrs, int defStyle) {
		super(context, attrs, defStyle);
		// TODO Auto-generated constructor stub
		this.context = context;
	}

	public MyListView(Context context, AttributeSet attrs) {
		this(context,attrs,0);
		// TODO Auto-generated constructor stub
	}

	public MyListView(Context context) {
		this(context,null);
		// TODO Auto-generated constructor stub
	}
	private   int mMaxOverDistance = 120;
	@Override
	protected boolean overScrollBy(int deltaX,int deltaY,int scrollX, int scrollY, int scrollRangeX,int scrollRangeY, int maxOverScrollX,
			int maxOverScrollY, boolean isTouchEvent){ 
		//This is where the magic happens, we have replaced the incoming maxOverScrollY with our own custom variable mMaxYOverscrollDistance; 
		return super.overScrollBy(deltaX, deltaY, scrollX, scrollY,scrollRangeX, scrollRangeY, maxOverScrollX, mMaxOverDistance, isTouchEvent);  
	}
	


}







                
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值