我有一个ImageView和一个GridView..
我的布局设计在这里..
我想将这两个视图合并为单个GridView
我的问题是:
如何设置GridView的第一个项目跨越两列?
我有一个ImageView和一个GridView..
我的布局设计在这里..
我想将这两个视图合并为单个GridView
我的问题是:
如何设置GridView的第一个项目跨越两列?
在研究您的问题时,我学到了一些新知识:我碰巧看到了用于RecyclerView
的GridLayoutManager
,并且我注意到您可以设置自定义的SpanSizeLookup
。现在,“span”只是一个列,如果垂直滚动,则为行。因此,SpanSizeLookup
允许您指定例如,第0项占据2列,第1项占据1列等。
结果发现,如果使用GridLayoutManager
的RecyclerView
,解决方案非常简单:
@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.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);
}
}
首先,创建一个RecyclerView.ViewHolder
子类。视图持有者模式现在成为了适配器视图新方式中的一个必要组成部分。您的ViewHolder
将为您的视图设置所有子视图。
然后,在您的RecyclerView.Adapter
子类中,重写onCreateViewHolder()
和onBindViewHolder()
方法。在onCreateViewHolder()
中,您需要填充您的视图并构造ViewHolder
对象。在onBindViewHolder()
中,您使用position
从适配器数据中获取信息,并使用ViewHolder
来设置子视图。因此,RecyclerView
会技术性地回收包含View
的ViewHolder
。
一旦您对适配器做出这些更改,就可以开始使用了。
RecyclerView.Adapter
与ListAdapter
不兼容,因此您需要稍微重新调整一下适配器。我会更新我的答案,添加一些相关内容。 - kris larsonGridView
和RecyclerView.GridLayoutManager
的文档,然后看到了SpanSizeLookup
,突然间有了灵感。但是我还是需要做一个测试项目来确保我的直觉是正确的。 - kris larson