我有一个 Imageview 和一个 gridview..
我的布局设计在这里..
我想将这两个 View 组合成一个 GridView
我的问题:
如何在两列中设置gridview的第一项跨度?
最佳答案
在研究您的问题时,我学到了一些新东西:我碰巧查看了 RecyclerView
的 GridLayoutManager
,我注意到您可以设置自定义 SpanSizeLookup
。现在,如果您垂直滚动,“跨度”只是一列,如果您水平滚动,则只是一行。所以 SpanSizeLookup
允许您指定例如,项目 0 占用 2 列,项目 1 占用 1 列,等等。
事实证明,如果您将 RecyclerView
与 GridLayoutManager
一起使用,解决方案很简单:
@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
子类。 View 持有者模式现在是这种新的适配器 View 方式的组成部分。您的 ViewHolder
将为您的 View 设置所有 subview 。
然后在您的 RecyclerView.Adapter
子类中,覆盖 onCreateViewHolder()
和 onBindViewHolder()
。在 onCreateViewHolder()
中,你膨胀你的 View 并构造 ViewHolder
。在 onBindViewHolder()
中,您使用 position
来获取适配器数据并使用 ViewHolder
设置 subview 。所以 RecyclerView
在技术上回收了包含 View
s 的 ViewHolder
s。
对适配器进行这些更改后,您应该已准备就绪。
关于android - 具有两列的 GridView,第一项跨越两列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31092261/