Задать вопрос
@samurainisad

Почему накладываются Layout'ы Recycler View друг на друга при скролле списка в эмуляторе?

Перенёс всю основную логику из MainActivity в свой фрагмент, приложение запускается, но при скролле почему то возникает наложение двух Layout'ов, перекопал весь код, с XML вроде всё в порядке. Прилагаю скрины и свой код.
Код Main Activity
override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        val policy = StrictMode.ThreadPolicy.Builder().permitAll().build()
        StrictMode.setThreadPolicy(policy)
        setContentView(R.layout.activity_main)
        val toolbar = findViewById<androidx.appcompat.widget.Toolbar>(R.id.toolbar)
        setSupportActionBar(toolbar)
        if (savedInstanceState == null){
            supportFragmentManager.beginTransaction()
                .add(R.id.fragmentContainerView,
                    FragmentContact::class.java, null)
                .commit()
        }
    }

    override fun onCreateOptionsMenu(menu: Menu?): Boolean {
        menuInflater.inflate(R.menu.search_tb_menu, menu)
        return true
    }
}


Код фрагмента
import android.content.Context
import android.content.SharedPreferences
import android.os.Bundle
import android.text.Editable
import android.text.TextWatcher
import androidx.fragment.app.Fragment
import android.view.LayoutInflater
import android.view.Menu
import android.view.View
import android.view.ViewGroup
import android.widget.EditText
import android.widget.TextView
import androidx.recyclerview.widget.DiffUtil
import androidx.recyclerview.widget.LinearLayoutManager
import androidx.recyclerview.widget.RecyclerView
import com.google.gson.Gson
import java.net.HttpURLConnection
import java.net.URL


class FragmentContact : Fragment() {
    var contacts = arrayListOf<Contact>()
    var contactsJson = arrayListOf<Contact>()
    val adapter = ListAdapter()
    override fun onCreateView(
        inflater: LayoutInflater, container: ViewGroup?,
        savedInstanceState: Bundle?
    ): View? {
        // Inflate the layout for this fragment
        return inflater.inflate(R.layout.fragment_contact, container, false)
    }

    override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
        super.onViewCreated(view, savedInstanceState)
        val recycleView: RecyclerView = requireView().findViewById(R.id.rView)
        val data = "https://drive.google.com/u/0/uc?id=1-KO-9GA3NzSgIc1dkAsNm8Dqw0fuPxcR&export=download"
        Thread {
            val connection = URL(data).openConnection() as HttpURLConnection
            val jsonData = connection.inputStream.bufferedReader().readText()

            contactsJson =
                Gson().fromJson(jsonData, Array<Contact>::class.java).toList() as ArrayList<Contact>
            contacts = contactsJson.clone() as ArrayList<Contact>
            requireActivity().runOnUiThread {
                recycleView.layoutManager = LinearLayoutManager(context)
                recycleView.adapter = adapter
                adapter.submitList(contacts)
                adapter.notifyDataSetChanged()
            }
            val edtxtx_search: EditText = view.findViewById(R.id.et_search)!!
            edtxtx_search.addTextChangedListener(object : TextWatcher {
                override fun afterTextChanged(s: Editable) {
                    val insertedtext = edtxtx_search.text.toString()
                    val SharedPreferences = requireActivity().getPreferences(Context.MODE_PRIVATE)
                    val editor: SharedPreferences.Editor = SharedPreferences.edit()
                    editor.apply {
                        putString("SEARCH_FILTER", insertedtext)
                    }.apply() //фиксирует значения
                }

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

                override fun onTextChanged(
                    s: CharSequence, start: Int,
                    before: Int, count: Int
                ) {
                    search()
                }
            })
        }.start()
    }

    fun search() {
        val edtxtx_search: EditText = view?.findViewById(R.id.et_search)!!
        contacts.clear()
        if (!edtxtx_search.text.isNullOrBlank()) {
            for (x in contactsJson) {
                if ((x.name.contains(edtxtx_search.text)) or (x.phone.contains(edtxtx_search.text)) or (x.type.contains(
                        edtxtx_search.text
                    ))
                )
                    contacts.add(x)
            }
        } else {
            contacts = contactsJson.clone() as ArrayList<Contact>
        }
        adapter.submitList(contacts)
        adapter.notifyDataSetChanged()
    }
}
data class Contact(
    val name: String,
    val phone: String,
    val type: String
)
class ContactItemDiffCallback : DiffUtil.ItemCallback<Contact>(){
    override fun areItemsTheSame(oldItem: Contact, newItem: Contact) = oldItem == newItem
    override fun areContentsTheSame(oldItem: Contact, newItem: Contact) = oldItem == newItem
}

class ViewHolder(view: View) : RecyclerView.ViewHolder(view) {
    val textview1: TextView = view.findViewById(R.id.textView)
    val textview2: TextView = view.findViewById(R.id.textView2)
    val textview3: TextView = view.findViewById(R.id.textView3)

    fun bindTo(contact: Contact){
        if (textview1 != null) {textview1.text = contact.name}
        if (textview2 != null) {textview2.text = contact.phone}
        if (textview3 != null) {textview3.text = contact.type}
    }
}
class ListAdapter : androidx.recyclerview.widget.ListAdapter<Contact, ViewHolder>(ContactItemDiffCallback()){
    override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ViewHolder {
        val view = LayoutInflater.from(parent.context).inflate(R.layout.rview_item, parent, false)
        return ViewHolder(view)
    }
    override fun onBindViewHolder(holder: ViewHolder, position: Int) {
        val data = currentList[position]
        holder.bindTo(data)
    }
}


Так работает скролл сейчас, идёт наложение
620cfb7fefd90206144030.png

А так должно быть
620cfbc8d8c88955361918.png

В чем может быть проблема? В каком направлении копать?
  • Вопрос задан
  • 153 просмотра
Подписаться 1 Простой 3 комментария
Пригласить эксперта
Ответы на вопрос 1
zagayevskiy
@zagayevskiy Куратор тега Android
Android developer at Yandex
Выглядит так, будто у тебя два ресайклера, один над другим. Может быть, ты два фрагмента одинаковых каким-то образом добавляешь. Проверь это.
Ответ написан
Комментировать
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы