GridView有两列,第一项跨越两列

And*_*Dev 23 android android-scrollview

我有一个Imageview和一个gridview ..

我的布局设计在这里..

在此输入图像描述

我想将这两个视图合并到单个gridview中

我的问题:

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

kri*_*son 53

在研究你的问题,我学到新的东西:我碰巧看到GridLayoutManagerRecyclerView,我注意到,你可以设置自定义SpanSizeLookup.现在,如果你是垂直滚动,"span"只是一列,如果你是水平滚动,则只是一行.因此,SpanSizeLookup允许您指定例如,项目0需要2列,项目1需要1列,等等.

事实证明,如果你使用RecyclerViewGridLayoutManager该解决方案是易于peasy:

    @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());
    }
Run Code Online (Sandbox Code Playgroud)

我创建了一个测试项目,只是为了尝试它并确保它完成了我的预期,它就像一个魅力.


关于适配器的说明: RecyclerView.Adapter不兼容ListAdapter.您需要扩展适配器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);
        }
    }
Run Code Online (Sandbox Code Playgroud)

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

然后在你的RecyclerView.Adapter子类中,覆盖onCreateViewHolder()onBindViewHolder().在onCreateViewHolder()你膨胀视图和构建ViewHolder.在onBindViewHolder(),您position用来获取适配器数据并使用ViewHolder.设置子视图.所以RecyclerView技术上回收ViewHolder包含Views的东西.

对适配器进行这些更改后,应该全部设置好.

  • 具体不知道。做了这么多年的事情,我觉得有一种本能。我刚刚开始浏览“GridView”和“RecyclerView.GridLayoutManager”的文档,然后我看到“SpanSizeLookup”并点击了一些东西。但我必须做一个测试项目来确保我的预感是正确的。 (2认同)