android ScrollView ListView的回弹效果

平常我们在使用ScrollView或者ListView的时候,最终的效果在各个系统上并不相同,有的系统支持滑动到顶后能后还能继续向下滑动一段距离,比如魅族的系统,这样可以很清晰的提示用户到达边界,但是有的系统,比如MIUI并不支持,其实android系统默认是支持这种滑动方式的,就在函数:

[java]  view plain copy
  1. protected boolean overScrollBy(int deltaX, int deltaY, int scrollX, int scrollY, int scrollRangeX, int scrollRangeY, int maxOverScrollX, int maxOverScrollY, boolean isTouchEvent)  


这个函数是定义在View中的,在滑动到边界的时候系统会调用这个函数
其中maxOverScrollX和maxOVerScrollY为超出边界的最大值,但是系统默认值是0,既不会超出边界,有些定制过得系统会修改此值,就实现了回弹的效果


我们要实现这种回弹效果,只要继承ScrollView或者ListView,重写 overScrollBy 方法,修改参数即可,下面以ListView为例

[java]  view plain copy
  1. package com.example.test;  
  2.   
  3. import android.content.Context;  
  4. import android.util.AttributeSet;  
  5. import android.widget.ListView;  
  6.   
  7. public class ScrollBackListView extends ListView{    
  8.     private static final int MAX_SCROLL = 200;    
  9.     private static final float SCROLL_RATIO = 0.5f;// 阻尼系数  
  10.          
  11.     private Context mContext;    
  12.          
  13.     public ScrollBackListView(Context context){    
  14.         super(context);    
  15.         mContext = context;    
  16.     }    
  17.          
  18.     public ScrollBackListView(Context context, AttributeSet attrs){    
  19.         super(context, attrs);    
  20.         mContext = context;    
  21.     }    
  22.          
  23.     public ScrollBackListView(Context context, AttributeSet attrs, int defStyle){    
  24.         super(context, attrs, defStyle);    
  25.         mContext = context;    
  26.     }    
  27.          
  28.     @Override    
  29.     protected boolean overScrollBy(int deltaX, int deltaY, int scrollX, int scrollY, int scrollRangeX, int scrollRangeY, int maxOverScrollX, int maxOverScrollY, boolean isTouchEvent){     
  30.         int newDeltaY = deltaY;  
  31.         int delta = (int) (deltaY * SCROLL_RATIO);  
  32.         if (delta != 0) newDeltaY = delta;  
  33.         return super.overScrollBy(deltaX, newDeltaY, scrollX, scrollY, scrollRangeX, scrollRangeY, maxOverScrollX, MAX_SCROLL, isTouchEvent);      
  34.     }  
  35. }  


其中deltaX,deltaY为本次滑动偏移,scrollX,scrollY为当前总偏移,我们可以给deltaY乘以一个小数来达到一种阻尼的效果


结果截图:

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值