似乎三星已经禁用了他们的overscroll(可能是因为苹果的诉讼)。
我有一个扩展ScrollView
和覆盖的视图的实现
protected boolean overScrollBy(int deltaX, int deltaY, int scrollX, int scrollY, int scrollRangeX, int scrollRangeY,int maxOverScrollX, int maxOverScrollY, boolean isTouchEvent)
{
...
return super.overScrollBy(deltaX, deltaY, scrollX, scrollY, scrollRangeX, scrollRangeY, 0, metrics.widthPixels,isTouchEvent);
}
在每一个其他设备(当然是姜饼和更高版本)上,当滚动条到达它的末端时,
overScrollBy
被调用,用户实际上可以对视图进行覆盖。在android 2.3.5+上,三星已经实现了某种完全禁用overscroll的机制(不仅是overscroll的实现,也是android的实现),每次用户尝试overscroll时,都会打印以下logcat事件:
02-13 16:02:34.230: D/BounceScrollRunnableDefault(15783): run(), TimeFraction=0.5225, mBounceExtent=7.273352
有没有办法解开三星在那里做的事情?或者用另一种方法来创建一个overscroller?
最佳答案
我只是遇到了同样的问题,最后提出了以下自定义overscroll检测:
listView.setOnTouchListener(new OnTouchListener() {
private static final float OVERSCROLL_THRESHOLD_IN_PIXELS = 70;
private float downY;
@Override
public boolean onTouch(View v, MotionEvent event) {
int firstVisibleItem = listView.getFirstVisiblePosition();
int totalItemCount = listView.getCount();
int visibleItemCount = listView.getChildCount();
boolean onTop = firstVisibleItem == 0 && listView.getChildAt(0) != null && listView.getChildAt(0).getTop() == 0;
boolean onBottom = firstVisibleItem + visibleItemCount == totalItemCount && listView.getChildAt(visibleItemCount-1).getBottom() == listView.getHeight();
if(onTop || onBottom) {
switch(event.getAction()) {
case MotionEvent.ACTION_DOWN:
downY = event.getY();
break;
case MotionEvent.ACTION_MOVE:
float deltaY = event.getY() - downY;
if(onTop && deltaY > OVERSCROLL_THRESHOLD_IN_PIXELS) {
// Top overscroll
}
if(onBottom && -deltaY > OVERSCROLL_THRESHOLD_IN_PIXELS) {
// Bottom overscroll
}
break;
}
}
return false;
}
});