Android: 如何创建类似 Facebook 的图片库网格?
Android: How to create a Facebook like images gallery grid?
我正在尝试实现类似 facebook 的画廊网格,其中的项目具有不同的大小:
我尝试使用不同的 libraries/solutions 但目前没有成功:
我尝试使用 AsymemetricGridView。
但是这个实现的问题是在抛出适配器后网格中留下了空白的死角。
我也考虑过使用 StaggeredGridLayoutManager
和 RecycleView
,但是在这种情况下,项目在实施时与其他项目的尺寸不相等或一半在 Facebook 图库中。
现在我想在适配器中为不同的情况提供不同的视图持有者,但我真的不喜欢这个想法。完成此任务的更好方法是什么?
您可以将 recyclerview 与 StaggeredGridLayoutManager 结合使用来完成此操作。 StaggeredGridLAyoutManager 已经处理了这个问题,您也可以使用 setFullSpan 为图像使用整行
最后,我决定使用 TwoWayView 库。
你可以从:https://github.com/lucasr/twoway-view
在我的代码中,我做了以下主要更改:
在 xml 布局中添加了 TwoWayView:
<org.lucasr.twowayview.widget.TwoWayView
android:id="@+id/twvGrid"
android:background="@android:color/white"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
style="@style/TwoWayView"
app:twowayview_layoutManager="SpannableGridLayoutManager"
app:twowayview_numColumns="3"
app:twowayview_numRows="3" />
我在代码中做了以下更改:
private TwoWayView mTwvGrid;
.........
mTwvGrid = (TwoWayView) findViewById(R.id.twvGrid);
final Drawable divider = getResources().getDrawable(R.drawable.divider);
mTwvGrid.addItemDecoration(new DividerItemDecoration(divider));
mTwvGrid.setOnScrollListener(new RecyclerView.OnScrollListener() {
@Override
public void onScrollStateChanged(RecyclerView recyclerView, int newState) {
RequestManager glideRequestManager = Glide.with(TimelineStoryActivity.this);
if (newState == RecyclerView.SCROLL_STATE_IDLE || newState == RecyclerView.SCROLL_STATE_SETTLING) {
glideRequestManager.resumeRequests();
} else {
glideRequestManager.pauseRequests();
}
}
@Override
public void onScrolled(RecyclerView recyclerView, int dx, int dy) {}
});
.......
if (mAdapter == null) {
mAdapter = new TimelineStoryRecycleAdapter(this, mStory, mTwvGrid, this);
mTwvGrid.setAdapter(mAdapter);
} else {
mAdapter.setStory(mStory);
}
这是最终结果:
我正在尝试实现类似 facebook 的画廊网格,其中的项目具有不同的大小:
我尝试使用不同的 libraries/solutions 但目前没有成功:
我尝试使用 AsymemetricGridView。 但是这个实现的问题是在抛出适配器后网格中留下了空白的死角。
我也考虑过使用
StaggeredGridLayoutManager
和RecycleView
,但是在这种情况下,项目在实施时与其他项目的尺寸不相等或一半在 Facebook 图库中。
现在我想在适配器中为不同的情况提供不同的视图持有者,但我真的不喜欢这个想法。完成此任务的更好方法是什么?
您可以将 recyclerview 与 StaggeredGridLayoutManager 结合使用来完成此操作。 StaggeredGridLAyoutManager 已经处理了这个问题,您也可以使用 setFullSpan 为图像使用整行
最后,我决定使用 TwoWayView 库。
你可以从:https://github.com/lucasr/twoway-view
在我的代码中,我做了以下主要更改:
在 xml 布局中添加了 TwoWayView:
<org.lucasr.twowayview.widget.TwoWayView
android:id="@+id/twvGrid"
android:background="@android:color/white"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
style="@style/TwoWayView"
app:twowayview_layoutManager="SpannableGridLayoutManager"
app:twowayview_numColumns="3"
app:twowayview_numRows="3" />
我在代码中做了以下更改:
private TwoWayView mTwvGrid;
.........
mTwvGrid = (TwoWayView) findViewById(R.id.twvGrid);
final Drawable divider = getResources().getDrawable(R.drawable.divider);
mTwvGrid.addItemDecoration(new DividerItemDecoration(divider));
mTwvGrid.setOnScrollListener(new RecyclerView.OnScrollListener() {
@Override
public void onScrollStateChanged(RecyclerView recyclerView, int newState) {
RequestManager glideRequestManager = Glide.with(TimelineStoryActivity.this);
if (newState == RecyclerView.SCROLL_STATE_IDLE || newState == RecyclerView.SCROLL_STATE_SETTLING) {
glideRequestManager.resumeRequests();
} else {
glideRequestManager.pauseRequests();
}
}
@Override
public void onScrolled(RecyclerView recyclerView, int dx, int dy) {}
});
.......
if (mAdapter == null) {
mAdapter = new TimelineStoryRecycleAdapter(this, mStory, mTwvGrid, this);
mTwvGrid.setAdapter(mAdapter);
} else {
mAdapter.setStory(mStory);
}
这是最终结果: