万能适配器basequickadapter + recycleview实现单选并且默认选择第一个

1、首先,确保您已经添加了BaseQuickAdapter和RecyclerView的依赖项。您可以在项目的build.gradle文件中添加以下依赖项:

dependencies {
    implementation 'com.github.CymChad:BaseRecyclerViewAdapterHelper:3.0.4'
    implementation 'androidx.recyclerview:recyclerview:1.2.1'
}

2、创建一个数据模型类来表示每个列表项的数据。例如,假设您有一个名为Item的数据类:

public class Item {
    private String name;
    private boolean isSelected;

    public Item(String name) {
        this.name = name;
        this.isSelected = false;
    }

    public String getName() {
        return name;
    }

    public boolean isSelected() {
        return isSelected;
    }

    public void setSelected(boolean selected) {
        isSelected = selected;
    }
}

3、创建一个Adapter类,继承自BaseQuickAdapter<Item, BaseViewHolder>。在Adapter中,您需要处理单选逻辑以及默认选择第一个项的逻辑:

public class ItemAdapter extends BaseQuickAdapter<Item, BaseViewHolder> {

    public ItemAdapter(@Nullable List<Item> data) {
        super(R.layout.item_layout, data);
    }

    @Override
    protected void convert(BaseViewHolder helper, Item item) {
        helper.setText(R.id.text_view, item.getName());
        // 设置选中状态的背景色
        if (item.isSelected()) {
            helper.itemView.setBackgroundColor(ContextCompat.getColor(mContext, R.color.selected_color));
        } else {
            helper.itemView.setBackgroundColor(Color.TRANSPARENT);
        }
    }

    public void setItemSelected(int position) {
        for (int i = 0; i < getData().size(); i++) {
            getData().get(i).setSelected(i == position);
        }
        notifyDataSetChanged();
    }
}

4、在您的Activity或Fragment中,初始化RecyclerView和Adapter,并设置默认选择第一个项:

public class MainActivity extends AppCompatActivity {

    private RecyclerView recyclerView;
    private ItemAdapter adapter;
    private List<Item> itemList = new ArrayList<>();

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

        recyclerView = findViewById(R.id.recycler_view);
        recyclerView.setLayoutManager(new LinearLayoutManager(this));

        // 初始化数据
        for (int i = 0; i < 10; i++) {
            itemList.add(new Item("Item " + (i + 1)));
        }

        // 创建Adapter并设置默认选中第一个项
        adapter = new ItemAdapter(itemList);
        adapter.setItemSelected(0);

        recyclerView.setAdapter(adapter);

        // 设置RecyclerView的点击事件
        adapter.setOnItemClickListener((adapter, view, position) -> {
            adapter.setSelected(position);
        });
    }
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面是Kotlin实现的BRVAH和RecyclerView实现无限循环滚动和可点击item的代码: 1. 首先在build.gradle中添加BRVAH依赖: ``` implementation 'com.github.CymChad:BaseRecyclerViewAdapterHelper:3.0.4' ``` 2. 在布局文件中添加RecyclerView: ``` <androidx.recyclerview.widget.RecyclerView android:id="@+id/recyclerView" android:layout_width="match_parent" android:layout_height="match_parent" /> ``` 3. 在Activity或Fragment中初始化RecyclerView: ``` val recyclerView = findViewById<RecyclerView>(R.id.recyclerView) val layoutManager = LinearLayoutManager(this) layoutManager.orientation = LinearLayoutManager.HORIZONTAL // 设置为横向滚动 recyclerView.layoutManager = layoutManager ``` 4. 创建Adapter并继承BaseQuickAdapter: ``` class MyAdapter(data: List<String>?) : BaseQuickAdapter<String, BaseViewHolder>(R.layout.item_layout, data) { override fun convert(holder: BaseViewHolder, item: String) { // 设置item的显示内容 holder.setText(R.id.tvItemName, item) } } ``` 5. 创建数据源并初始化Adapter: ``` val dataList = listOf("item1", "item2", "item3", "item4", "item5") val myAdapter = MyAdapter(dataList) recyclerView.adapter = myAdapter ``` 6. 实现无限循环滚动: ``` recyclerView.post { val layoutManager = recyclerView.layoutManager as LinearLayoutManager val firstItem = layoutManager.findFirstVisibleItemPosition() val lastItem = layoutManager.findLastVisibleItemPosition() val itemCount = layoutManager.itemCount // 如果当前第一个可见item是第0个item,则将RecyclerView滚动到最后一个item的位置 if (firstItem == 0) { recyclerView.scrollToPosition(itemCount - 1) } // 如果当前最后一个可见item是最后一个item,则将RecyclerView滚动到第一个item的位置 else if (lastItem == itemCount - 1) { recyclerView.scrollToPosition(0) } } ``` 7. 实现可点击item: ``` myAdapter.setOnItemClickListener { adapter, view, position -> // 处理item的点击事件 } ``` 以上就是BRVAH和RecyclerView实现无限循环滚动和可点击item的Kotlin代码。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值