RecyclerView机制解析: ItemDecoration

RecyclerView的ItemDecoration机制相对比较简单,不过扩展性很强,在ChildView的测量和展示上为使用者提供了极大的发挥空间,像divider/项目高亮/项目边框等效果都可以轻松实现ItemDecoration可以同时存在复数个,维护在一个列表中,影响是可以叠加的,ItemDecoration的作用顺序从列表头到列表尾。addItemDecoration可以添加一个Ite
摘要由CSDN通过智能技术生成
  1. RecyclerView的ItemDecoration机制相对比较简单,不过扩展性很强,在ChildView的测量和展示上为使用者提供了极大的发挥空间,像divider/项目高亮/项目边框等效果都可以轻松实现

  2. ItemDecoration可以同时存在复数个,维护在一个列表中,影响是可以叠加的,ItemDecoration的作用顺序从列表头到列表尾

    1. addItemDecoration可以添加一个ItemDecoration。
    2. removeItemDecoration可以删除一个ItemDecoration。
    3. invalidateItemDecorations表示当前的ItemDecoration发生了变化,需要更新。
    4. 因为RecyclerView**继承自ViewGroup,默认其willNoDraw是true(意味着其onDraw函数不会被调用),但是ItemDecoration的onDraw需要在RecyclerView的onDraw回调点进行,因此添加/删除ItemDecoraton时会根据情况改变willNotDraw属性**。
    5. 应为ItemDecoration会影响ChildView的测量,进而影响布局,还影响绘制,因此ItemDecoration的添加/删除/Invalidate会触发requestLayout来重新测量布局绘制.
    6. 在Scroll/Layout的过程中禁止添加/删除ItemDecoration
  3. 先看ItemDecoration是如何影响ChildView的测量:

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在 Android RecyclerView 的头部和尾部设置圆角,可以使用 ItemDecoration。具体的实现步骤如下: 1. 创建自定义的 ItemDecoration 类,并在该类的构造函数中传入圆角半径大小等参数。 2. 在该类的 `onDraw()` 方法中,使用 `Canvas` 和 `Paint` 对象绘制圆角矩形。可以通过 `getItemOffsets()` 方法来设置矩形的偏移量,以避免覆盖到 RecyclerView 的内容。 3. 在 RecyclerView 的 Adapter 类中,判断当前的 position 是否为头部或尾部,如果是,则在 `onCreateViewHolder()` 方法中设置对应的圆角布局。 以下是示例代码: ```java public class MyItemDecoration extends RecyclerView.ItemDecoration { private int radius; // 圆角半径 private int padding; // 矩形偏移量 public MyItemDecoration(int radius, int padding) { this.radius = radius; this.padding = padding; } @Override public void getItemOffsets(Rect outRect, View view, RecyclerView parent, RecyclerView.State state) { super.getItemOffsets(outRect, view, parent, state); if (parent.getChildAdapterPosition(view) == 0) { // 头部 outRect.top = padding; } else if (parent.getChildAdapterPosition(view) == parent.getAdapter().getItemCount() - 1) { // 尾部 outRect.bottom = padding; } } @Override public void onDraw(Canvas c, RecyclerView parent, RecyclerView.State state) { int childCount = parent.getChildCount(); for (int i = 0; i < childCount; i++) { View child = parent.getChildAt(i); RecyclerView.LayoutParams params = (RecyclerView.LayoutParams) child.getLayoutParams(); int left = child.getLeft() + params.leftMargin; int right = child.getRight() - params.rightMargin; int top = child.getTop() + params.topMargin; int bottom = child.getBottom() - params.bottomMargin; if (parent.getChildAdapterPosition(child) == 0) { // 头部 drawRoundRect(c, left, top, right, bottom + padding, radius, true, true, false, false); } else if (parent.getChildAdapterPosition(child) == parent.getAdapter().getItemCount() - 1) { // 尾部 drawRoundRect(c, left, top - padding, right, bottom, radius, false, false, true, true); } } } // 绘制圆角矩形 private void drawRoundRect(Canvas canvas, float left, float top, float right, float bottom, float radius, boolean tl, boolean tr, boolean bl, boolean br) { Paint paint = new Paint(); paint.setAntiAlias(true); paint.setColor(Color.WHITE); paint.setStyle(Paint.Style.FILL); Path path = new Path(); float[] radii = new float[8]; if (tl) { radii[0] = radius; radii[1] = radius; } if (tr) { radii[2] = radius; radii[3] = radius; } if (br) { radii[4] = radius; radii[5] = radius; } if (bl) { radii[6] = radius; radii[7] = radius; } path.addRoundRect(new RectF(left, top, right, bottom), radii, Path.Direction.CW); canvas.drawPath(path, paint); } } ``` 然后,在 RecyclerView 的 Adapter 中,可以根据 position 判断是否为头部或尾部,并设置对应的布局: ```java @Override public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) { if (viewType == TYPE_HEADER) { // 头部 View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.item_header, parent, false); return new HeaderViewHolder(view); } else if (viewType == TYPE_FOOTER) { // 尾部 View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.item_footer, parent, false); return new FooterViewHolder(view); } else { // 正常的 Item View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.item_normal, parent, false); return new NormalViewHolder(view); } } ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值