BaseRecyclerViewAdapterHelper万能适配器(item点击,子item点击)

一、框架引入

  • 先在项目的 build.gradle(Project:XXXX) 的 repositories 添加:
    allprojects {       
       repositories {            ...           
             maven { url "https://jitpack.io" }       
           }  
  }
  • 然后在Module的 build.gradle(Module:app) 的 dependencies 添加:
    dependencies { 
           ......            
      compile 'com.github.CymChad:BaseRecyclerViewAdapterHelper:2.9.22'  
  }

2.2 最基本使用示例

编写适配器
MyAdapter.java

  public class MyAdapter extends BaseQuickAdapter<Model,         BaseViewHolder> {

      public MyAdapter(@LayoutRes int layoutResId, @Nullable List<Model> data) {
          super(layoutResId, data);
      }

      @Override
       protected void convert(BaseViewHolder helper, Model item) {
              //获取当前条目position
              //int position = helper.getLayoutPosition();
              //可链式调用赋值
              helper.setText(R.id.tv_title, item.getTitle())//标题
                .setText(R.id.tv_content, item.getContent())//内容
                .setImageResource(R.id.iv_img, R.mipmap.ic_launcher);//背景


    }
}

最后一步:在Activity中使用该适配器
MainActivity.java

public class MainActivity extends AppCompatActivity {

private RecyclerView recyclerView;
private List<Model> datas;
private MyAdapter adapter;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    //初始化RecyclerView
    recyclerView = (RecyclerView) findViewById(R.id.recycler_view);

    //模拟的数据(实际开发中一般是从网络获取的)
    datas = new ArrayList<>();
    Model model;
    for (int i = 0; i < 15; i++) {
        model = new Model();
        model.setTitle("我是第" + i + "条标题");
        model.setContent("第" + i + "条内容");
        datas.add(model);
    }

    //创建布局管理
    LinearLayoutManager layoutManager = new LinearLayoutManager(this);
    layoutManager.setOrientation(LinearLayoutManager.VERTICAL);
    recyclerView.setLayoutManager(layoutManager);

    //创建适配器 (在这特别说明一下,括号离填item布局和集合数据,分别把布局和数据添加进去)
    adapter = new MyAdapter(R.layout.item_rv, datas);

    //给RecyclerView设置适配器
    recyclerView.setAdapter(adapter);
  }
}

还有最重要的,我也老是忘记怎么写的,单击子item的点击事件和整条item的的点击事件

往下接着看👉

条目事件

Item的点击事件

    //条目点击事件
    adapter.setOnItemClickListener(new BaseQuickAdapter.OnItemClickListener() {
        @Override
        public void onItemClick(BaseQuickAdapter adapter, View view, int position) {

            Toast.makeText(MainActivity.this, "点击了第" + (position + 1) + "条条目", Toast.LENGTH_SHORT).show();
        }
    });

Item的长按事件
//条目长按事件

adapter.setOnItemLongClickListener(new     BaseQuickAdapter.OnItemLongClickListener() {
        @Override
        public boolean onItemLongClick(BaseQuickAdapter adapter, View view, int position) {

            Toast.makeText(MainActivity.this, "长按了第" + (position + 1) + "条条目", Toast.LENGTH_SHORT).show();
            return false;
        }
    });

注意事项
在嵌套recycleView的情况下需要使用你使用 adapter. setOnItemClickListener 来设置点击事件,如果使用recycleView.addOnItemTouchListener会累计添加的。

条目子控件事件

Item子控件的点击事件

  • 首先:在adapter的convert方法里面通过 helper.addOnClickListener 绑定一下子控件的控件id
    @Override    
protected void convert(BaseViewHolder helper, Model item) {        
//可链式调用赋值       
 helper.setText(R.id.tv_title, item.getTitle())  
              .setText(R.id.tv_content, item.getContent())  
              .addOnClickListener(R.id.iv_img)    //给图标添加点击事件   (这一行很重要噢)        
              .setImageResource(R.id.iv_img, R.mipmap.ic_launcher);       
 //获取当前条目position      
  //int position = helper.getLayoutPosition(); 
   }
  • 然后:我们设置
        //条目子控件点击事件        
adapter.setOnItemChildClickListener(new BaseQuickAdapter.OnItemChildClickListener() {          
  @Override            
      public void onItemChildClick(BaseQuickAdapter adapter, View view, int position) {              
         Toast.makeText(MainActivity.this, "点击了第" + (position + 1) + "条条目的图片", Toast.LENGTH_SHORT).show();         
      }      
  });

Item子控件的长按事件

这里和子控件点击事件是一样的,只是将 点击 变成 长按 就可以了

首先:在adapter的convert方法里面通过 helper.addOnLongClickListener 绑定一下子控件的控件id

 @Override    
protected void convert(BaseViewHolder helper, Model item) {        
//可链式调用赋值       
 helper.setText(R.id.tv_title, item.getTitle())  
              .setText(R.id.tv_content, item.getContent())    
            //.addOnClickListener(R.id.iv_img)    
             //给图标添加点击事件                
            .addOnLongClickListener(R.id.iv_img)//给图片添加长按事件    
            .setImageResource(R.id.iv_img, R.mipmap.ic_launcher);     
   //获取当前条目position     
   //int position = helper.getLayoutPosition();    }
  • 然后:我们设置
        //条目子控件长按事件        adapter.setOnItemChildLongClickListener(new BaseQuickAdapter.OnItemChildLongClickListener() { 
    @Override            
          public boolean onItemChildLongClick(BaseQuickAdapter adapter, View view, int position) {       
              Toast.makeText(MainActivity.this, "长按了第" + (position + 1) + "条条目的图片", Toast.LENGTH_SHORT).show();                return false;           
     }       
 });

注意事项

  • 设置子控件的事件,如果不在adapter中绑定,点击事件无法生效,因为无法找到你需要设置的控件。

多个Item子控件事件

  • 官方文档上没说,但是 其实这里可以用很常规的方法处理,就是通过判断ID来判定是否是我要的控件?,从而处理不同的事件

  • 比如我这里给 图片和标题 都加点击事件处理不同的逻辑

  • 首先:当然是在适配器中给图片和标题都添加点击事件

 @Override    
protected void convert(BaseViewHolder helper, Model item) {    
            //可链式调用赋值     
              helper.setText(R.id.tv_title, item.getTitle())  
              .setText(R.id.tv_content, item.getContent())   
               .addOnClickListener(R.id.iv_img)    //给图标添加 点击事件 
               .addOnClickListener(R.id.tv_title)  //给标题也添加 点击事件    
              .setImageResource(R.id.iv_img, R.mipmap.ic_launcher);   
             //获取当前条目position      
            //int position = helper.getLayoutPosition();    }
  • 其次:
        //条目子控件点击事件        
adapter.setOnItemChildClickListener(new BaseQuickAdapter.OnItemChildClickListener() {           
@Override           
public void onItemChildClick(BaseQuickAdapter adapter, View view, int position) {              
   //判断id               
       if (view.getId() == R.id.iv_img) {         
                 Log.i("tag", "点击了第" + position + "条条目的 图片");            
              } else if (view.getId() == R.id.tv_title) {     
               Log.i("tag", "点击了第" + position + "条条目的 标题");           
              }           
       }      
  });
  • 那么如果是长按事件呢?当然也是相同的处理方法。

如果需要在子控件事件中获取其他子控件可以使用:

getViewByPosition(RecyclerView recyclerView, int position, @IdRes int viewId)

比如:

        //条目子控件点击事件        
adapter.setOnItemChildClickListener(new BaseQuickAdapter.OnItemChildClickListener() {           
 @Override            
      public void onItemChildClick(BaseQuickAdapter adapter, View view, int position) {              
           Toast.makeText(MainActivity.this, "点击了第" + (position + 1) + "条条目的图片", Toast.LENGTH_SHORT).show();                 
          TextView tv_title = (TextView) ;
          adapter.getViewByPosition(recyclerView, position, R.id.tv_title);       
           Log.i("tag", "当前图片对应的 title=" + tv_title.getText());         
       }          
    });         
//条目子控件长按事件        
 adapter.setOnItemChildLongClickListener(new BaseQuickAdapter.OnItemChildLongClickListener() {       
    @Override            
      public boolean onItemChildLongClick(BaseQuickAdapter adapter, View view, int position) {                
           Toast.makeText(MainActivity.this, "长按了第" + position + "条条目的图片", Toast.LENGTH_SHORT).show();           
           TextView tv_title = (TextView) ;
            adapter.getViewByPosition(recyclerView, position, R.id.tv_title);     
               Log.i("tag", "长按的图片对应的title=" + tv_title.getText());     
              return false;           
           }     
     });

注意:如果有header的话需要处理一下position加上 headerlayoutcount。

  • 最后,点击事件基本就完了
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,657评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,662评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,143评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,732评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,837评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,036评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,126评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,868评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,315评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,641评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,773评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,859评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,584评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,676评论 2 351

推荐阅读更多精彩内容