RecyclerView使用上下文菜单registerForContextMenu小记.

本文详述在ViewPager包裹的多个Fragment中实现Recyclerview条目长按编辑和删除功能的具体步骤,包括注册上下文菜单、创建菜单项、重写上下文方法及设置长按事件。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

写在前面:最近要做一个在viewpager的fragment内,长按对每个条目进行删除和编辑的需求.网上搜集了好久的资料,都是自说自话,只适用部分场景,所以现在做一个总结,可以涵盖大部分场景的需求开发记录.

0.首先是一个activity内包含一个viewpager.viewpager内包含N个fragment,而每个fragment内都有一个recyclerview,并且每个recyclerview都支持长按弹窗"显示编辑和删除两个选项".

ok,话不多说,开搞.

1.在fragment初始化view以后,调用下边的代码注册上下文菜单:

registerForContextMenu(collect_video_rv); // 消息fragment点击事件

2.在res文件夹下的menu文件夹下创建一个commen_menu.xml,内容如下:

<menu xmlns:android="http://schemas.android.com/apk/res/android" >
    <item
        android:id="@+id/edit"
        android:title="编辑"/>
 <item
        android:id="@+id/delete"
        android:title="删除"/>
</menu>

3.在fragment内重写onCreateContextMenu和onContextItemSelected两个方法:

 @Override
    public void onCreateContextMenu(ContextMenu menu, View v, ContextMenu.ContextMenuInfo menuInfo) {
        // 这个方法是创建点击以后显示的布局条目的
        getActivity().getMenuInflater().inflate(R.menu.commen_menu, menu);
    }

    @Override
    public boolean onContextItemSelected(MenuItem item) {// 返回值true是拦截事件,false是不拦截
        if (getUserVisibleHint()) {// 这个方法是判断当前页面是哪一个页面的返回false就是不在当前页面
            if (item.getItemId() == R.id.delete) {
                ItemBean itemBean = mDataList.get(mAdapter.getPosition());// 通过adapter的getposition获得当前点击的是第几条,针对某条做相应操作.
                
            }else if (item.getItemId() == R.id.edit) {
                ItemBean itemBean = mDataList.get(mAdapter.getPosition());
               
            }
            return true;
        }
        return false;
    }

4.创建adapter继承RecyclerView.Adapter,然后创建变量position和相应的get方法,以便fragment内调用.

    private int mPosition = -1;

    public int getPosition() {
        return mPosition;
    }

5.对viewholder的itemview设置长按事件(必要)

            itemView.setLongClickable(true);
            itemView.setOnLongClickListener(new View.OnLongClickListener() {
                @Override
                public boolean onLongClick(View v) {
                    mPosition = getAdapterPosition();
                    return false;
                }
            });

OK,五步走,到此完成.

剩下的就是TODO you want TODO 了.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值