RecyclerView结合ViewBinding的使用

引入ViewBinding

在这里插入图片描述

android {
compileSdk 32

defaultConfig {
    ... ...
    viewBinding {
        enabled = true
    }
}

添加Adapter子布局

在这里插入图片描述

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:background="#D05C5C"
    android:orientation="vertical"
    android:padding="16dp">

    <TextView
        android:id="@+id/main_name"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="小王" />

    <TextView
        android:id="@+id/main_phone"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginTop="16dp"
        android:text="123543123" />
</LinearLayout>

RecyclerViewAdapter实现

在这里插入图片描述

import android.annotation.SuppressLint;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.ViewGroup;

import androidx.annotation.NonNull;

import androidx.recyclerview.widget.RecyclerView;

import com.example.recyclerview.databinding.ViewMainBinding;

import java.util.List;

public class MainAdapter extends RecyclerView.Adapter<MainAdapter.MainViewHolder> {
    private static final String TAG = "MainAdapter";
    private List<String> mList;

    @SuppressLint("NotifyDataSetChanged")
    public void setList(List<String> list) {
        mList = list;
        Log.e(TAG, "setList: " + mList);
        notifyDataSetChanged();
    }

    @NonNull
    @Override
    public MainViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
        ViewMainBinding binding = ViewMainBinding
                .inflate(LayoutInflater.from(parent.getContext()), parent, false);
        return new MainViewHolder(binding);
    }

    @SuppressLint("SetTextI18n")
    @Override
    public void onBindViewHolder(@NonNull MainViewHolder holder, int position) {
        holder.binding.mainName.setText("小明: " + position);
        holder.binding.mainPhone.setText(String.valueOf(position * 31321));
    }

    @Override
    public int getItemCount() {
        return mList == null ? 0 : mList.size();
    }

    static class MainViewHolder extends RecyclerView.ViewHolder {
        final ViewMainBinding binding;

        MainViewHolder(ViewMainBinding binding) {
            super(binding.getRoot());
            this.binding = binding;
        }
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现自定义 RecyclerView结合 `computeVerticalScrollExtent()` 设置 scrollbar 高度,你可以继承 RecyclerView 实现自己的 RecyclerView,然后在它的 `onDraw()` 方法中计算可见 item 数量和滚动条高度,再在 `onMeasure()` 方法中设置 scrollbar 的高度。 首先,你需要在自定义 RecyclerView 中重写 `onDraw()` 方法: ```java @Override protected void onDraw(Canvas canvas) { super.onDraw(canvas); // 计算可见 item 数量 int visibleItemCount = getLayoutManager().getChildCount(); // 计算所有 item 的数量 int totalItemCount = getLayoutManager().getItemCount(); // 计算垂直方向上当前可见的视图区域的大小 int verticalScrollExtent = computeVerticalScrollExtent(); // 计算滚动条的高度 int scrollBarHeight = (int) ((float) verticalScrollExtent / (float) totalItemCount * getHeight()); // 绘制滚动条 Paint paint = new Paint(); paint.setColor(Color.RED); canvas.drawRect(getWidth() - 20, 0, getWidth(), scrollBarHeight, paint); } ``` 在这段代码中,我们使用 `computeVerticalScrollExtent()` 方法计算垂直方向上当前可见的视图区域的大小,然后根据可见 item 数量、所有 item 的数量和视图区域的大小计算出滚动条的高度,最后在 Canvas 上绘制滚动条。 接下来,你还需要在自定义 RecyclerView 中重写 `onMeasure()` 方法: ```java @Override protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { super.onMeasure(widthMeasureSpec, heightMeasureSpec); // 计算滚动条的高度 int verticalScrollExtent = computeVerticalScrollExtent(); int totalItemCount = getLayoutManager().getItemCount(); int scrollBarHeight = (int) ((float) verticalScrollExtent / (float) totalItemCount * getHeight()); // 设置滚动条的高度 setMeasuredDimension(getMeasuredWidth(), getMeasuredHeight() + scrollBarHeight); } ``` 在这段代码中,我们使用 `computeVerticalScrollExtent()` 方法计算垂直方向上当前可见的视图区域的大小,然后根据视图区域的大小计算出滚动条的高度,并将 RecyclerView 的高度加上滚动条的高度,从而保证滚动条不会遮挡 RecyclerView。 最后,你需要在自定义 RecyclerView 中调用 `setWillNotDraw(false)` 方法,以启用绘制滚动条的功能: ```java public MyRecyclerView(Context context) { super(context); setWillNotDraw(false); } ``` 这样,你就可以实现自定义 RecyclerView结合 `computeVerticalScrollExtent()` 设置 scrollbar 高度的效果了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值