android - Android Studio Navigation Drawer 如何导航不同的 Fragment?
问题描述
我一直在试图弄清楚 Android Studio 附带的默认 Navigation Drawer Activity 模板是如何在不同片段之间导航的。我知道这个菜单是一个使用 AndroidX 导航组件和导航图的实现,但我就是不明白每个菜单项是如何映射到其相应的片段的。我没有看到任何侦听器或 onNavigationItemSelected() 等。有人可以解释一下 menuItem 和相应片段之间的映射是如何实现的吗?
MainActivity.java:
public class MainActivity extends AppCompatActivity {
private AppBarConfiguration mAppBarConfiguration;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Toolbar toolbar = findViewById(R.id.toolbar);
setSupportActionBar(toolbar);
FloatingActionButton fab = findViewById(R.id.fab);
DrawerLayout drawer = findViewById(R.id.drawer_layout);
NavigationView navigationView = findViewById(R.id.nav_view);
// Passing each menu ID as a set of Ids because each
// menu should be considered as top level destinations.
NavController navController = Navigation.findNavController(this, R.id.nav_host_fragment);
mAppBarConfiguration = new AppBarConfiguration.Builder(
navController.getGraph())
.setDrawerLayout(drawer)
.build();
NavigationUI.setupActionBarWithNavController(this, navController, mAppBarConfiguration);
NavigationUI.setupWithNavController(navigationView, navController);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.main, menu);
return true;
}
@Override
public boolean onSupportNavigateUp() {
NavController navController = Navigation.findNavController(this, R.id.nav_host_fragment);
return NavigationUI.navigateUp(navController, mAppBarConfiguration)
|| super.onSupportNavigateUp();
}
}
菜单.xml:
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android"
>
<group android:checkableBehavior="single">
<item
android:id="@+id/nav_home"
android:icon="@drawable/ic_menu_camera"
android:title="@string/menu_home" />
<item
android:id="@+id/nav_gallery"
android:icon="@drawable/ic_menu_gallery"
android:title="@string/menu_gallery" />
<item
android:id="@+id/nav_slideshow"
android:icon="@drawable/ic_menu_slideshow"
android:title="@string/menu_slideshow" />
</group>
</menu>
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/mobile_navigation"
app:startDestination="@+id/nav_home">
<fragment
android:id="@+id/nav_home"
android:name="com.buzzz.myapplication.ui.home.HomeFragment"
android:label="@string/menu_home"
tools:layout="@layout/fragment_home">
<action
android:id="@+id/action_HomeFragment_to_HomeSecondFragment"
app:destination="@id/nav_home_second" />
</fragment>
<fragment
android:id="@+id/nav_home_second"
android:name="com.buzzz.myapplication.ui.home.HomeSecondFragment"
android:label="@string/home_second"
tools:layout="@layout/fragment_home_second">
<action
android:id="@+id/action_HomeSecondFragment_to_HomeFragment"
app:destination="@id/nav_home" />
<argument
android:name="myArg"
app:argType="string" />
</fragment>
<fragment
android:id="@+id/nav_gallery"
android:name="com.buzzz.myapplication.ui.gallery.GalleryFragment"
android:label="@string/menu_gallery"
tools:layout="@layout/fragment_gallery" />
<fragment
android:id="@+id/nav_slideshow"
android:name="com.buzzz.myapplication.ui.slideshow.SlideshowFragment"
android:label="@string/menu_slideshow"
tools:layout="@layout/fragment_slideshow" />
</navigation>
非常感谢。
解决方案
根据使用 NavigationUI 文档更新 UI 组件,这些setupWithNavController()
方法将 UI 元素(例如 your NavigationView
)与 NavController 挂钩。
查看setupWithNavController()
Javadoc:
设置 a
NavigationView
与 a 一起使用NavController
。这将onNavDestinationSelected
在选择菜单项时调用。NavigationView
目的地更改时,将自动更新所选项目。
因此,在内部,这是设置适当的侦听器 - 既NavigationView
用于处理菜单选择,也用于NavController
在当前目标更改时更新所选项目。
查看onNavDestinationSelected()
Javadoc,可以清楚地看到菜单项和导航图目标是如何匹配的:
因此,单击带有 的菜单项android:id="@+id/nav_home"
将导航到带有 的目的地android:id="@+id/nav_home"
。
推荐阅读
- java - 如何仅覆盖接口的少数方法?
- ios - 如何像 Swift 中的 Uber 共享一样在 GoogleMap 中绘制曲线形状折线?
- abap - FORM 和 PERFORM 中的参数数量不同
- r - How plot new point in ggplot with older color data?
- android - Algolia 和 Firestore 价格 + 评论
- python - pandas plot 聚合时间戳索引
- nginx - 如何使用 metricbeat 检查我的服务器是否还活着,这可能吗?
- angularjs - ng-repeat : 添加新元素的 ng-model 问题
- swift - 如果存在多个有效的登录用户,则无法调用 RealmSwift currentUser
- asp.net-core - 发送客户端请求后如何执行操作?