当滑动到顶部和底部时,实现Item的分离效果的ListView

这个博客介绍了一个自定义的PullSeparateListView,当滑动到顶部或底部时,Item之间会分离并有动画效果。通过设置属性可以控制是否全部分离和显示按下的Item动画。
摘要由CSDN通过智能技术生成
拉动ListView,Item之间的间距会变大,释放后恢复原样;

package cn.tangdada.tangbang.widget;

import android.annotation.TargetApi;
import android.content.Context;
import android.content.res.TypedArray;
import android.graphics.drawable.BitmapDrawable;
import android.os.Build;
import android.util.AttributeSet;
import android.view.MotionEvent;
import android.view.View;
import android.view.ViewConfiguration;
import android.view.animation.AccelerateInterpolator;
import android.widget.AbsListView;
import android.widget.ListView;
import cn.tangdada.tangbang.R;

import com.nineoldandroids.view.ViewPropertyAnimator;

/**
 * 当滑动到顶部和底部时,实现Item的分离效果。
 * 
 * @author pythoner
 * 
 */
@TargetApi(Build.VERSION_CODES.HONEYCOMB)
public class PullSeparateListView extends ListView
{
    /**
     * 最大滑动距离
     */
    private static final float MAX_DELTAY = 100;

    /**
     * 分离后恢复的动画时长
     */
    private static final long SEPARATE_RECOVER_DURATION = 200;

    /**
     * 摩擦系数
     */
    private static final float FACTOR = 0.25f;

    /**
     * 按下x的缩放比例
     */
    private static final float SCALEX = 1.0f;

    /**
     * 按下y的缩放比例
     */
    private static final float SCALEY = 1.0f;

    /**
     * 展开全部
     */
    private boolean separateAll;

    /**
     * 到达边界时,滑动的起始位置
     */
    private float startY;

    /**
     * 按下时的View
     */
    private View downView;

    private int touchSlop;

    private boolean separate = false;

    private boolean showDownAnim;

    /**
     * 原始按下位置(在所有Item中的位置)
     */
    private int originDownPosition;

    /**
     * 按下的位置(在屏幕中的位置)
     */
    private int downPosition;

    /**
     * 上次滑动的位置,用于判断方向
     */
    private float preY;

    private float deltaY;

    private boolean reachTop, reachBottom, move;

    private OnScrollListener mScrollListener;

    public PullSeparateListView(Context context, AttributeSet attrs)
    {
        super(context, attrs);
        TypedArray t = context.obtainStyledAttributes(attrs, R.styleable.PullSeparateListView);
        separateAll = t.getBoolean(R.styleable.PullSeparateListView_separate_all, false);
        showDownAnim = t.getBoolean(R.styleable.PullSeparateListView_showDownAnim, true);
        t.recycle();
        init();
    }

    public PullSeparateListView(Context context, AttributeSet attrs, int defStyle)
    {
        super(context, attrs, defStyle);
        init();
    }

    public PullSeparateListView(Context context)
    {
        super(context);
        init();
    }

    @SuppressWarnings("deprecation")
    private void init()
    {
        // 不知道怎么让divider和selector和Item一起移动,所以去除,需要自己加分割线
        this.setDivider(null);
        this.setSelector(new BitmapDrawabl
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值