RecyclerView 与同一行中的各种元素
RecyclerView with various elements in the same line
我想制作一个 RecyclerView
每行都有不同的元素,具体取决于适配器中的布尔值。
在我的应用程序中,您有一些钞票和硬币。我必须把所有的都放在一个 RecyclerView
中。首先,我想展示钞票(每 2 张 2 张)和硬币(每 4 张 4 张)
像这样:
这就是我想要的结果:
这是我的适配器
class MoneyAdapter(private val money_list: ArrayList<Money>) : RecyclerView.Adapter<MoneyAdapter.ViewHolder>() {
override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): MoneyAdapter.ViewHolder {
val v = LayoutInflater.from(parent.context).inflate(R.layout.item_money, parent, false)
return ViewHolder(v)
}
override fun onBindViewHolder(holder: MoneyAdapter.ViewHolder, position: Int) {
money_map.put(money_list[position].value, 0)
holder.bindItems(money_list[position])
}
inner class ViewHolder(itemView: View) : RecyclerView.ViewHolder(itemView) {
fun bindItems(money: Money) {
// if (money.isCoin) I would like to put it on a 4 element per line
}
}
}
override fun getItemCount(): Int {
return money_list.size
}
}
这是我声明我的 RecyclerView 的地方:
recycler_money.layoutManager = StaggeredGridLayoutManager(2, StaggeredGridLayoutManager.VERTICAL)
recycler_money.adapter = MoneyAdapter(getMoneyList(PrefsModel.currency)
我搜索了很多示例,但使用 StaggeredGridLayoutManager
总是有不同的 col/row,我只想直接在 [=15] 上按行(2 或 4)更改元素数=].
感谢@Gautam,我找到了解决方案:
val l = GridLayoutManager(context, 4)
l.spanSizeLookup = object : GridLayoutManager.SpanSizeLookup() {
override fun getSpanSize(position: Int): Int {
if (getMoneyList(PrefsModel.currency)[position].type == MONEY_PIECE)
return 1
else
return 2
}
}
recycler_money.layoutManager = l
我想制作一个 RecyclerView
每行都有不同的元素,具体取决于适配器中的布尔值。
在我的应用程序中,您有一些钞票和硬币。我必须把所有的都放在一个 RecyclerView
中。首先,我想展示钞票(每 2 张 2 张)和硬币(每 4 张 4 张)
像这样:
这就是我想要的结果:
这是我的适配器
class MoneyAdapter(private val money_list: ArrayList<Money>) : RecyclerView.Adapter<MoneyAdapter.ViewHolder>() {
override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): MoneyAdapter.ViewHolder {
val v = LayoutInflater.from(parent.context).inflate(R.layout.item_money, parent, false)
return ViewHolder(v)
}
override fun onBindViewHolder(holder: MoneyAdapter.ViewHolder, position: Int) {
money_map.put(money_list[position].value, 0)
holder.bindItems(money_list[position])
}
inner class ViewHolder(itemView: View) : RecyclerView.ViewHolder(itemView) {
fun bindItems(money: Money) {
// if (money.isCoin) I would like to put it on a 4 element per line
}
}
}
override fun getItemCount(): Int {
return money_list.size
}
}
这是我声明我的 RecyclerView 的地方:
recycler_money.layoutManager = StaggeredGridLayoutManager(2, StaggeredGridLayoutManager.VERTICAL)
recycler_money.adapter = MoneyAdapter(getMoneyList(PrefsModel.currency)
我搜索了很多示例,但使用 StaggeredGridLayoutManager
总是有不同的 col/row,我只想直接在 [=15] 上按行(2 或 4)更改元素数=].
感谢@Gautam,我找到了解决方案:
val l = GridLayoutManager(context, 4)
l.spanSizeLookup = object : GridLayoutManager.SpanSizeLookup() {
override fun getSpanSize(position: Int): Int {
if (getMoneyList(PrefsModel.currency)[position].type == MONEY_PIECE)
return 1
else
return 2
}
}
recycler_money.layoutManager = l