Recyclerview 间距设置

Android新的Recyclerview布局完美代替ListView,GridView等,其大多数属性都需要自己进行定制,更加灵活,但有时候也觉得麻烦。这里对其中作为GridView情况时的间距设置做介绍。

主要是讲怎么对GridView模式进行间距的设置,因为将之前的GridView换过来,不像GridView一样可以直接就设置好,我们需要根据确定item的位置然后再来确定需要设置哪个位置的间距。做着看起来比较麻烦,不过的确是高度自定义,十分灵活。项目中在Recyclerview中又嵌套了一个Recyclerview,子Recyclerview以GridView方式显示,之前使用GridView的时候直接在建立的时候使用android:horizontalSpacingandroid:verticalSpacing就可以进行间距的设置,而Recyclerview没有这个属性,但它提供了一个抽象类ItemDecoration可以对Recyclerview的Item进行间距的配置,我们需要做的就是实现该抽象类中的getItemOffsets
方法。
下面是具体的实现:
我们的思路就是通过对item位置的判断确定对其边距的设置,在本例中,我们的布局是将item按两列显示,我们要对左侧的item右边位置设置边距,然后对右侧item的左边位置设置边距。因此我们需要做的就是判断哪个item位于左侧,哪一个位于右侧,这个通过取模的方式就可以获得,代码如下:

private class SpaceItemDecoration extends RecyclerView.ItemDecoration {
  private int space;//声明间距 //使用构造函数定义间距 
  public SpaceItemDecoration(int space) {
     this.space = space;
 } 
@Override
  public void getItemOffsets(Rect outRect, View view, RecyclerView parent, RecyclerView.State state) { 
    //获得当前item的位置 
    int position = parent.getChildAdapterPosition(view); 
    //根据position确定item需要留出的位置 
    switch (position % 2) { 
      case 0:
        //位于左侧的item 
        outRect.right = this.space; 
        break; 
      case 1:
        //位于右侧的item 
        outRect.left = this.space; 
        break; 
      default: 
        break; 
}  
      //设置底部边距 
    outRect.bottom = this.space; 
  }
 }

最后addItemDecoration
即可。
注意:addItemDecoration放到ViewHolder中,放到onBindViewHolder每次获得item焦点它都会执行一次,会出现十分酷炫的效果,你会发现列表中的元素会越来越小,因为在下拉时,onBindViewHolder会不停执行,从而不停地增加元素间的间距

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

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,273评论 25 707
  • 最终的效果如下: 上图是我需求的一个页面,作为学习就直接贴出来了。 为了更好的使用网格布局,所以决定使用Recyc...
    tyrannos阅读 5,246评论 5 1
  • 先贴代码 模拟数据 76=(500-(5+1)*20)/5 有了以上的信息,想理解就不难了吧。
    StyleShu阅读 594评论 0 0
  • Tangram是阿里出品、用于快速实现组合布局的框架模型,在手机天猫Android&iOS版 内广泛使用 该框架提...
    wintersweett阅读 3,241评论 0 1
  • SDWebImage是ios上常用的一套网络图片加载的方案。 oc和swift语言都支持 探索了一下源码,受益良多...
    bibibime阅读 363评论 3 0