實(shí)現(xiàn)瀑布流布局效果可以使用RecyclerView控件配合StaggeredGridLayoutManager來實(shí)現(xiàn)。具體步驟如下:
<androidx.recyclerview.widget.RecyclerView
android:id="@+id/recycler_view"
android:layout_width="match_parent"
android:layout_height="match_parent" />
RecyclerView recyclerView = findViewById(R.id.recycler_view);
StaggeredGridLayoutManager layoutManager = new StaggeredGridLayoutManager(2, StaggeredGridLayoutManager.VERTICAL);
recyclerView.setLayoutManager(layoutManager);
public class MyAdapter extends RecyclerView.Adapter<MyAdapter.ViewHolder> {
private List<String> dataList;
public MyAdapter(List<String> dataList) {
this.dataList = dataList;
}
@NonNull
@Override
public ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.item_layout, parent, false);
return new ViewHolder(view);
}
@Override
public void onBindViewHolder(@NonNull ViewHolder holder, int position) {
ViewGroup.LayoutParams layoutParams = holder.itemView.getLayoutParams();
layoutParams.height = (int) (100 + Math.random() * 300); // 設(shè)置item的高度,可以根據(jù)需要自行調(diào)整
holder.itemView.setLayoutParams(layoutParams);
}
@Override
public int getItemCount() {
return dataList.size();
}
class ViewHolder extends RecyclerView.ViewHolder {
public ViewHolder(@NonNull View itemView) {
super(itemView);
}
}
}
List<String> dataList = new ArrayList<>();
// 添加數(shù)據(jù)到dataList
MyAdapter adapter = new MyAdapter(dataList);
recyclerView.setAdapter(adapter);
通過以上步驟,即可實(shí)現(xiàn)瀑布流布局效果。在Adapter的onBindViewHolder方法中設(shè)置item的高度,可以根據(jù)需求動(dòng)態(tài)調(diào)整每個(gè)item的高度,從而使得瀑布流布局效果更加靈活和多樣化。