Android RecyclerView与CardView:卡片之间的边距
创始人
2024-08-15 07:00:39
0

要在Android RecyclerView中为CardView之间添加边距,可以使用ItemDecoration类来实现。下面是一个示例代码,演示如何在RecyclerView中添加边距:

  1. 首先,在你的项目中添加CardView的依赖。在app的build.gradle文件中添加以下代码:
implementation 'androidx.cardview:cardview:1.0.0'
  1. 创建一个类来实现ItemDecoration。这个类将继承RecyclerView.ItemDecoration,并重写getItemOffsets()方法。在这个方法中,我们可以定义用于设置边距的逻辑。
import android.content.Context;
import android.graphics.Rect;
import android.view.View;

import androidx.annotation.NonNull;
import androidx.recyclerview.widget.RecyclerView;

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

    public RecyclerViewItemDecoration(Context context, int space) {
        this.space = space;
    }

    @Override
    public void getItemOffsets(@NonNull Rect outRect, @NonNull View view, @NonNull RecyclerView parent, @NonNull RecyclerView.State state) {
        outRect.left = space;
        outRect.right = space;
        outRect.bottom = space;

        // Add top margin only for the first item to avoid double space between items
        if (parent.getChildAdapterPosition(view) == 0) {
            outRect.top = space;
        } else {
            outRect.top = 0;
        }
    }
}
  1. 在你的Activity或Fragment中,创建RecyclerView和Adapter,并设置LayoutManager和ItemDecoration。
import android.os.Bundle;

import androidx.appcompat.app.AppCompatActivity;
import androidx.recyclerview.widget.LinearLayoutManager;
import androidx.recyclerview.widget.RecyclerView;

public class MainActivity extends AppCompatActivity {
    private RecyclerView recyclerView;
    private RecyclerViewAdapter adapter;

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

        recyclerView = findViewById(R.id.recycler_view);
        adapter = new RecyclerViewAdapter(/* your data here */);

        recyclerView.setLayoutManager(new LinearLayoutManager(this));
        recyclerView.addItemDecoration(new RecyclerViewItemDecoration(this, 16)); // 设置边距
        recyclerView.setAdapter(adapter);
    }
}

这样,RecyclerView中的每个CardView之间就会有16dp的边距了。根据你的需求,你可以调整getItemOffsets()方法中的边距数值来适应你的UI设计。

相关内容

热门资讯

透视辅助!红龙扑克总是存在有挂... 透视辅助!红龙扑克总是存在有挂,红龙扑克竟然真的有挂(详细辅助器教程),亲,有的,ai轻松简单,又可...
透视辅助!微扑克一直真的有挂,... 透视辅助!微扑克一直真的有挂,德州微扑克专用确实真的有挂(详细wpk透视辅助教程);1、全新机制【w...
透视辅助!AAPOKer软件透... 透视辅助!AAPOKer软件透明挂,aa扑克伙牌竟然是真的有挂(详细猫腻教程)1、任何ai辅助神器的...
透视辅助!aapoker有网页... 透视辅助!aapoker有网页版吗,aapoker切实真的是有挂(详细有外卦挂教程)1、完成透视辅助...
透视辅助!红龙扑克真是是真的有... 透视辅助!红龙扑克真是是真的有挂,红龙扑克原来真的有挂(详细辅助器教程)(1)透视辅助!红龙扑克真是...
透视辅助!aapOker果然是... 透视辅助!aapOker果然是有挂,aapker代理一直是有挂(详细辅助工具教程)1、ai辅助优化,...
透视辅助!红龙扑克辅助脚本,红... 透视辅助!红龙扑克辅助脚本,红龙扑克好像真的有挂(详细辅助教程)1、系统规律教程、辅助透视等服务,为...
透视辅助!wpk胜率跟号有关系... 透视辅助!wpk胜率跟号有关系么,(wpk辅助)原来真的有挂(详细外卦挂教程)是一款可以让一直输的玩...
一分钟教会你!红龙扑克辅助工具... 一分钟教会你!红龙扑克辅助工具,红龙扑克一贯真的有挂(详细辅助器教程)1、ai辅助优化,发牌逻辑科技...
第十分钟了解!微扑克辅助神器,... 第十分钟了解!微扑克辅助神器,微扑克计算器都是是真的有挂(详细wpk透视辅助教程)1)wpk透视辅助...