Android RecyclerView实现仿QQ侧滑删除效果

很简单的一个效果,就不多说了,全部代码贴上,复制即可使用。

1.自定义SlideRecyclerView,一个支持侧滑的RecyclerView

import android.content.Context;
import android.graphics.Rect;
import android.util.AttributeSet;
import android.util.Log;
import android.view.MotionEvent;
import android.view.VelocityTracker;
import android.view.View;
import android.view.ViewConfiguration;
import android.view.ViewGroup;
import android.widget.Scroller;

import androidx.annotation.Nullable;
import androidx.recyclerview.widget.LinearLayoutManager;
import androidx.recyclerview.widget.RecyclerView;

/**
 * 支持侧滑删除的RecyclerView
 */

public class SlideRecyclerView extends RecyclerView {

    private static final String TAG = "SlideRecyclerView";
    private static final int INVALID_POSITION = -1; // 触摸到的点不在子View范围内
    private static final int INVALID_CHILD_WIDTH = -1;  // 子ItemView不含两个子View
    private static final int SNAP_VELOCITY = 600;   // 最小滑动速度

    private VelocityTracker mVelocityTracker;   // 速度追踪器
    private int mTouchSlop; // 认为是滑动的最小距离(一般由系统提供)
    private Rect mTouchFrame;   // 子View所在的矩形范围
    private Scroller mScroller;
    private float mLastX;   // 滑动过程中记录上次触碰点X
    private float mFirstX, mFirstY; // 首次触碰范围
    private boolean mIsSlide;   // 是否滑动子View
    private boolean mIsShowSlideView;   // 是否显示子View
    private ViewGroup mFlingView;   // 触碰的子View
    private int mPosition;  // 触碰的view的位置
    private int mMenuViewWidth;    // 菜单按钮宽度
    private float xVelocityValue;

    public SlideRecyclerView(Context context) {
        this(context, null);
    }

    public SlideRecyclerView(Context context, @Nullable AttributeSet attrs) {
        this(context, attrs, 0);
    }

    public SlideRecyclerView(Context context, @Nullable AttributeSet attrs, int defStyle) {
        super(context, attrs, defStyle);
        mTouchSlop = ViewConfiguration.get(context).getScaledTouchSlop();
        mScroller = new Scroller(context);
    }

    @Override
    public boolean onInterceptTouchEvent(MotionEvent e) {
        int x = (int) e.getX();
        int y = (int) e.getY();
        obtainVelocity(e);
        switch (e.getAction()) {
            case MotionEvent.ACTION_DOWN:
                if (!mScroller.isFinished()) {  // 如果动画还没停止,则立即终止动画
                    mScroller.abortAnimation();
                }
                mFirstX = mLastX = x;
                mFirstY = y;
                mPosition = pointToPosition(x, y);  // 获取触碰点所在的position
                if (mPosition != INVALID_POSITION) {
                    View view = mFlingView;
                    // 获取触碰点所在的view
                    mFlingView = (ViewGroup) getChildAt(mPosition - ((LinearLayoutManager) getLayoutManager()).findFirstVisibleItemPosition());
                    // 这里判断一下如果之前触碰的view已经打开,而当前碰到的view不是那个view则立即关闭之前的view,此处并不需要担动画没完成冲突,因为之前已经abortAnimation
                    if (view != null && mFlingView != view && view.getScrollX() != 0) {
                        view.scrollTo(0, 0);
                    }
                    // 这里进行了强制的要求,RecyclerView的子ViewGroup必须要有2个子view,这样菜单按钮才会有值,
                    // 需要注意的是:如果不定制RecyclerView的子View,则要求子View必须要有固定的width。
                    // 比如使用LinearLayout作为根布局,而content部分width已经是match_parent,此时如果菜单view用的是wrap_content,menu的宽度就会为0。
                    if (mFlingView.getChildCount() == 2) {
                        mMenuViewWidth = mFlingView.getChildAt(1).getWidth();
                    } else {
                        mMenuViewWidth = INVALID_CHILD_WIDTH;
                    }
                }
                break;
            case MotionEvent.ACTION_MOVE:
                mVelocityTracker.computeCurrentVelocity(1000);
                // 此处有俩判断,满足其一则认为是侧滑:
                // 1.如果x方向速度大于y方向速度,且大于最小速度限制;
                // 2.如果x方向的侧滑距离大于y方向滑动距离,且x方向达到最小滑动距离;
                float xVelocity = mVelocityTracker.getXVelocity();
                xVelocityValue = xVelocity;
                float yVelocity = mVelocityTracker.getYVelocity();
                Log.d(TAG, "onInterceptTouchEvent: xVelocity:"+xVelocity);
                Log.d(TAG, "onInterceptTouchEvent: yVelocity:"+yVelocity);
                if (Math.abs(xVelocity) > SNAP_VELOCITY && Math.abs(xVelocity) > Math.abs(yVelocity)
                        || Math.abs(x - mFirstX) >= mTouchSlop
                        && Math.abs(x - mFirstX) > Math.abs(y - mFirstY)) {
                    mIsSlide = true;
                    return true;
                }
                break;
            case MotionEvent.ACTION_UP:
                releaseVelocity();
                break;
        }
        return super.onInterceptTouchEvent(e);
    }

    @Override
    public boolean onTouchEvent(MotionEvent e) {
        if (mIsSlide && mPosition != INVALID_POSITION) {
            float x = e.getX();
            obtainVelocity(e);
            switch (e.getAction()) {
                case MotionEvent.ACTION_DOWN:   // 因为没有拦截,所以不会被调用到
                    break;
                case MotionEvent.ACTION_MOVE:
                    // 随手指滑动
                    if (mMenuViewWidth != INVALID_CHILD_WIDTH) {
                        float dx = mLastX - x;
                        if (mFlingView.getScrollX() + dx <= mMenuViewWidth
                                && mFlingView.getScrollX() + dx > 0) {
                            mFlingView.scrollBy((int) dx, 0);
                        }
                        mLastX = x;
                    }
                    break;
                case MotionEvent.ACTION_UP:
                    if (mMenuViewWidth != INVALID_CHILD_WIDTH) {
                        int scrollX = mFlingView.getScrollX();
                        mVelocityTracker.computeCurrentVelocity(1000);
                        // 此处有两个原因决定是否打开菜单:
                        // 1.菜单被拉出宽度大于菜单宽度一半;
                        // 2.横向滑动速度大于最小滑动速度;
                        // 注意:之所以要小于负值,是因为向左滑则速度为负值
                        if (mVelocityTracker.getXVelocity() < -SNAP_VELOCITY) {    // 向左侧滑达到侧滑最低速度,则打开
                            mIsShowSlideView = true;
                            mScroller.startScroll(scrollX, 0, mMenuViewWidth - scrollX, 0, Math.abs(mMenuViewWidth - scrollX));
                        } else if (mVelocityTracker.getXVelocity() >= SNAP_VELOCITY) {  // 向右侧滑达到侧滑最低速度,则关闭
                            mIsShowSlideView = false;
                            mScroller.startScroll(scrollX, 0, -scrollX, 0, Math.abs(scrollX));
                        } else if (scrollX >= mMenuViewWidth / 2) { // 如果超过删除按钮一半,则打开
                            mIsShowSlideView = true;
                            mScroller.startScroll(scrollX, 0, mMenuViewWidth - scrollX, 0, Math.abs(mMenuViewWidth - scrollX));
                        } else {    // 其他情况则关闭
                            mIsShowSlideView = false;
                            mScroller.startScroll(scrollX, 0, -scrollX, 0, Math.abs(scrollX));
                        }
                        invalidate();
                    }
                    mMenuViewWidth = INVALID_CHILD_WIDTH;
                    mIsSlide = false;
                    mPosition = INVALID_POSITION;
                    releaseVelocity();  // 这里之所以会调用,是因为如果前面拦截了,就不会执行ACTION_UP,需要在这里释放追踪
                    break;
            }
            return true;
        } else {
            // 此处防止RecyclerView正常滑动时,还有菜单未关闭
            closeMenu();
            // Velocity,这里的释放是防止RecyclerView正常拦截了,但是在onTouchEvent中却没有被释放;
            // 有三种情况:1.onInterceptTouchEvent并未拦截,在onInterceptTouchEvent方法中,DOWN和UP一对获取和释放;
            // 2.onInterceptTouchEvent拦截,DOWN获取,但事件不是被侧滑处理,需要在这里进行释放;
            // 3.onInterceptTouchEvent拦截,DOWN获取,事件被侧滑处理,则在onTouchEvent的UP中释放。
            releaseVelocity();
        }
        return super.onTouchEvent(e);
    }

    private void releaseVelocity() {
        if (mVelocityTracker != null) {
            mVelocityTracker.clear();
            mVelocityTracker.recycle();
            mVelocityTracker = null;
        }
    }

    private void obtainVelocity(MotionEvent event) {
        if (mVelocityTracker == null) {
            mVelocityTracker = VelocityTracker.obtain();
        }
        mVelocityTracker.addMovement(event);
    }

    public int pointToPosition(int x, int y) {
        int firstPosition = ((LinearLayoutManager) getLayoutManager()).findFirstVisibleItemPosition();
        Rect frame = mTouchFrame;
        if (frame == null) {
            mTouchFrame = new Rect();
            frame = mTouchFrame;
        }

        final int count = getChildCount();
        for (int i = count - 1; i >= 0; i--) {
            final View child = getChildAt(i);
            if (child.getVisibility() == View.VISIBLE) {
                child.getHitRect(frame);
                if (frame.contains(x, y)) {
                    return firstPosition + i;
                }
            }
        }
        return INVALID_POSITION;
    }

    @Override
    public void computeScroll() {
        if (mScroller.computeScrollOffset()) {
            mFlingView.scrollTo(mScroller.getCurrX(), mScroller.getCurrY());
            invalidate();
        }
    }

    /**
     * 将显示子菜单的子view关闭
     * 这里本身是要自己来实现的,但是由于不定制item,因此不好监听器点击事件,因此需要调用者手动的关闭
     */
    public void closeMenu() {
        mIsShowSlideView = false;
        if (mFlingView != null && mFlingView.getScrollX() != 0) {
            mFlingView.scrollTo(0, 0);
        }
    }

    public boolean isShowSlideView() {
        return mIsShowSlideView;
    }
}

2.布局,要注意的是:item布局中的侧滑控件的总宽度要和自己添加的几个按钮的宽度之和要一致,不然就无法正常侧滑

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/root_view"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@color/white"
    android:orientation="vertical">

    <RelativeLayout
        android:id="@+id/rl_title"
        android:layout_width="match_parent"
        android:layout_height="49dp"
        android:background="@color/white"
        android:gravity="center|left"
        android:orientation="vertical">

        <LinearLayout
            android:id="@+id/ll_back"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_centerVertical="true">

            <ImageView
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_marginLeft="16dp"
                android:layout_marginRight="8dp"
                android:src="@mipmap/icon_back_arrow_left" />
        </LinearLayout>

        <TextView
            android:id="@+id/tv_title"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_centerInParent="true"
            android:text="选择摊玩红包"
            android:textColor="@color/black_333333"
            android:textSize="20sp" />

        <RelativeLayout
            android:id="@+id/rl_more"
            android:layout_width="60dp"
            android:layout_height="wrap_content"
            android:layout_alignParentRight="true"
            android:layout_centerVertical="true"
            android:visibility="gone">

            <ImageView
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_alignParentRight="true"
                android:layout_marginRight="16dp"
                android:src="@mipmap/icon_horizontal_more" />
        </RelativeLayout>

    </RelativeLayout>

    <androidx.core.widget.NestedScrollView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_below="@+id/rl_title"
        android:layout_marginBottom="65dp"
        android:background="@color/gray_F7F7F7">

        <RelativeLayout
            android:layout_width="match_parent"
            android:layout_height="match_parent">

            <LinearLayout
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:orientation="vertical">

                <TextView
                    android:id="@+id/tv_selected"
                    android:layout_width="match_parent"
                    android:layout_height="wrap_content"
                    android:layout_below="@+id/rl_title"
                    android:layout_marginLeft="16dp"
                    android:background="@color/gray_F7F7F7"
                    android:paddingTop="16dp"
                    android:paddingBottom="8dp"
                    android:text="可选择一张"
                    android:textColor="@color/gray_999"
                    android:textSize="12sp" />

                <LinearLayout
                    android:layout_width="match_parent"
                    android:layout_height="wrap_content"
                    android:layout_marginLeft="16dp"
                    android:layout_marginRight="16dp"
                    android:orientation="vertical">


                    <com.kuanghua.msgdyq.util.SlideRecyclerView
                        android:id="@+id/rvRedEnvelope"
                        android:layout_width="match_parent"
                        android:layout_height="wrap_content"
                        android:layout_gravity="center"
                        android:layout_marginTop="8dp"
                        android:paddingLeft="16dp"
                        android:paddingRight="16dp"
                        android:paddingBottom="16dp" />

                </LinearLayout>

            </LinearLayout>

        </RelativeLayout>

    </androidx.core.widget.NestedScrollView>

    <Button
        android:layout_width="match_parent"
        android:layout_height="40dp"
        android:layout_alignParentBottom="true"
        android:layout_marginLeft="16dp"
        android:layout_marginRight="16dp"
        android:layout_marginBottom="16dp"
        android:background="@drawable/login_button_blue_bg"
        android:text="确定"
        android:textColor="@color/white"
        android:textSize="16sp" />

</RelativeLayout>
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:id="@+id/ll_view"
    android:background="@color/white"
    android:orientation="horizontal">

    <RelativeLayout
        android:visibility="visible"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="?android:attr/selectableItemBackground"
        android:gravity="center_vertical"
        android:paddingBottom="12dp"
        android:paddingEnd="16dp"
        android:paddingStart="16dp"
        android:paddingTop="12dp">

        <TextView
            android:id="@+id/tv_quantity"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignParentEnd="true"
            android:layout_alignParentRight="true"
            android:layout_marginLeft="2dp"
            android:text="星期三"
            android:layout_marginStart="2dp"
            android:textColor="#FF34393F"
            android:textSize="12sp" />

        <TextView
            android:id="@+id/tv_item_desc"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:text="Android X"
            android:layout_toLeftOf="@id/tv_quantity"
            android:layout_toStartOf="@id/tv_quantity"
            android:textColor="#FF34393F"
            android:textSize="14sp" />

        <TextView
            android:id="@+id/tv_detail"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_below="@id/tv_item_desc"
            android:layout_marginTop="8dp"
            android:text="杭州"
            android:layout_toLeftOf="@+id/tv_volume"
            android:layout_toStartOf="@+id/tv_volume"
            android:textColor="#FFA3A5A8"
            android:textSize="12sp" />

        <TextView
            android:id="@+id/tv_volume"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignBottom="@id/tv_detail"
            android:layout_alignParentEnd="true"
            android:layout_alignParentRight="true"
            android:text="2023-08-09"
            android:layout_marginLeft="2dp"
            android:layout_marginStart="2dp"
            android:textColor="#FFA3A5A8"
            android:textSize="12sp" />

        <TextView
            android:id="@+id/tv_name"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"/>

    </RelativeLayout>

<!--    <TextView-->
<!--        android:id="@+id/tv_delete"-->
<!--        android:layout_width="60dp"-->
<!--        android:layout_height="match_parent"-->
<!--        android:background="#FFF55030"-->
<!--        android:gravity="center"-->
<!--        android:visibility="gone"-->
<!--        android:paddingEnd="16dp"-->
<!--        android:paddingStart="16dp"-->
<!--        android:text="删除"-->
<!--        android:textColor="#FFFFFFFF"-->
<!--        android:textSize="14sp" />-->

    <LinearLayout
        android:layout_width="240dp"
        android:layout_height="match_parent">

        <TextView
            android:id="@+id/tv_delete"
            android:layout_width="80dp"
            android:layout_height="match_parent"
            android:background="@color/blue_500"
            android:gravity="center"
            android:text="置顶"
            android:textColor="#FFFFFFFF"
            android:textSize="12sp" />

        <TextView
            android:layout_width="80dp"
            android:layout_height="match_parent"
            android:background="@color/orange_FF8B52"
            android:gravity="center"
            android:text="修改"
            android:textColor="#FFFFFFFF"
            android:textSize="12sp" />

        <TextView
            android:layout_width="80dp"
            android:layout_height="match_parent"
            android:background="#FFF55030"
            android:gravity="center"
            android:text="删除"
            android:textColor="#FFFFFFFF"
            android:textSize="12sp" />

<!--        <ImageView-->
<!--            android:id="@+id/im_delete"-->
<!--            android:layout_width="60dp"-->
<!--            android:layout_height="match_parent"-->
<!--            android:gravity="center"-->
<!--            android:paddingEnd="16dp"-->
<!--            android:paddingStart="16dp"-->
<!--            android:src="@mipmap/icon_wechat" />-->

<!--        <ImageView-->
<!--            android:layout_width="60dp"-->
<!--            android:layout_height="match_parent"-->
<!--            android:gravity="center"-->
<!--            android:paddingEnd="16dp"-->
<!--            android:paddingStart="16dp"-->
<!--            android:src="@mipmap/icon_alipay" />-->

    </LinearLayout>


</LinearLayout>

3.颜色:

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <color name="purple_200">#FFBB86FC</color>
    <color name="purple_500">#FF6200EE</color>
    <color name="purple_700">#FF3700B3</color>
    <color name="teal_200">#FF03DAC5</color>
    <color name="teal_700">#FF018786</color>
    <color name="black">#FF000000</color>
    <color name="black_333333">#333333</color>
    <color name="black_333333_30">#30333333</color>

    <color name="white">#FFFFFFFF</color>
    <color name="white_03">#30ffffff</color>

    <!--背景色-->
    <color name="bg_transparent">#00000000</color>

    <color name="blue_500">#62A5F1</color>
    <color name="blue_700">#336CDF</color>
    <color name="blue_E3EBFB">#E3EBFB</color>
    <color name="blue_1A3699">#1A3669</color>
    <color name="blue_4E5988">#4E5988</color>
    <color name="blue_0B1152">#0B1152 </color>
    <color name="blue_F3F4FF">#F3F4FF </color>
    <color name="blue_96B5F7">#96B5F7 </color>
    <color name="blue_9AB8FF">#9AB8FF </color>

    <color name="gray_f9f9f9">#F9F9F9</color>
    <color name="gray_F7F7F7">#F7F7F7</color>
    <color name="gray_666666">#666666</color>
    <color name="gray_999">#999999</color>
    <color name="gray_E5E5E5">#E5E5E5</color>
    <color name="gray_EBECED">#EBECED</color>
    <color name="gray_f6f6f6">#f6f6f6</color>
    <color name="gray_F9F8F9">#F9F8F9</color>
    <color name="grey_F9F9F9">#F9F9F9</color>
    <color name="grey_8080">#808080</color>
    <color name="grey_D8D8D8">#D8D8D8</color>
    <color name="grey_test">#d4d5d9</color>
    <color name="grey_CBCDDF">#CBCDDF</color>
    <color name="grey_FCFDFF">#FCFDFF</color>
    <color name="orange_FF4200">#FF4200</color>
    <color name="pink_FF4081">#FF4081</color>
    <color name="pink_FF4D4F">#FF4D4f</color>
    <color name="red_C20707">#C20707</color>

    <color name="gray_B7C6E6">#B7C6E6</color>

    <color name="orange_FF8B52">#FF8B52</color>
    <color name="orange_FF8B52_20">#22FF8B52</color>
</resources>

4.主函数

import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.LinearLayout;
import android.widget.TextView;

import androidx.recyclerview.widget.LinearLayoutManager;
import androidx.recyclerview.widget.RecyclerView;

import com.kuanghua.msgdyq.R;
import com.kuanghua.msgdyq.ui.adapter.ConfirmOrderAdapter;
import com.kuanghua.msgdyq.ui.adapter.RedEnvelopeAdapter;
import com.kuanghua.msgdyq.ui.base.BaseActivity;
import com.kuanghua.msgdyq.util.SlideRecyclerView;
import com.kuanghua.msgdyq.util.ToastUtil;

import java.util.ArrayList;
import java.util.List;

/**
 * 选择红包
 */
public class SelectRedEnvelopeActivity extends BaseActivity implements View.OnClickListener {

    private TextView mTvCommentCnt, mTvLike, mTvLast;
    private SlideRecyclerView mRvOrder;

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
    }

    @Override
    public int setContentLayout() {
        return R.layout.activity_select_red_envelope;
    }

    @Override
    public void initView() {
        View rootView = findViewById(R.id.root_view);
        setStatusBarHeight(rootView);

        final LinearLayout mLlBack = findViewById(R.id.ll_back);
        mRvOrder = findViewById(R.id.rvRedEnvelope);
        mRvOrder.setVerticalScrollBarEnabled(false);
        mRvOrder.setHorizontalScrollBarEnabled(false);
        mLlBack.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                finish();
            }
        });
    }

    @Override
    public void initData() {

        List<String> list = new ArrayList<>();
        for (int i = 0; i < 15; i++) {
            list.add("早晨推荐"+i);
        }
        LinearLayoutManager LayoutManager=  new LinearLayoutManager(this,LinearLayoutManager.VERTICAL, false);
        RedEnvelopeAdapter mAdapter = new RedEnvelopeAdapter(this, list);
        mRvOrder.setLayoutManager(LayoutManager);
        mRvOrder.setAdapter(mAdapter);

        mAdapter.setItemClickListener(new RedEnvelopeAdapter.MyItemClickListener() {
            @Override
            public void onItemClick(int position) {
                Log.d("SGF", "isShowSlideView: "+mRvOrder.isShowSlideView());
                if(mRvOrder.isShowSlideView()){
                    mRvOrder.closeMenu();
                }else {
                    mRvOrder.computeScroll();
                    ToastUtil.show("准备跳转");
                }

            }
        });
        mAdapter.setOnDeleteClickListener(new RedEnvelopeAdapter.OnDeleteClickLister() {
            @Override
            public void onDeleteClick(View view, int position) {
                mRvOrder.closeMenu();
//                mRvOrder.computeScroll();
                ToastUtil.show("删除了"+position+1);
            }
        });

    }

    @Override
    public void initListener() {
//        mTvLike.setOnClickListener(this);
    }

    @Override
    public void onClick(View view) {
        switch (view.getId()) {
            case R.id.tv_go_follow:
                break;
            default:
                break;

        }
    }
}

5.适配器

import android.content.Context;
import android.graphics.drawable.Drawable;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.TextView;

import androidx.recyclerview.widget.RecyclerView;

import com.kuanghua.msgdyq.R;

import java.util.List;

/**
 * Description:选择红包适配器
 *
 * @author SGF
 * date:
 */
public class RedEnvelopeAdapter extends RecyclerView.Adapter<RedEnvelopeAdapter.MyViewHolder> {

    private Context context;
    private View view;
    private int num = 0;
    List<String> topIconData;


    public RedEnvelopeAdapter(Context context, List<String> topIconData) {
        this.context = context;
        this.topIconData = topIconData;

    }

    @Override
    public MyViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
        LayoutInflater inflater = (LayoutInflater) context.getSystemService(context.LAYOUT_INFLATER_SERVICE);
        view = inflater.inflate(R.layout.item_rv_red_envelope_test, parent, false);
        return new MyViewHolder(view);
    }

    @Override
    public void onBindViewHolder(final MyViewHolder holder, int position) {
        int adapterPosition = holder.getAdapterPosition();
        String s = this.topIconData.get(adapterPosition);
//        Glide.with(context).load(topIconDataBean.getIcon_img()).into(holder.mImTopIcon);
//        holder.mTvTopIcon.setText(topIconDataBean.getIcon_title());
    }

    @Override
    public int getItemCount() {
        return topIconData.size();
    }

    class MyViewHolder extends RecyclerView.ViewHolder {
        ImageView mImHeadSculpture;
        TextView mTvName, mTvIdentification, mTvPrice, mTvDelete;
        ImageView mImFire, mImDelete;
        LinearLayout mLlView;

        public MyViewHolder(View itemView) {
            super(itemView);
//            mImHeadSculpture = (ImageView) itemView.findViewById(R.id.im_head_sculpture);
            mTvName = (TextView) itemView.findViewById(R.id.tv_name);
//            mTvIdentification = (TextView) itemView.findViewById(R.id.tv_identification);
//            mTvPrice = (TextView) itemView.findViewById(R.id.tv_price);
            mTvDelete = (TextView) itemView.findViewById(R.id.tv_delete);
//            mImDelete = (ImageView) itemView.findViewById(R.id.im_delete);
            mLlView = (LinearLayout) itemView.findViewById(R.id.ll_view);
            mLlView.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {//整个item监听
                    int position = getPosition();
                    if (mItemClickListener != null)
                        mItemClickListener.onItemClick(position);
                }
            });
            if (!mTvDelete.hasOnClickListeners()) {
                mTvDelete.setOnClickListener(new View.OnClickListener() {
                    @Override
                    public void onClick(View v) {
                        if (mDeleteClickListener != null) {
                            int position = getPosition();
//                            mDeleteClickListener.onDeleteClick(v, (Integer) v.getTag());
                            mDeleteClickListener.onDeleteClick(v, position);
                        }
                    }
                });
            }
//            mTvDelete.setOnClickListener(new View.OnClickListener() {
//                @Override
//                public void onClick(View view) {
//                    mTvDelete.setTextColor(context.getResources().getColor(R.color.blue_0B1152));
//                }
//            });
        }
    }

    public void setItemClickListener(MyItemClickListener myItemClickListener) {
        this.mItemClickListener = myItemClickListener;
    }

    public void setCaseDetailsClickListener(MyCaseDetailsClickListener myCaseDetailsClickListener) {
        this.mCaseDetailsClickListener = myCaseDetailsClickListener;
    }

    private MyItemClickListener mItemClickListener;

    private MyCaseDetailsClickListener mCaseDetailsClickListener;

    private OnDeleteClickLister mDeleteClickListener;

    public void setOnDeleteClickListener(OnDeleteClickLister listener) {
        this.mDeleteClickListener = listener;
    }

    public interface OnDeleteClickLister {
        void onDeleteClick(View view, int position);
    }

    /**
     * 创建一个回调接口
     */
    public interface MyItemClickListener {
        //        void onItemClick(OccupationBeen firstPageListBean, int position);
        void onItemClick(int position);
    }

    public interface MyCaseDetailsClickListener {
        //        void onItemClick(OccupationBeen firstPageListBean, int position);
        void onItemClick(int position);
    }

    /**
     * 设置关注按钮背景颜色
     *
     * @param linearLayout 设置的控件
     * @param background   背景颜色
     */
    public void setBackground(LinearLayout linearLayout, int background) {
//                    btn_importWallet.setBackgroundColor(ContextCompat.getColor(getContext(), R.color.light_blue));
        //設置佈局背景色方法一
        Drawable drawable = context.getResources().getDrawable(background);
        linearLayout.setBackgroundDrawable(drawable);
    }
}

参考链接:侧滑删除

  • 5
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现Android侧滑菜单有多种方式,其中一种比较常见的实现方式是使用DrawerLayout和NavigationView。 步骤如下: 1. 在XML布局文件中添加DrawerLayout和NavigationView,其中NavigationView中可以添加菜单项。 ``` <android.support.v4.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/drawer_layout" android:layout_width="match_parent" android:layout_height="match_parent"> <!-- 主界面内容 --> <FrameLayout android:id="@+id/content_frame" android:layout_width="match_parent" android:layout_height="match_parent" /> <!-- 侧滑菜单 --> <android.support.design.widget.NavigationView android:id="@+id/navigation_view" android:layout_width="wrap_content" android:layout_height="match_parent" android:layout_gravity="start" android:fitsSystemWindows="true" app:headerLayout="@layout/nav_header" app:menu="@menu/nav_menu" /> </android.support.v4.widget.DrawerLayout> ``` 2. 在Activity中设置DrawerLayout和NavigationView的监听器,并在onOptionsItemSelected方法中处理菜单项点击事件。 ``` public class MainActivity extends AppCompatActivity { private DrawerLayout mDrawerLayout; private NavigationView mNavigationView; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); mDrawerLayout = findViewById(R.id.drawer_layout); mNavigationView = findViewById(R.id.navigation_view); mNavigationView.setNavigationItemSelectedListener(new NavigationView.OnNavigationItemSelectedListener() { @Override public boolean onNavigationItemSelected(@NonNull MenuItem item) { // 处理菜单项点击事件 return false; } }); ActionBarDrawerToggle toggle = new ActionBarDrawerToggle( this, mDrawerLayout, toolbar, R.string.navigation_drawer_open, R.string.navigation_drawer_close); mDrawerLayout.addDrawerListener(toggle); toggle.syncState(); } @Override public boolean onOptionsItemSelected(MenuItem item) { int id = item.getItemId(); if (id == android.R.id.home) { mDrawerLayout.openDrawer(GravityCompat.START); return true; } return super.onOptionsItemSelected(item); } } ``` 3. 在NavigationView中添加菜单项,并为菜单项设置图标和标题。 ``` <menu xmlns:android="http://schemas.android.com/apk/res/android"> <group android:checkableBehavior="single"> <item android:id="@+id/nav_home" android:icon="@drawable/ic_home" android:title="Home" /> <item android:id="@+id/nav_gallery" android:icon="@drawable/ic_gallery" android:title="Gallery" /> <item android:id="@+id/nav_slideshow" android:icon="@drawable/ic_slideshow" android:title="Slideshow" /> </group> </menu> ``` 至此,实现了一个简单的Android侧滑菜单。如果要实现仿QQ侧滑删除功能,可以在ListView或RecyclerView中添加滑动删除的功能,并在删除时更新侧滑菜单中的未读消息数等信息。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值