android ListView阻尼效果
2014-02-08 16:43
197 查看
微信聊天界面聊天记录当被拉到低后还是可以继续向上滑的效果
查找资料以后发现是阻尼效果,整理一下代码
import android.annotation.SuppressLint;
import android.content.Context;
import android.util.AttributeSet;
import android.util.DisplayMetrics;
import android.widget.ListView;
public class BounceListView extends ListView {
private static final int MAX_Y_OVERSCROLL_DISTANCE = 1000;
private Context mContext;
private int mMaxYOverscrollDistance;
public BounceListView(Context context){
super(context);
mContext = context;
initBounceListView();
}
public BounceListView(Context context, AttributeSet attrs){
super(context, attrs);
mContext = context;
initBounceListView();
}
public BounceListView(Context context, AttributeSet attrs, int defStyle){
super(context, attrs, defStyle);
mContext = context;
initBounceListView();
}
private void initBounceListView(){
//get the density of the screen and do some maths with it on the max overscroll distance
//variable so that you get similar behaviors no matter what the screen size
final DisplayMetrics metrics = mContext.getResources().getDisplayMetrics();
final float density = metrics.density;
mMaxYOverscrollDistance = (int) (density * MAX_Y_OVERSCROLL_DISTANCE);
}
@SuppressLint("NewApi")
@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, mMaxYOverscrollDistance, isTouchEvent);
}
}
查找资料以后发现是阻尼效果,整理一下代码
import android.annotation.SuppressLint;
import android.content.Context;
import android.util.AttributeSet;
import android.util.DisplayMetrics;
import android.widget.ListView;
public class BounceListView extends ListView {
private static final int MAX_Y_OVERSCROLL_DISTANCE = 1000;
private Context mContext;
private int mMaxYOverscrollDistance;
public BounceListView(Context context){
super(context);
mContext = context;
initBounceListView();
}
public BounceListView(Context context, AttributeSet attrs){
super(context, attrs);
mContext = context;
initBounceListView();
}
public BounceListView(Context context, AttributeSet attrs, int defStyle){
super(context, attrs, defStyle);
mContext = context;
initBounceListView();
}
private void initBounceListView(){
//get the density of the screen and do some maths with it on the max overscroll distance
//variable so that you get similar behaviors no matter what the screen size
final DisplayMetrics metrics = mContext.getResources().getDisplayMetrics();
final float density = metrics.density;
mMaxYOverscrollDistance = (int) (density * MAX_Y_OVERSCROLL_DISTANCE);
}
@SuppressLint("NewApi")
@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, mMaxYOverscrollDistance, isTouchEvent);
}
}
相关文章推荐
- Android 带阻尼效果的ListView
- android的阻尼效果-ListView添加阻尼效果的HeadView
- Android UI设计系列之自定义ListView仿QQ空间阻尼下拉刷新和渐变菜单栏效果(8)
- Android回弹阻尼效果的简单实现,非基于ListView,ScrollView
- android listview 去掉阻尼效果
- Android使用最简单的方式实现ListView 拉出回弹效果,阻尼效果(一)
- Android UI设计之<十>自定义ListView,实现QQ空间阻尼下拉刷新和渐变菜单栏效果
- Android仿QQ消息列表ListView滑动删除效果
- Android 使用NineOldAndroids实现绚丽的ListView左右滑动删除Item效果
- Android的ExpandableListView的动画展开效果和使用traceview的性能优化
- android仿通讯录ListView效果
- android listview 不显示选中效果分析
- android listview仿ios 3dTouch效果
- android 自定义ScrollView实现反弹效果(以及解决和ListView之间的冲突)
- Android 实现ListView的滑动删除效果--SwipeListView
- Android编程实现带有图标的ListView并带有长按菜单效果示例
- Android 横向带有吸附效果的横向拖动控件(效果同纵向下拉刷新ListView)
- android 怎么给listview添加一个固定表头以及显示像table的效果
- Android使用ListView实现滚轮的动画效果实例
- Android 三种布局实现上下回弹效果(普通布局,ListView,ScrollView)