gpt4 book ai didi

Android:导航组件 - 如何将工具栏菜单连接到 fragment ?

转载 作者:行者123 更新时间:2023-12-04 23:54:18 24 4
gpt4 key购买 nike

我一直在尝试将导航组件添加到我的应用程序中。专门针对我的工具栏菜单项。

我一直在关注 navigation migrate Android 网站上的文档,但我对它的工作原理甚至设置感到困惑。

这是一个单 Activity 多 fragment 架构。

应用程序将在 MainFragment 中启动,然后在点击工具栏中的菜单项时启动,例如 Main Frag 到 Search Movie Frag。用户将能够使用应用程序中任何位置的菜单项进行导航(例如,如果他们单击主页图标,它们应该被发送到应用程序中任何位置的主屏幕表单。仍在考虑是否应该这样做)。

主要是我不知道如何将导航组件正确附加到菜单项。

应用

Main Fragment displayed on phone

导航图

Nav Graph displayed on Android Studio

nav_graph.xml

<?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"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/nav_graph"
app:startDestination="@id/mainFragment">

<fragment
android:id="@+id/mainFragment"
android:name="com.example.movieapp.ui.main.MainFragment"
android:label="MainFragment">
<action
android:id="@+id/action_mainFragment_to_searchMovieFragment"
app:destination="@id/searchMovieFragment" />
</fragment>
<fragment
android:id="@+id/searchMovieFragment"
android:name="com.example.movieapp.ui.search.SearchMovieFragment"
android:label="SearchMovieFragment" />
</navigation>

ma​​in_activity.xml

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/container"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".activity.MainActivity">

<include
layout="@layout/appbar"
android:id="@+id/mainToolBar"/>

<androidx.fragment.app.FragmentContainerView
android:id="@+id/nav_host_fragment"
android:name="androidx.navigation.fragment.NavHostFragment"
android:layout_width="0dp"
android:layout_height="0dp"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toBottomOf="@id/mainToolBar"
app:layout_constraintBottom_toBottomOf="parent"
app:defaultNavHost="true"
app:navGraph="@navigation/nav_graph" />

</androidx.constraintlayout.widget.ConstraintLayout>

MainActivity.kt

class MainActivity : AppCompatActivity() {

private lateinit var toolbar: Toolbar
private val navController by lazy {
(supportFragmentManager.findFragmentById(R.id.nav_host_fragment) as NavHostFragment).navController
}
private lateinit var appBarConfiguration: AppBarConfiguration

override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.main_activity)
toolbar = findViewById(R.id.mainToolBar)
setSupportActionBar(toolbar)
appBarConfiguration = AppBarConfiguration(navController.graph, null)
setupActionBarWithNavController(navController, appBarConfiguration)
}

override fun onCreateOptionsMenu(menu: Menu?): Boolean {
val inflater: MenuInflater = menuInflater
inflater.inflate(R.menu.main_menu_bar, menu)
return true
}

override fun onSupportNavigateUp(): Boolean {
return navController.navigateUp(appBarConfiguration) || super.onSupportNavigateUp()
}
}

MainFragment.kt

class MainFragment : Fragment() {

companion object {
fun newInstance() = MainFragment()
}

private lateinit var viewModel: MainViewModel
private lateinit var binding: MainFragmentBinding
private lateinit var navController: NavController

override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View {
binding = DataBindingUtil.inflate(inflater, R.layout.main_fragment, container, false)
setHasOptionsMenu(true)
return binding.root
}

override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
super.onViewCreated(view, savedInstanceState)
navController = Navigation.findNavController(view)
// navController.navigate(R.id.action_mainFragment_to_searchMovieFragment)
}

override fun onActivityCreated(savedInstanceState: Bundle?) {
super.onActivityCreated(savedInstanceState)
viewModel = ViewModelProvider(this).get(MainViewModel::class.java)
binding.viewModel = viewModel
// TODO: Use the ViewModel
}

}

ma​​in_fragment.xml

<?xml version="1.0" encoding="utf-8"?>
<layout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools">

<data>
<variable
name="viewModel"
type="com.example.movieapp.ui.main.MainViewModel" />
</data>

<LinearLayout
android:orientation="vertical"
android:id="@+id/main_fragment"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".ui.main.MainFragment">

<TextView
android:id="@+id/message"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="MainFragment1" />

</LinearLayout>
</layout>

最佳答案

文件 main_menu_bar.xml 中菜单项的 ID 需要与导航图 (nav_graph.xml) 中指定的目的地( fragment )的 ID 相匹配.

您的 main_menu_bar.xml 应如下所示:

<menu xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
tools:showIn="navigation_view">

<group android:checkableBehavior="single">
<item
android:id="@id/searchMovieFragment"
android:icon="@drawable/search"
android:title="@string/menu_search" />
<item
android:id="@id/mainFragment"
android:icon="@drawable/ic_menu_camera"
android:title="@string/menu_home" />
</group>
</menu>

此外,您需要覆盖 onOptionsItemSelected(MenuItem) 方法并将您的菜单项与目的地相关联。像这样:

override fun onOptionsItemSelected(item: MenuItem): Boolean {
val navController = findNavController(R.id.nav_host_fragment)
return item.onNavDestinationSelected(navController) || super.onOptionsItemSelected(item)
}

Reference

关于Android:导航组件 - 如何将工具栏菜单连接到 fragment ?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63762233/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com