添加选项菜单时操作栏后退按钮不起作用

问题描述 投票:0回答:1

我正在将一个选项菜单膨胀到一个片段,之后,操作栏后退按钮不起作用,而系统后退按钮也起作用。请在下面查看我的代码。

这是我的代码:

NewsFragment.kt

package com.example.googlelike.news

import android.os.Bundle
import android.view.*
import androidx.fragment.app.Fragment
import androidx.lifecycle.ViewModelProviders
import com.example.googlelike.R
import com.example.googlelike.databinding.FragmentNewsBinding
import com.example.googlelike.network.MarsApiFilter

class NewsFragment : Fragment(){
    private val newsViewModel: NewsViewModel by lazy {
        ViewModelProviders.of(this).get(NewsViewModel::class.java)
    }
    override fun onCreateView(
        inflater: LayoutInflater,
        container: ViewGroup?,
        savedInstanceState: Bundle?
    ): View? {
        val binding = FragmentNewsBinding.inflate(inflater)

        binding.lifecycleOwner = this
        binding.recyclerView.adapter = NewsAdapter()
        binding.viewModel = newsViewModel

        setHasOptionsMenu(true)

        return binding.root
    }

    override fun onCreateOptionsMenu(menu: Menu?, inflater: MenuInflater?) {
        super.onCreateOptionsMenu(menu, inflater)
        inflater?.inflate(R.menu.option_menu,menu)
    }

    override fun onOptionsItemSelected(item: MenuItem?): Boolean {
        newsViewModel.updateFilterProperty(when(item?.itemId){
            R.id.rent_menu -> MarsApiFilter.RENT
            R.id.buy_menu -> MarsApiFilter.BUY
            else -> MarsApiFilter.SHOW_ALL
        })
        return true
    }

}

HomeFragment.kt(在将选项菜单膨胀到 NewsFragment.kt 后,我无法通过操作栏后退按钮从 NewsFragment 返回到 HomeFragment)

import android.os.Bundle
import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup
import androidx.fragment.app.Fragment
import androidx.navigation.fragment.findNavController
import com.example.googlelike.databinding.FragmentHomeBinding

class HomeFragment : Fragment(){
    override fun onCreateView(
        inflater: LayoutInflater,
        container: ViewGroup?,
        savedInstanceState: Bundle?
    ): View? {
        val binding = FragmentHomeBinding.inflate(inflater)
        binding.lifecycleOwner = this
        binding.button3.setOnClickListener {
            this.findNavController().navigate(HomeFragmentDirections.actionHomeFragmentToNewsFragment())
        }
        return binding.root
    }
}

MainActivity.kt

class MainActivity : AppCompatActivity() {
lateinit var binding: ActivityMainBinding
override fun onCreate(savedInstanceState: Bundle?) {
    super.onCreate(savedInstanceState)
    binding = DataBindingUtil.setContentView(this,R.layout.activity_main)
    val navController = this.findNavController(R.id.nav_host_fragment)
    NavigationUI.setupActionBarWithNavController(this,navController)

}

override fun onSupportNavigateUp(): Boolean {
    val navController = this.findNavController(R.id.nav_host_fragment)
    return navController.navigateUp()
}
}

编辑

我的导航图

    <?xml version="1.0" encoding="utf-8"?>
<navigation xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto" android:id="@+id/nav_graph"
    app:startDestination="@id/homeFragment">

    <fragment
        android:id="@+id/homeFragment"
        android:name="com.example.googlelike.home.HomeFragment"
        android:label="HomeFragment" >
        <action
            android:id="@+id/action_homeFragment_to_newsFragment"
            app:destination="@id/newsFragment" />
    </fragment>
    <fragment
        android:id="@+id/newsFragment"
        android:name="com.example.googlelike.news.NewsFragment"
        android:label="NewsFragment" >
        <action
            android:id="@+id/action_newsFragment_to_detailFragment"
            app:destination="@id/detailFragment" />
    </fragment>
    <fragment
        android:id="@+id/detailFragment"
        android:name="com.example.googlelike.detail.DetailFragment"
        android:label="DetailFragment" />
</navigation>
java android kotlin android-fragments android-menu
1个回答
0
投票

在你的片段中这样实现

     class BackButtonWithMenu : Fragment() {
            private val menuProvider = object : MenuProvider {
                    override fun onCreateMenu(menu: Menu, menuInflater: MenuInflater) {
                        menuInflater.inflate(R.menu.BackButton_frag_menu, menu)
                    }
            
                    override fun onMenuItemSelected(menuItem: MenuItem): Boolean {
                        return when (menuItem.itemId) {
                            R.id.termsBtn -> {
                                navigateToIntroductionPage()
                                false //check this
                            }
                            else -> false //check this
                        }
                    }
                }
            
            //set ActionBar to .show
            override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
                    super.onViewCreated(view, savedInstanceState)
                    (requireActivity() as AppCompatActivity).supportActionBar?.show()

val menuHost: MenuHost = requireActivity()
            menuHost.addMenuProvider(menuProvider, viewLifecycleOwner, Lifecycle.State.RESUMED)
            
            }

在您的活动中加入这些乐趣

override fun onNavigateUp(): Boolean {
     return navController.navigateUp(appBarConfiguration)
}
            
override fun onSupportNavigateUp(): Boolean {
     onBackPressed()
     return true
}
//This is 100% working
© www.soinside.com 2019 - 2024. All rights reserved.