android - 具有两列的 GridView,第一项跨越两列

标签 android android-scrollview

我有一个 Imageview 和一个 gridview..

我的布局设计在这里..

enter image description here

我想将这两个 View 组合成一个 GridView

我的问题:

如何在两列中设置gridview的第一项跨度?

最佳答案

在研究您的问题时,我学到了一些新东西:我碰巧查看了 RecyclerViewGridLayoutManager,我注意到您可以设置自定义 SpanSizeLookup。现在,如果您垂直滚动,“跨度”只是一列,如果您水平滚动,则只是一行。所以 SpanSizeLookup 允许您指定例如,项目 0 占用 2 列,项目 1 占用 1 列,等等。

事实证明,如果您将 RecyclerViewGridLayoutManager 一起使用,解决方案很简单:

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

        // Create a grid layout with two columns
        GridLayoutManager layoutManager = new GridLayoutManager(this, 2);

        // Create a custom SpanSizeLookup where the first item spans both columns
        layoutManager.setSpanSizeLookup(new GridLayoutManager.SpanSizeLookup() {
            @Override
            public int getSpanSize(int position) {
                return position == 0 ? 2 : 1;
            }
        });

        RecyclerView recyclerView = (RecyclerView) findViewById(R.id.recyclerview);
        recyclerView.setLayoutManager(layoutManager);
        recyclerView.setAdapter(new MyGridAdapter());
    }

我创建了一个测试项目,只是为了尝试一下,确保它达到了我的预期,而且效果很好。


关于适配器的说明:RecyclerView.AdapterListAdapter 不兼容。您需要从 RecyclerView.Adapter 扩展您的适配器并进行适当的更改。

这是我为我的测试项目创建的适配器:

    public static class MyViewHolder extends RecyclerView.ViewHolder {

        ImageView mImageView;
        TextView mTextView;

        public MyViewHolder(View itemView) {
            super(itemView);
            mImageView = (ImageView) itemView.findViewById(R.id.imageView);
            mTextView = (TextView) itemView.findViewById(R.id.textView);
        }
    }

    public static class MyGridAdapter extends RecyclerView.Adapter<MyViewHolder> {

        private int[] mDrawables;

        public MyGridAdapter() {
            this.mDrawables = new int[] {
                    R.drawable.images_01,
                    R.drawable.images_02,
                    .
                    .
                    .
            };
        }

        @Override
        public int getItemCount() {
            return mDrawables.length;
        }

        @Override
        public MyViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {

            LayoutInflater inflater = (LayoutInflater) parent.getContext().getSystemService(Context.LAYOUT_INFLATER_SERVICE);
            View view = inflater.inflate(R.layout.layout_grid_item, parent, false);
            MyViewHolder holder = new MyViewHolder(view);
            // set up any onClickListener you need on the view here
            return holder;
        }

        @Override
        public void onBindViewHolder(MyViewHolder holder, int position) {

            holder.mImageView.setImageResource(mDrawables[position]);
            holder.mTextView.setText("Image " + position);
        }
    }

首先,创建一个 RecyclerView.ViewHolder 子类。 View 持有者模式现在是这种新的适配器 View 方式的组成部分。您的 ViewHolder 将为您的 View 设置所有 subview 。

然后在您的 RecyclerView.Adapter 子类中,覆盖 onCreateViewHolder()onBindViewHolder()。在 onCreateViewHolder() 中,你膨胀你的 View 并构造 ViewHolder。在 onBindViewHolder() 中,您使用 position 来获取适配器数据并使用 ViewHolder 设置 subview 。所以 RecyclerView 在技术上回收了包含 Views 的 ViewHolders。

对适配器进行这些更改后,您应该已准备就绪。

关于android - 具有两列的 GridView,第一项跨越两列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31092261/

相关文章:

android - 如何从Flutter中的mapbox获取当前位置

android - 无法启动 Activity ComponentInfo,仅来自 android N 的错误

android - 垂直滚动条与水平滚动 Android

java - 如何通过以编程方式提供 SELECTALL CHECKBOX 来检查多选警报框中的所有项目

java - Surface View 被挤压在 View 寻呼机内

java - 如何在真实设备上启动android应用程序

android - 我的 ScrollView 根本不起作用

java - 滑动刷新布局和 ScrollView 中的 WebView

android - 是否可以在蓝图模式下使用 ConstraintLayout 滚动 ScrollView?

Android - 向布局添加 View