У меня проблема с моим адаптером RecyclerView.Я хотел бы вызвать этот метод в своем классе RecyclerView Adapter:
class UIManager {
companion object {
fun updateElem(fromActivity: Activity?)
{
if (fromActivity == null) { return }
val number: TextView = fromActivity.findViewById(R.id.box)
var chest = fromActivity.resources.getString(R.string.chests)
if (DataManager.boxes?.size!! < 2)
chest = fromActivity.resources.getString(R.string.chest)
number.text = DataManager.boxes?.size?.let { "" + DataManager.boxes?.size + " " + chest } ?: "0 " + chest
}
}
}
Обычно я мог бы просто создать метод в моем адаптере и передать Activity в качестве параметра, а затем вызвать updateElem ().
BUTЯ много чего перепробовал, и у меня это не сработало, потому что даже если я это сделаю, я вызываю его в методе переопределения моего адаптера, см .:
class RecyclerAdapter(val list: ArrayList<String>) : RecyclerView.Adapter<RecyclerAdapter.ViewHolder>()
{
override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ViewHolder {
val view: View = LayoutInflater.from(parent.context).inflate((R.layout.box_elem), parent, false)
return ViewHolder(view)
}
override fun getItemId(position: Int): Long {
return position.toLong()
}
override fun getItemViewType(position: Int): Int {
return position
}
override fun getItemCount(): Int {
return list.size
}
override fun onBindViewHolder(holder: ViewHolder, position: Int) {
holder.image.setImageResource(R.drawable.original_box)
holder.itemView.setOnClickListener(View.OnClickListener {
removeElemAt(position)
})
}
fun removeElemAt(position: Int) {
list.removeAt(position)
notifyItemRemoved(position)
notifyItemRangeChanged(position, list.size)
// I WANT TO USE THE METHOD HERE
// !!
UIManager.updateElem() <--------------
//
}
class ViewHolder(itemView: View) : RecyclerView.ViewHolder(itemView){
var image: ImageView = itemView.findViewById(R.id.box_elem)
}
}
}