自定义RecyclerView.ItemDecoration修改间距

本文档展示了如何通过自定义一个名为TextTopicGridSpaceItemDecoration的类,继承自RecyclerView.ItemDecoration,实现宫格列表的特殊间距效果。在该实现中,第一行的顶部会增加间距,其他行则没有顶部间距。此外,根据item的位置,左右间距也会有所调整,奇数位置的item左侧间距完整,右侧间距减半,偶数位置的item则反之。这个定制的装饰器可以用于创建更加个性化的列表展示。

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

自定义类继承自RecyclerView.ItemDecoration,并重写getItemOffsets方法,根据自己想要的效果定制规则来实现。
以下实现的效果是以宫格列表为例实现的:第一行时顶部加间距,其他行不加(布局中加了底部间距);item在左边时左间距完整,右间距减一半,item在右边时左间距减半,右间距完整。

public class TextTopicGridSpaceItemDecoration extends RecyclerView.ItemDecoration {
    private int space;

    public TextTopicGridSpaceItemDecoration(Context mContext, int space){
        this.space= DeviceUtils.dp2px(mContext,space);
    }
    @Override
    public void getItemOffsets(@NonNull Rect outRect, @NonNull View view, @NonNull RecyclerView parent, @NonNull RecyclerView.State state) {
        if (parent.getChildAdapterPosition(view)==0||parent.getChildAdapterPosition(view)==1){
            outRect.top= space;
        }else {
            outRect.top=0;
        }
        if (parent.getChildAdapterPosition(view)%2==0){
            outRect.left=space;
            outRect.right=space/2;
        }else {
            outRect.left=space/2;
            outRect.right=space;
        }
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值