微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何使用 Kotlin 过滤 RecycleView

如何解决如何使用 Kotlin 过滤 RecycleView

我是 Kotlin 编程语言的新手,处理 recyclerView 有点难以理解,所以我使用了 Groupie 库,但是没有足够的文档或教程来说明如何处理这个库。

直截了当地说我有一个回收器视图包含我添加到适配器的数据,我想使用 searchView 过滤该数据,我不知道如何从 groupAdapter 中获取列表或文本或其中的项目进行过滤。

这是我的 Fragment 的 XML 布局

<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".fragment.SearchFragment"
    android:background="@color/backgroundGray">

    <androidx.constraintlayout.widget.ConstraintLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent">

        <include
            android:id="@+id/include4"
            layout="@layout/fragment_search_toolbar"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toTopOf="parent" />

        <androidx.recyclerview.widget.RecyclerView
            android:id="@+id/recycleview_search"
            android:layout_width="match_parent"
            android:layout_height="0dp"
            android:divider="@null"
            android:background="@color/backgroundGray"
            app:layout_constraintBottom_toBottomOf="parent"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toBottomOf="@+id/include4"
            app:layoutManager="androidx.recyclerview.widget.linearlayoutmanager"
            tools:listitem="@layout/search_row"/>

    </androidx.constraintlayout.widget.ConstraintLayout>



</FrameLayout>

seachView XML 布局

<?xml version="1.0" encoding="utf-8"?>
<androidx.appcompat.widget.SearchView xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:id="@+id/searchView"
    android:layout_marginRight="10dp"
    android:layout_marginLeft="10dp"
    android:layout_marginBottom="10dp"
    app:queryHint="Looking For Stores.."
    app:iconifiedByDefault="false"
    android:layoutDirection="rtl"
    android:clickable="true"
    android:elevation="4dp"
    android:gravity="end"
    app:queryBackground="@null"
    android:textAlignment="textEnd"
    tools:ignore="KeyboardInaccessibleWidget,UnusedAttribute"
    android:background="@drawable/searchview_background">

</androidx.appcompat.widget.SearchView>

这是我的片段类

class SearchFragment : Fragment() {

    lateinit var searchView: android.widget.SearchView

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        arguments?.let {

        }
    }

    override fun onCreateView(
        inflater: LayoutInflater,container: ViewGroup?,savedInstanceState: Bundle?
    ): View? {
        // Inflate the layout for this fragment

        return inflater.inflate(R.layout.fragment_search,container,false)
    }

    override fun onViewCreated(view: View,savedInstanceState: Bundle?) {
        super.onViewCreated(view,savedInstanceState)

        searchView = view.findViewById(R.id.searchView)
        val adapter = GroupAdapter<GroupieViewHolder>()
        recycleview_search.adapter = StoresItems()
        

        adapter.add(Stores(R.drawable.ic_kfc,"KFC",15.581010,32.569032))
        adapter.add(Stores(R.drawable.ic_pizzahut,"Pizza Hut",15.581050,32.569002))
        adapter.add(Stores(R.drawable.ic_dominos,"Dominos Pizza",15.581560,32.512002))

        adapter.setonItemClickListener { item,view ->
            val storesItem = item as Stores
            val  intent = Intent(view.context,OrderActivity::class.java)

            intent.putExtra("storename",storesItem.storename)
            startActivity(intent)
        }

        searchView.setonCloseListener(object: SearchView.OnQueryTextListener,SearchView.OnCloseListener {
            override fun onQueryTextSubmit(p0: String?): Boolean {
               return false
            }

            override fun onQueryTextChange(p0: String?): Boolean {
                return false
            }
       })
    }



}
 class Stores(val img: Int,val storename: String,val latitude: Double,val longitude: Double) : Item<GroupieViewHolder>() {
        override fun getLayout(): Int {
            return R.layout.search_row
        }
    
        override fun bind(viewHolder: GroupieViewHolder,position: Int) {
    
            viewHolder.itemView.storeName.text = storename
            viewHolder.itemView.storeImage.setimageResource(img)
        }
    }

解决方法

换个角度来看:

概念是,您有一个 List<Things>,您的 RecyclerView/Adapter 会显示它。 您生成了一个应该减少该列表的关键字(搜索)。您如何过滤此列表、过滤它的位置、存储它的位置等(并且应该)与 RecyclerView/Adapter 无关。 它们的职责不同(出于性能原因回收视图,并将它们分别调整/绑定到“视图”),而不是搜索/过滤列表。你还没有发布你的适配器代码,但本质上:

当您提交搜索查询时,您可以以任何您认为合适的方式“过滤”列表,生成一个包含过滤结果的新列表,并将其传递给适配器。然后适配器将计算需要做什么来显示新列表。

如果您使用实现了 ListAdapter<T,K>DiffUtil.ItemCallback 会加分,因为这意味着您可以做 adapter.submitList(newFilteredList),坐下来放松一下。

换句话说,分离职责,搜索、过滤不是适配器/回收者视图的一部分。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?