具有不同工具栏和菜单的导航组件

时间:2019-09-02 16:40:51

标签: android kotlin

我正在使用导航模式的应用程序。 现在我有一个活动和一些片段。 每个片段都有其独特的功能,因此我为每个片段创建了一个单独的工具栏:折叠,普通或根本没有工具栏。 我使用以下示例:https://android.jlelse.eu/instagram-style-navigation-using-navigation-component-854037cf1389

它工作得很好,但是现在我想在工具栏中设置一些菜单项时遇到问题。

例如,我想在“个人资料片段”的工具栏上添加一个设置菜单

我尝试设置菜单项,但是它根本没有出现,而且我认为根本不会调用该方法。

是否可以在不更改整个体系结构逻辑的情况下解决此问题?

override fun onCreateView(
        inflater: LayoutInflater, container: ViewGroup?,
        savedInstanceState: Bundle?
    ): View? {
        binding = DataBindingUtil.inflate(inflater, R.layout.my_layout, container, false)

        setHasOptionsMenu(true)

        return binding.root
    }
override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
        super.onViewCreated(view, savedInstanceState)

        binding.toolbar.apply {
            setupWithNavController(findNavController())
        }
    }
  override fun onCreateOptionsMenu(menu: Menu, inflater: MenuInflater) {
        inflater.inflate(R.menu.main_menu, menu)

        super.onCreateOptionsMenu(menu, inflater)
    }

    override fun onOptionsItemSelected(item: MenuItem): Boolean {
        if(item.itemId == R.id.action_get_info)
            Toast.makeText(context!!, "test message", Toast.LENGTH_SHORT).show()

        return super.onOptionsItemSelected(item)
    }
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:app="http://schemas.android.com/apk/res-auto">

    <item
            android:id="@+id/action_get_info"
            android:icon="@drawable/ic_setting"
            android:title="Settings"
            app:showAsAction="always" />

</menu>
<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"
 tools:context="com.example.MyFragment">


<androidx.coordinatorlayout.widget.CoordinatorLayout
            android:layout_width="match_parent"
            android:fitsSystemWindows="true"
            android:layout_height="match_parent">

        <com.google.android.material.appbar.AppBarLayout 
            android:id="@+id/app_bar_layout"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:background="@android:color/white">

         <androidx.appcompat.widget.Toolbar
              android:id="@+id/toolbar"
              style="@style/ToolbarAppearance"
              android:layout_width="match_parent"
              android:layout_height="?attr/actionBarSize">

    </androidx.appcompat.widget.Toolbar>
</com.google.android.material.appbar.AppBarLayout>


        <RelativeLayout
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                app:layout_behavior="@string/appbar_scrolling_view_behavior">

              <ImageView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:src="@drawable/ic_test_image" />
        </RelativeLayout>    

</androidx.coordinatorlayout.widget.CoordinatorLayout>

</layout>

0 个答案:

没有答案