在 ArrayAdapter 上使用 ViewBinding

use*_*651 9 android android-arrayadapter kotlin android-viewbinding

我正在尝试重构我的应用程序以使用ViewBinding. 我已经浏览了所有的片段和活动;但是,我不确定ArrayAdapter使用视图绑定来防止内存泄漏的正确约定。

viewbinding在 ArrayAdapter 中使用 a 的正确方法是什么?

我一直在使用这种方法来处理片段:

private var _binding: BINDING_FILE_NAME? = null
private val binding get() = _binding!!

override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View? {
    _binding = BINDING_FILE_NAME.inflate(inflater, container, false)
    return binding.root
}

override fun onDestroyView() {
    super.onDestroyView()
    _binding = null
}
Run Code Online (Sandbox Code Playgroud)

我这样称呼我的适配器:

   var myadapter : MyCustomAdapter = MyCustomAdapter(requireContext(), R.layout.row_autocomplete_item, myListOfStrings())
Run Code Online (Sandbox Code Playgroud)

MyCustomAdapter


class MyCustomAdapter(ctx: Context, private val layout: Int, private val allItems: List<String>) : ArrayAdapter<String>(ctx, layout, allItems) {

    var filteredItems: List<String> = listOf()

    override fun getCount(): Int = filteredItems.size

    override fun getItem(position: Int): String = filteredItems[position]


    @SuppressLint("SetTextI18n")
    override fun getView(position: Int, convertView: View?, parent: ViewGroup): View {
        val view = convertView ?: LayoutInflater.from(parent.context).inflate(layout, parent, false)

        val item = filteredItems[position]

        view.apply {
            // HERE IS WHERE I AM NEEDING TO BIND THE VIEW
            tvName?.text = item
        }

        return view
    }

    override fun getFilter(): Filter {
        return object : Filter() {
            override fun publishResults(charSequence: CharSequence?, filterResults: FilterResults) {
                @Suppress("UNCHECKED_CAST")
                filteredItems = filterResults.values as List<String>
                notifyDataSetChanged()
            }

            override fun performFiltering(charSequence: CharSequence?): FilterResults {
                val queryString = charSequence?.toString()?.lowercase(Locale.ROOT)

                val results = FilterResults()

                results.values = if (queryString == null || queryString.isEmpty())
                    allItems
                else
                    allItems.filter {
                        it.lowercase(Locale.ROOT).contains(queryString)
                    }
                return results
            }
        }
    }

}
Run Code Online (Sandbox Code Playgroud)

小智 4

我确实喜欢这个,它的工作原理。但我不确定这是否是正确的方法

 override fun getView(position: Int, convertView: View?, parent: ViewGroup): View {
    val binding: LayoutCustomSpinnerBinding
    var row = convertView

    if (row == null) {
        val inflater =
            context.getSystemService(Context.LAYOUT_INFLATER_SERVICE) as LayoutInflater
        binding = LayoutCustomSpinnerBinding.inflate(inflater, parent, false)
        row = binding.root
    } else {
        binding = LayoutCustomSpinnerBinding.bind(row)
    }
    binding.txtContent.text = spinnerList[position].ValueData
    return row
}
Run Code Online (Sandbox Code Playgroud)