修改一个值,让ScrollView、ListView充满弹性

android默认的ScrollView、ListView在最顶端下拉或者最底端上拉的时候,都不会带有反弹效果,很生硬的让你不能继续拖动,记得不像iOS那样可以回弹,个人认为,iOS的交互还是略好一点,那么我们也来在Android下实现下这个功能。


先看下效果图:


注:记得当时在android系统2.3前,默认的ScrollView、ListView都支持下拉回弹效果的,但后来被苹果买断版权。(记得大学时口袋里穷叮当响,用仅剩的560元买了个杂牌的android手机,那时的系统是2.3的,目前仍然用来测试各种布局和界面效果,里面的ScrollView、ListView是可以回弹的


今天的目标是一句话实现ScrollView、ListView下拉回弹效果,如何去做呢?


先看下代码:

  1. package com.xys.flexible;  
  2.   
  3. import android.content.Context;  
  4. import android.util.AttributeSet;  
  5. import android.util.DisplayMetrics;  
  6. import android.widget.ScrollView;  
  7.   
  8. public class FlexibleScrollView extends ScrollView {  
  9.   
  10.     private Context mContext;  
  11.     private static int mMaxOverDistance = 50;  
  12.   
  13.     public FlexibleScrollView(Context context, AttributeSet attrs,  
  14.             int defStyleAttr) {  
  15.         super(context, attrs, defStyleAttr);  
  16.         this.mContext = context;  
  17.         initView();  
  18.     }  
  19.   
  20.     public FlexibleScrollView(Context context, AttributeSet attrs) {  
  21.         super(context, attrs);  
  22.         this.mContext = context;  
  23.         initView();  
  24.     }  
  25.   
  26.     public FlexibleScrollView(Context context) {  
  27.         super(context);  
  28.         this.mContext = context;  
  29.         initView();  
  30.     }  
  31.   
  32.     private void initView() {  
  33.         DisplayMetrics metrics = mContext.getResources().getDisplayMetrics();  
  34.         float density = metrics.density;  
  35.         mMaxOverDistance = (int) (density * mMaxOverDistance);  
  36.     }  
  37.   
  38.     @Override  
  39.     protected boolean overScrollBy(int deltaX, int deltaY, int scrollX,  
  40.             int scrollY, int scrollRangeX, int scrollRangeY,  
  41.             int maxOverScrollX, int maxOverScrollY, boolean isTouchEvent) {  
  42.         return super.overScrollBy(deltaX, deltaY, scrollX, scrollY,  
  43.                 scrollRangeX, scrollRangeY, maxOverScrollX, mMaxOverDistance,  
  44.                 isTouchEvent);  
  45.     }  
  46. }  

其实我们虽然重写了ScrollView(或者ListView),但是只改了它的一个方法的一个值!

也就是将overScrollBy中的maxOverScrollY改成了我们自己写的值。


测试布局:

  1. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  2.     xmlns:tools="http://schemas.android.com/tools"  
  3.     android:layout_width="match_parent"  
  4.     android:layout_height="match_parent"  
  5.     android:paddingBottom="@dimen/activity_vertical_margin"  
  6.     android:paddingLeft="@dimen/activity_horizontal_margin"  
  7.     android:paddingRight="@dimen/activity_horizontal_margin"  
  8.     android:paddingTop="@dimen/activity_vertical_margin"  
  9.     tools:context=".MainActivity" >  
  10.   
  11.     <com.xys.flexible.FlexibleScrollView  
  12.         android:layout_width="match_parent"  
  13.         android:layout_height="match_parent"  
  14.         android:text="@string/hello_world" >  
  15.   
  16.         <TextView  
  17.             android:id="@+id/tv"  
  18.             android:layout_width="fill_parent"  
  19.             android:layout_height="wrap_content"  
  20.             android:text="......我是字符串......\n......我是字符串......\n......我是字符串......\n......我是字符串......\n......我是字符串......\n......我是字符串......\n......我是字符串......\n......我是字符串......\n......我是字符串......\n......我是字符串......\n......我是字符串......\n......我是字符串......\n......我是字符串......\n......我是字符串......\n......我是字符串......\n......我是字符串......\n......我是字符串......\n......我是字符串......\n......我是字符串......\n......我是字符串......\n......我是字符串......\n......我是字符串......\n......我是字符串......\n......我是字符串......\n......我是字符串......\n......我是字符串......\n......我是字符串......\n......我是字符串......\n......我是字符串......\n......我是字符串......\n......我是字符串......\n......我是字符串......\n......我是字符串......\n" />  
  21.     </com.xys.flexible.FlexibleScrollView>  
  22.   
  23. </RelativeLayout>  

默认的maxOverScrollY=0,所以我们看不见任何效果,只要改为>0的值,就有效果了

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值