0

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

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

这是我的片段的 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)
        }
    }
4

1 回答 1

0

让我们从另一个角度来看:

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

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

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

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

于 2021-05-17T09:55:49.773 回答