【Android实战】ListView的回弹效果实现

/**
 * 弹性listView。 
 * 注意,当且仅当在列表项目够多可占满一个屏幕以上时才能显现出弹性效果。
 */
public class ElasticListView extends ListView {

    /**
     * 初始可拉动Y轴方向距离
     */
    private static final int MAX_Y_OVERSCROLL_DISTANCE = 120;

    // 实际可上下拉动Y轴上的距离
    private int distance;

    public ElasticListView(Context context) {
        super(context);
        initWidget();
    }

    public ElasticListView(Context context, AttributeSet attrs) {
        super(context, attrs);
        initWidget();
    }

    public ElasticListView(Context context, AttributeSet attrs, int defStyle) {
        super(context, attrs, defStyle);
        initWidget();
    }

    private void initWidget() {
        // 初始化参数
        DisplayMetrics metrics = getContext().getResources().getDisplayMetrics();
        float density = metrics.density;
        distance = (int) (density * MAX_Y_OVERSCROLL_DISTANCE);
    }

    /* 拓展:弹性 */

    @Override
    protected boolean overScrollBy(int deltaX, int deltaY, int scrollX, int scrollY,
            int scrollRangeX, int scrollRangeY, int maxOverScrollX, int maxOverScrollY,
            boolean isTouchEvent) {
        // 实现的本质就是在这里动态改变了maxOverScrollY的值
        return super.overScrollBy(deltaX, deltaY, scrollX, scrollY, scrollRangeX, scrollRangeY,
                maxOverScrollX, distance, isTouchEvent);
    }

}

如何使用那,很简单!

  <com.storm.durian.view.ElasticListView
            android:id="@+id/fragment_hot_live_listview"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:paddingLeft="6dp"
            android:paddingRight="6dp"
            android:paddingTop="6dp"
            android:divider="@color/ececec"
            android:dividerHeight="6dp"
        	 />


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值