一个简单的 Recycleview + GridLayoutManager 显示图片的例子

本文通过一个实例展示了如何使用Recycleview结合GridLayoutManager来显示图片,详细介绍了XML布局、Adapter代码以及Activity代码的实现过程。在实现过程中,遇到了图片之间间距过大的问题,通过将item的layout_width设为match_parent成功解决了问题。

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

显示效果

Recycleview  XML 布局文件

(该文件内容有省略)


        <android.support.v7.widget.RecyclerView
            android:id="@+id/recycleview"
            android:paddingLeft="18dp"
            android:paddingRight="18dp"
            android:layout_width="match_parent"
            android:layout_height="match_parent"/>

ITEM 项XML 布局文件

<?xml version="1.0" encoding="utf-8"?>
<ImageView
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/iv"
    android:layout_height="wrap_content"
    android:padding="8dp"
    android:layout_width="match_parent" />

Aapter 代码 

构造函数中传入要显示的图片的URL。由 Gide  图片库负责图片的显示。


public class MyAdapter extends RecyclerView.Adapter<MyAdapter.ViewHolder> {

    private List<String> mDataset;

    private Context mContext;

    public static class ViewHolder extends RecyclerView.ViewHolder {

        ImageView iv;

        public ViewHolder(View v) {
            super(v);
            iv = (ImageView) v.findViewById(R.id.iv);
        }
    }

    public MyAdapter(List<String> myDataset) {
        mDataset = myDataset;
    }

    @Override
    public MyAdapter.ViewHolder onCreateViewHolder(ViewGroup parent,
                                                   int viewType) {
        View v;
        mContext = parent.getContext();
        v = LayoutInflater.from(parent.getContext())
                    .inflate(R.layout.image_item, parent, false);
        return new ViewHolder(v);
    }

    @Override
    public void onBindViewHolder(ViewHolder holder, final int position) {
        ImageView iv = holder.iv;
        Glide.with(mContext).load(mDataset.get(position)).into(iv);
    }

    @Override
    public int getItemCount() {
        return mDataset.size();
    }
}


Ativity 代码

public class EditorActivity extends Activity {

    private static String TAG = "EditorActivity";

    private RecyclerView recyclerView;
    private GridLayoutManager gridLayoutManager;

    @Override
    public void onCreate(Bundle bundle) {

        requestWindowFeature(Window.FEATURE_NO_TITLE);

        super.onCreate(bundle);
        this.setContentView(R.layout.post_commit_main);

        
        recyclerView = findViewById(R.id.recycleview);

        gridLayoutManager = new GridLayoutManager(this.getApplicationContext(), 3);
        recyclerView.setLayoutManager(gridLayoutManager);

        // 需要传入图片URL
        MyAdapter adapter = new MyAdapter(new ArrayList<String>());

        recyclerView.setAdapter(adapter);
    }
}

遇到的问题

一开始 item 项 imageView 的布局文件中 layout_width 赋值为  wrap_content

图片行与行之间的空白很大。

改为 match_parent 之后问题解决。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Zonson9999

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值