Android 水平布局的回收视图
创始人
2024-08-15 18:00:07
0

在Android中实现水平布局的回收视图,可以通过使用RecyclerView和自定义LayoutManager来实现。下面是一个示例代码,演示如何实现水平布局的回收视图。

  1. 创建一个布局文件activity_main.xml,其中包含一个RecyclerView:

  1. 创建一个item的布局文件item_layout.xml,用于定义每个item的视图:

  1. 创建一个自定义的LayoutManager类,继承自LinearLayoutManager,并覆盖onLayoutChildren()方法:
public class CustomLayoutManager extends LinearLayoutManager {

    public CustomLayoutManager(Context context) {
        super(context);
    }

    public CustomLayoutManager(Context context, int orientation, boolean reverseLayout) {
        super(context, orientation, reverseLayout);
    }

    @Override
    public void onLayoutChildren(RecyclerView.Recycler recycler, RecyclerView.State state) {
        super.onLayoutChildren(recycler, state);
        scrollHorizontallyBy(0, recycler, state);
    }

    private int scrollHorizontallyBy(int dx, RecyclerView.Recycler recycler, RecyclerView.State state) {
        int scrolled = super.scrollHorizontallyBy(dx, recycler, state);
        fill(recycler);
        return scrolled;
    }

    private void fill(RecyclerView.Recycler recycler) {
        int leftEdge = getWidth() - getPaddingRight();
        int rightEdge = getWidth() - getPaddingRight() + getMaxChildWidth();
        int topEdge = getPaddingTop();
        int bottomEdge = getHeight() - getPaddingBottom();

        int itemCount = getItemCount();
        int childCount = getChildCount();
        int lastPosition = childCount > 0 ? getPosition(getChildAt(childCount - 1)) : -1;

        while (rightEdge > leftEdge && lastPosition < itemCount - 1) {
            lastPosition++;
            View view = recycler.getViewForPosition(lastPosition);
            addView(view);
            measureChildWithMargins(view, 0, 0);

            int width = getDecoratedMeasuredWidth(view);
            int height = getDecoratedMeasuredHeight(view);

            layoutDecoratedWithMargins(view, rightEdge - width, topEdge, rightEdge, topEdge + height);

            rightEdge -= width;
        }

        while (getChildCount() > 0 && getDecoratedRight(getChildAt(0)) < getPaddingLeft()) {
            removeAndRecycleView(getChildAt(0), recycler);
        }
    }

    private int getMaxChildWidth() {
        int maxChildWidth = 0;
        for (int i = 0; i < getChildCount(); i++) {
            View child = getChildAt(i);
            int width = getDecoratedMeasuredWidth(child);
            if (width > maxChildWidth) {
                maxChildWidth = width;
            }
        }
        return maxChildWidth;
    }
}
  1. 在MainActivity中设置RecyclerView的LayoutManager为自定义的CustomLayoutManager,并创建一个适配器Adapter:
public class MainActivity extends AppCompatActivity {

    private RecyclerView recyclerView;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        recyclerView = findViewById(R.id.recyclerView);
        recyclerView.setLayoutManager(new CustomLayoutManager(this, LinearLayoutManager.HORIZONTAL, false));

        List dataList = new ArrayList<>();
        for (int i = 0; i < 10; i++) {
            dataList.add("Item " + (i + 1));
        }

        Adapter adapter = new Adapter(dataList);
        recyclerView.setAdapter(adapter);
    }
}
  1. 创建一个适配器Adapter,用于将数据绑定到item上:
public class Adapter extends RecyclerView.Adapter {

    private List dataList;

    public Adapter(List 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) {
        String data = dataList.get(position);
        holder.textView.setText(data);
    }

    @Override
    public int getItemCount() {
        return dataList.size();
    }

    public static class ViewHolder extends RecyclerView.ViewHolder {
        TextView textView;

相关内容

热门资讯

黑科技中牌率!微扑克有后台控制... 黑科技中牌率!微扑克有后台控制吗(ai代打)太坑了真的有挂(必胜教程黑科技细节)-哔哩哔哩1、玩家可...
黑科技app(AAPoker)... 黑科技app(AAPoker)ai辅助实战案例(透视)智能ai辅助介绍(原生是有挂);(需添加指定威...
黑科技辅助挂!微扑克系统发牌逻... 黑科技辅助挂!微扑克系统发牌逻辑,wpk辅助插件,爆料教程(有挂辅助挂)-哔哩哔哩1)微扑克系统发牌...
黑科技脚本"wpk微... 黑科技脚本"wpk微扑克模拟器"云扑克辅助器(其实真的是有挂)-哔哩哔哩;1、每一步都需要思考,不同...
黑科技智能ai!wepoke有... 黑科技智能ai!wepoke有挂么(黑科技)一贯真的是有挂(有挂德州版)-哔哩哔哩;原来确实真的有挂...
黑科技免费(aa扑克辅助)外挂... 黑科技免费(aa扑克辅助)外挂透明挂辅助挂(透视)原来有挂(黑科技黑科技)-哔哩哔哩;1、让任何用户...
黑科技透明!微扑克全自动机器人... 黑科技透明!微扑克全自动机器人(智能ai)太坑了真的是有挂(2025新版技巧黑科技详情)-哔哩哔哩1...
黑科技挂!德扑ai助手,智星德... 黑科技挂!德扑ai助手,智星德州菠萝辅助,总结教程(有挂总结)-哔哩哔哩1)智星德州菠萝辅助辅助挂:...
黑科技计算(aapOker)德... 《黑科技计算(aapOker)德州ai机器人(透视)辅助软件(原先存在有挂)》 德州ai机器人软件透...
黑科技挂!微扑克ai算牌器(透... 这是一款非常优秀的微扑克ai算牌器 ia辅助检测软件,能够让你了解到微扑克ai算牌器中牌率当中全部隐...