Android RecyclerView(瀑布流)水平/垂直方向分割线

Android RecyclerView不像过去的ListView那样随意的设置水平方向的分割线,如果要实现RecyclerView的水平/垂直分割线,则需要继承自RecyclerView.ItemDecoration重写getItemOffsets方法,从而增加水平/垂直分割线。

写一个例子。

MainActivity.java:

package zhangphil.app;

import android.content.Context;

import android.graphics.Color;

import android.support.v7.app.AppCompatActivity;

import android.os.Bundle;

import android.support.v7.widget.RecyclerView;

import android.support.v7.widget.StaggeredGridLayoutManager;

import android.view.View;

import android.view.ViewGroup;

import android.widget.TextView;

public class MainActivity extends AppCompatActivity {

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

RecyclerView mRecyclerView = (RecyclerView) findViewById(R.id.recyclerView);

// 两列

int spanCount = 2;

// StaggeredGridLayoutManager管理RecyclerView的布局。

StaggeredGridLayoutManager mLayoutManager = new StaggeredGridLayoutManager(spanCount, StaggeredGridLayoutManager.VERTICAL);

mRecyclerView.setLayoutManager(mLayoutManager);

//为RecyclerView增加分割线,水平和垂直方向都有。增加分割线值比如为32。

RecyclerViewItemDecoration decoration = new RecyclerViewItemDecoration(32);

mRecyclerView.addItemDecoration(decoration);

RecyclerViewAdapter mAdapter = new RecyclerViewAdapter(this);

mRecyclerView.setAdapter(mAdapter);

}

private class ItemViewHolder extends RecyclerView.ViewHolder {

private TextView text;

public ItemViewHolder(View itemView) {

super(itemView);

text = (TextView) itemView.findViewById(android.R.id.text1);

text.setTextColor(Color.WHITE);

}

}

public class RecyclerViewAdapter extends RecyclerView.Adapter {

private Context context;

public RecyclerViewAdapter(Context context) {

super();

this.context = context;

}

@Override

public ItemViewHolder onCreateViewHolder(ViewGroup viewGroup, int viewType) {

View view = View.inflate(context, android.R.layout.simple_list_item_1, null);

view.setBackgroundColor(Color.RED);

ItemViewHolder holder = new ItemViewHolder(view);

return holder;

}

@Override

public void onBindViewHolder(ItemViewHolder viewHolder, int pos) {

viewHolder.text.setText(String.valueOf(pos));

}

@Override

public int getItemCount() {

return 15;

}

}

}

布局文件,很简单,就放一个RecyclerView,注意背景颜色的设置:

android:layout_width="match_parent"

android:layout_height="match_parent"

android:background="@android:color/holo_orange_light">

android:id="@+id/recyclerView"

android:layout_width="match_parent"

android:layout_height="match_parent">

最关键的RecyclerViewItemDecoration.java:

package zhangphil.app;

/**

* Created by Phil on 2016/10/8.

*/

import android.graphics.Rect;

import android.support.v7.widget.RecyclerView;

import android.view.View;

/**

* 为RecyclerView增加间距

* 预设2列,如果是3列,则左右值不同

*/

public class RecyclerViewItemDecoration extends RecyclerView.ItemDecoration {

private int space = 0;

private int pos;

public RecyclerViewItemDecoration(int space) {

this.space = space;

}

@Override

public void getItemOffsets(Rect outRect, View view, RecyclerView parent, RecyclerView.State state) {

outRect.top = space;

//该View在整个RecyclerView中位置。

pos = parent.getChildAdapterPosition(view);

//取模

//两列的左边一列

if (pos % 2 == 0) {

outRect.left = space;

outRect.right = space / 2;

}

//两列的右边一列

if (pos % 2 == 1) {

outRect.left = space / 2;

outRect.right = space;

}

}

}

代码运行结果:

android 水平方向瀑布流,Android RecyclerView(瀑布流)水平/垂直方向分割线相关推荐

  1. Android RecyclerViewSwipeDismiss:水平、垂直方向的拖曳删除item

     Android RecyclerViewSwipeDismiss:水平.垂直方向的拖曳删除item RecyclerViewSwipeDismiss是一种支持RecyclerView的水平.垂直 ...

  2. Android RecyclerView 向上偏移解决、添加自定义分割线,瀑布流,ScrollView嵌套RecyclerView滑动卡顿

    向上偏移解决 android:focusableInTouchMode="true" android:focusable="true" android:fill ...

  3. android实现超酷的腾讯视频首页和垂直水平网格瀑布流一揽子效果

    代码地址如下: http://www.demodashi.com/demo/13381.html 先来一波demo截图 实现ListView.GridView.瀑布流 1.导入RecyclerView ...

  4. android瀑布流列表两边跳,Android Fragment + RecyclerView瀑布流布局

    Android Fragment + RecyclerView瀑布流布局 Android Fragment + RecyclerView瀑布流布局 目录 1.瀑布流效果图 2.使用RecyclerVi ...

  5. Android瀑布流仿京东,(二) 仿京东顶部伸缩渐变丶自定义viewpager指示器丶viewpager3D回廊丶recyclerview瀑布流...

    效果图如下: demo2.gif Demo2 1.仿京东首页顶部轮播图+搜索栏渐变 public class GradientScrollView extends ScrollView { publi ...

  6. Android 解决RecyclerView瀑布流刷新之后Item位置改变

    解决RecyclerView瀑布流刷新之后Item位置改变 为了测试RecyclerView瀑布流效果,每个Item的高度采取了随机高度,导致每次刷新的时候,重新随机出来的高度和原来的不一致,会导致I ...

  7. android开发 RecyclerView 瀑布列表布局

    android开发 RecyclerView 瀑布列表布局 1.写一个内容的自定义小布局: <?xml version="1.0" encoding="utf-8& ...

  8. android自定义viewgroup之我也玩瀑布流

    先看效果图吧, 继上一篇<android自定义viewgroup实现等分格子布局>中实现的布局效果,这里稍微有些区别,每个格子的高度不规则,就是传说的瀑布流布局,一般实现这种效果,要么用第 ...

  9. Android下拉刷新上拉更多瀑布流(附源码)

    关于瀑布流,我相信有很多朋友经常会用到.但是呢我们经常也会遇到这个问题,比如瀑布流不能下拉刷新,或者上拉更多,有的是一个简单的touch事件监听上拉加载更多,但是很显然,这样的功能以及用户体验得不到提 ...

最新文章

  1. R语言White’s检验实战:检验回归模型中是否存在异方差性(heteroscedasticity)、发生了异常差(heteroscedasticity)问题如何解决
  2. LAMP+Postfix+Dovecot+Postfixadmin搭建邮件管理系统(四)
  3. 联想微型计算机 m4350q,比超极本便携 评联想M4350q小型台式机
  4. JavaScript实现计算π值算法(附完整源码)
  5. 初探ES6(1)...
  6. 自下而上滚动公告栏(可悬停)
  7. python生成动态二维码实例_python生成动态个性二维码(示例代码)
  8. ndoe.js实战之开发微博第一讲之工具准备
  9. 机器学习笔记十一之降维
  10. 第三:jenkins集成httpclient项目并生成在线报告(接口自动化落地)
  11. 哈工大刘铭:开放式知识图谱的自动构建技术
  12. MAC查看一个库的编译版本
  13. matlab 深度学习环境配置
  14. HTML怎么使表格居中显示
  15. Sloth组件之NetRisc.Configuration源代码发布
  16. [资料分享] 干货~WLAN从入门到精通系列-WLAN技术连载帖汇
  17. ppt如何替换其他mo ban_“华南师范大学”专属PPT模板来了!华南师大同学们的PPT我们承包了!...
  18. 广州大学 数据结构实验报告
  19. 药监局,药品监督管理局
  20. php第三方阿里云接口

热门文章

  1. TCC两阶段补偿方案
  2. ActiveMQ入门-发送消息机制的介绍
  3. oracle 10g 更换ocr,Oracle10g RAC在线更换OCR votedisk
  4. 200827C阶段一_C++基础
  5. break与continue的区别【图解】(简洁明了)
  6. AntDB上使用表空间
  7. SIMD学习 -- 用SSE2指令作点乘和累加计算
  8. 【php】命名空间 和 自动加载的关系
  9. IOS开发知识(二)
  10. ifconfig命令无法找到,提示bash: ifconfig: command not found