Как очистить ввод EditText от всех представлений элементов RecyclerView? - PullRequest
3 голосов
/ 01 июля 2019

Я ищу решение для перебора всех видов моих элементов Recycler View Adapter, чтобы получить EditTexts и изменить входные данные.

Я использую список RecyclerView. Строки элементов содержат EditText. Когда пользователь нажимает кнопку, я хочу очистить ввод всех представлений, даже тех, которые еще не связаны. Как мне это сделать?

class ScoresAdapter : RecyclerView.Adapter<ScoresViewHolder>() {

private var scores: List<Score> = ArrayList()
private var listener: ScoreItemListener? = null

override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ScoresViewHolder {
    val view =
        LayoutInflater
            .from(parent.context)
            .inflate(R.layout.score_item, parent, false)

    return ScoresViewHolder(view)
}

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

override fun onBindViewHolder(holder: ScoresViewHolder, position: Int) {
    val score = scores[position]

    holder.playerView.text = score.player.email
    holder.totalScoreView.text = score.total().toString()
}

fun setItemListener(listener: ScoreItemListener) {
    this.listener = listener
}

fun loadScores(scores: ArrayList<Score>) {
    this.scores = scores
    notifyDataSetChanged()
}

fun clearInputs() {
    // for all scores in list remove text from EditText and set ""
}

inner class ScoresViewHolder(itemView: View) : RecyclerView.ViewHolder(itemView) {
    var playerView = itemView.findViewById<TextView>(R.id.player)!!
    var currentScoreView = itemView.findViewById<EditText>(R.id.current_score)!!
    var totalScoreView = itemView.findViewById<TextView>(R.id.total_score)!!

    init {
        setTextChangedListener(itemView)
    }

    private fun setTextChangedListener(itemView: View) {
        if (listener != null)
            currentScoreView.addTextChangedListener(object : TextWatcher {
                override fun afterTextChanged(s: Editable?) {

                }

                override fun beforeTextChanged(s: CharSequence?, start: Int, count: Int, after: Int) {

                }

                override fun onTextChanged(text: CharSequence?, start: Int, before: Int, count: Int) {
                    listener!!.textChanged(itemView, text!!.toString(), adapterPosition)
                }

            })
    }
}
}

Ответы [ 3 ]

3 голосов
/ 01 июля 2019

Вы можете сделать что-то, как показано ниже: *

var clearEditText = false

override fun onBindViewHolder(holder: ScoresViewHolder, position: Int) {
    val score = scores[position]

    holder.playerView.text = if(clearEditText) "" else score.player.email
    holder.totalScoreView.text = score.total().toString()
}


fun clearInputs() {
    clearEditText = true
    notifyDataSetChanged();
}
0 голосов
/ 01 июля 2019

Попробуйте с этим это может работать

override fun onBindViewHolder(holder: ScoresViewHolder, position: Int) {
    val score = scores[position]

    holder.playerView.text = if(clearEditText) "" else score.player.email
    holder.totalScoreView.text = score.total().toString()
    holder.currentScoreView.setText("")
}

public void clearInputs() {
 notifyDataSetChanged();
}
0 голосов
/ 01 июля 2019

Я понимаю, что вам, возможно, придется сохранить EditText ввод как currentScore в Score позже.

Предполагая это и currentScore как String.

В Java:

public void clearInputs() {
 for(Score score: scores) {
  score.currentScore = "";
 }
 notifyDataSetChanged();
}

в Котлине:

fun clearInputs() {
  for (score in scores)
  {
    score.currentScore = ""
  }
  notifyDataSetChanged()
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...