RecyclerView 设置了GridLayoutManager 空白区域点击事件

只要这样设置就好了
recycle_foodl.setOnTouchListener(new View.OnTouchListener() {
    @Override
    public boolean onTouch(View v, MotionEvent event) {
        if (v.getId()!=0){
            //发现只有点击了空白处,v.getId,才能打印出东西
            //可以在此处做文章
            goodsAdapter.dimmMissll_edit();
        }
        return false;
    }
});
使用 GridLayoutManager 来实现 RecyclerView 的网格布局,在设置 GridLayoutManager 时,可以通过 setSpanSizeLookup() 方法来设置每个 item 所占用的网格数,而在设置行间隔时,可以通过设置 item 之间的间距来实现。 具体实现步骤如下: 1. 创建 GridLayoutManager 对象,并设置每个 item 所占用的网格数: ```java GridLayoutManager layoutManager = new GridLayoutManager(context, spanCount); layoutManager.setSpanSizeLookup(new GridLayoutManager.SpanSizeLookup() { @Override public int getSpanSize(int position) { // 返回当前 item 所占用的网格数 return 1; } }); ``` 2. 创建 ItemDecoration 对象,并设置 item 之间的间距: ```java int spacing = 10; // 行间距 int halfSpacing = spacing / 2; recyclerView.addItemDecoration(new RecyclerView.ItemDecoration() { @Override public void getItemOffsets(Rect outRect, View view, RecyclerView parent, RecyclerView.State state) { super.getItemOffsets(outRect, view, parent, state); int position = parent.getChildAdapterPosition(view); int column = position % spanCount; outRect.left = halfSpacing; outRect.right = halfSpacing; outRect.bottom = spacing; if (position < spanCount) { outRect.top = spacing; } } }); ``` 其中,getItemOffsets() 方法会在 RecyclerView 绘制 item 时被调用,可以通过设置 outRect 来控制 item 之间的间距。 以上代码中,我们设置了左右间距为行间距的一半,底部间距为行间距,顶部间距只在每一行的第一个 item 上设置。 这样就可以实现 RecyclerView 网格布局的行间隔了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值