Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/kotlin/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Android 使用ActionBar中的SearchView小部件和一个片段_Android_Kotlin_Android Recyclerview_Fragment_Searchview - Fatal编程技术网

Android 使用ActionBar中的SearchView小部件和一个片段

Android 使用ActionBar中的SearchView小部件和一个片段,android,kotlin,android-recyclerview,fragment,searchview,Android,Kotlin,Android Recyclerview,Fragment,Searchview,我正在尝试使用SearchView小部件从RecyclerView中过滤数据。 在一项活动中,它就像一个符咒。 但是,在片段中,回调不会被触发 这是我的片段: class CowListFragment : Fragment(), SearchView.OnQueryTextListener { private val adapter = CowAdapter() private val args: CowListFragmentArgs by navArgs()

我正在尝试使用SearchView小部件从RecyclerView中过滤数据。 在一项活动中,它就像一个符咒。 但是,在片段中,回调不会被触发

这是我的片段:

class CowListFragment : Fragment(), SearchView.OnQueryTextListener {

    private val adapter = CowAdapter()

    private val args: CowListFragmentArgs by navArgs()

    private val viewModel: CowListViewModel by viewModels {
        InjectorUtils.provideCowViewModelFactory(this, args.livestockId)
    }

    override fun onCreateView(
        inflater: LayoutInflater,
        container: ViewGroup?,
        savedInstanceState: Bundle?
    ): View? {
        val binding = FragmentCowListBinding.inflate(inflater, container, false)
        context ?: return binding.root

        binding.cowRecyclerView.adapter = adapter
        subscribeUi(adapter)
        setHasOptionsMenu(true)

        return binding.root
    }

    override fun onCreateOptionsMenu(menu: Menu, inflater: MenuInflater) {
        inflater.inflate(R.menu.menu_cow_list, menu)
        val searchItem = menu.findItem(R.id.search_cow)
        val searchView = searchItem.actionView as SearchView
        searchView.setOnQueryTextListener(this)
    }

    private fun subscribeUi(adapter: CowAdapter) {
        viewModel.cows.observe(viewLifecycleOwner) { cows ->
            adapter.submitList(cows)
        }
    }

    override fun onOptionsItemSelected(item: MenuItem): Boolean {
        return when (item.itemId) {
            R.id.search_cow -> {
                true
            }
            else -> super.onOptionsItemSelected(item)
        }
    }

    override fun onQueryTextSubmit(query: String?): Boolean {
        query?.let { viewModel.filter(it) }
        return true
    }

    override fun onQueryTextChange(query: String?): Boolean {
        query?.let { viewModel.filter(it) }
        return true
    }
}
以下是我的片段布局:

<?xml version="1.0" encoding="utf-8"?>

<layout 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">

    <androidx.appcompat.widget.LinearLayoutCompat
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical"
        tools:context=".MainActivity">

        <com.google.android.material.appbar.AppBarLayout
            android:id="@+id/app_bar_layout"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:fitsSystemWindows="true"
            android:theme="@style/Theme.Bcs.AppBarOverlay">

            <androidx.appcompat.widget.Toolbar
                android:id="@+id/toolbar"
                android:layout_width="match_parent"
                android:layout_height="?attr/actionBarSize"
                android:background="@android:color/transparent"
                app:contentInsetStartWithNavigation="0dp"
                app:layout_collapseMode="pin"
                app:menu="@menu/menu_cow_list"
                app:navigationIcon="@drawable/ic_detail_back"
                app:titleTextColor="?attr/colorOnSurface" />

        </com.google.android.material.appbar.AppBarLayout>

        <androidx.recyclerview.widget.RecyclerView
            android:id="@+id/cow_recycler_view"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:clipToPadding="false"
            android:paddingStart="@dimen/card_side_margin"
            android:paddingTop="@dimen/header_margin"
            android:paddingEnd="@dimen/card_side_margin"
            app:layoutManager="androidx.recyclerview.widget.StaggeredGridLayoutManager"
            app:spanCount="@integer/grid_columns"
            tools:context=".MainActivity"
            tools:listitem="@layout/list_item_cow" />
    </androidx.appcompat.widget.LinearLayoutCompat>
</layout>

任何帮助都将不胜感激。
谢谢

在onCreateView函数中添加此选项解决了以下问题:

(activity as AppCompatActivity).setSupportActionBar(binding.toolbar)

在onCreateView函数中添加此选项解决了以下问题:

(activity as AppCompatActivity).setSupportActionBar(binding.toolbar)

您指的是哪个回调?最好包括函数名。我指的是来自SearchView组件的queryTextSubmit和queryTextChange回调。不管怎样,我根据另一个答案找到了一个解决方案。你指的是哪个回调?最好包括函数名。我指的是来自SearchView组件的queryTextSubmit和queryTextChange回调。不管怎样,我根据另一个答案找到了一个解决方案。