【问题标题】:RecyclerView with Button only AdapterRecyclerView 与仅按钮适配器
【发布时间】:2019-10-16 17:54:39
【问题描述】:

所以我的杂货项目需要我(拥有 3 周的 Android 知识)为包含类别按钮的页面制作一个 RecyclerView。这些按钮应该将用户带到带有相应产品列表的片段。

我学到的方法是,我需要为item创建一个xml,将recyclerView放到main.xml中,并编写一个适配器。

我通过基本的 TextView 示例做到了这一点,我可以在其中轻松地将 .text 放入适配器中。但在这种情况下,我的项目完全由一个按钮组成。而且我不知道如何在适配器中调用它,因为对于TextView使用setText()更容易。

我不知道会有多少按钮,因为他们说他们会为项目提供API,其中也应该有类别按钮名称。

这就是我所拥有的:

cat_unit.xml

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

    <Button
        android:id="@+id/cat_btn"
        android:background="#000000"
        android:textColor="#ffffff"
        android:layout_margin="10dp"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"/>

</LinearLayout>

这是我的适配器:

CatAdapter.kt

package org.mp.chiproject01.adapter

import android.content.Context
import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup
import android.widget.Button
import androidx.recyclerview.widget.RecyclerView
import org.mp.chiproject01.R

class CatAdapter(var catList: ArrayList<String>, var context: Context): RecyclerView.Adapter<ViewHolder>() {
    override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ViewHolder {
        var v: View = LayoutInflater.from(context).inflate(R.layout.cat_unit, parent, false)
        return ViewHolder(v)
    }

    override fun getItemCount( ): Int {
        return catList.size
    }

    override fun onBindViewHolder(holder: ViewHolder, position: Int) {
        // I don't know what to put in the bind
        // Button will have different names, and I don't know how to 
        // Set the text for buttons
    }


}

class ViewHolder(view: View): RecyclerView.ViewHolder(view){
    var catBtn = view.findViewById<Button>(R.id.cat_btn)
}

这是带有 RecyclerView 的片段:

class FragmentCategory : Fragment() {


    var catList: ArrayList<String>()
    //Should I use 'String' or 'Button' here?

    override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View? {

        //View inflater for Fragment
        var view = inflater.inflate(R.layout.cat_unit, container, false)

        // Layout Manager and Adapter for RecyclerView
        view.recyclerViewmeat.layoutManager = LinearLayoutManager(context)
        view.recyclerViewmeat.adapter = CatAdapter(catList, this.context!!)

        //I don't know how if I can add them as 'String' or 'Button'
        //Can I do the setOnClickListener on the button the Button way
        //or do I have to write my own onClick to handle this? 

        return view

    }
}

谢谢!如果有任何提示/良好的编码实践,请告诉我!

【问题讨论】:

  • 如果我知道了,所有按钮名称都是存储在catList: ArrayList&lt;String&gt; 中的那些字符串?
  • FragmentCategory 应该扩大包含 RecyclerView 的布局。然后,适配器将为每个项目膨胀布局。在您的代码中,片段和适配器都在膨胀相同的布局:cat_unit.xml。

标签: android android-recyclerview android-adapter android-button


【解决方案1】:

您似乎很难理解RecyclerView 的工作原理。

我应该在这里使用“字符串”还是“按钮”?

我们通常将一个数据列表传递给适配器类,这个列表将用于在 RecyclerView 视图中填充数据(因此我们永远不会传递按钮或类似的东西),并且 RecyclerView 负责为我们创建视图,具体取决于我们在CatAdapter类中的RecyclerView中传入的数据列表大小:

override fun getItemCount( ): Int {
        return catList.size
}

现在,对于每个位置,RecyclerView 将创建一个 ViewHolder,它将我们的 Layout 保存为 View,这就是 onCreateViewHolderCatAdapter 中发生的情况:

override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ViewHolder {
//Inflating our layout (inflaing simple words, it's just a process to convert xml layout to View.
var v: View = LayoutInflater.from(context).inflate(R.layout.cat_unit, parent, false)
//Creating a ViewHolder that holds the view inside it.
return ViewHolder(v)
}

最后一件事,onBindViewHolder 在 ViewHolder 附加到 ReyclerView 时被调用,这是绑定数据(用数据填充我们的视图)和设置视图上的单击侦听器(在您的情况下为按钮)的合适位置。那么如何在那个Button上绑定数据和setOnClickListener呢? 先来看看onBindViewHolder()

override fun onBindViewHolder(holder: ViewHolder, position: Int) {

}

在参数中:

  • holder: ViewHolder 保存我们的视图,我们可以使用它来绑定数据和点击监听器。
  • position: Int 的当前视图,我们将使用此位置从我们的列表中获取数据(在您的情况下为 catList)。

现在你知道如何使用onBindViewHolder,让我们编写代码(CatAdapter 类):

package org.mp.chiproject01.adapter

import android.content.Context
import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup
import android.widget.Button
import androidx.recyclerview.widget.RecyclerView
import org.mp.chiproject01.R

class CatAdapter(var catList: ArrayList<String>, var context: Context): RecyclerView.Adapter<ViewHolder>() {
    override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ViewHolder {
        var v: View = LayoutInflater.from(context).inflate(R.layout.cat_unit, parent, false)
        return ViewHolder(v)
    }

    override fun getItemCount( ): Int {
        return catList.size
    }

    override fun onBindViewHolder(holder: ViewHolder, position: Int) {
      //First, get data from catList by position.
      val data = catList[position]
      //Then, bind this data to the views (the button).
      holder.catBtn.text = data
      holder.catBtn.setOnClickListener {
      //Do something when button clicked
      }
    }


}

class ViewHolder(view: View): RecyclerView.ViewHolder(view){
    //catBtn should be val since it'll never change.
    val catBtn = view.findViewById<Button>(R.id.cat_btn)
}

注意: 确保您将FragmentCategory 附加到您的活动中,并将数据传递给FragmentCategory 中的catList

【讨论】:

  • 非常感谢!你让它很容易理解。教程看了太多,搞得一头雾水!
猜你喜欢
  • 2020-12-29
  • 2015-12-04
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2016-04-08
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多