+ // Get handles for `navigationMenu` and the back and forward menu items. The menu is zero-based, so item 1 and 2 and the second and third items in the menu.
+ final Menu navigationMenu = navigationView.getMenu();
+ final MenuItem navigationBackMenuItem = navigationMenu.getItem(1);
+ final MenuItem navigationForwardMenuItem = navigationMenu.getItem(2);
+ final MenuItem navigationHistoryMenuItem = navigationMenu.getItem(3);
+
+ // The `DrawerListener` allows us to update the Navigation Menu.
+ drawerLayout.addDrawerListener(new DrawerLayout.DrawerListener() {
+ @Override
+ public void onDrawerSlide(View drawerView, float slideOffset) {
+ }
+
+ @Override
+ public void onDrawerOpened(View drawerView) {
+ }
+
+ @Override
+ public void onDrawerClosed(View drawerView) {
+ }
+
+ @Override
+ public void onDrawerStateChanged(int newState) {
+ // Update the `Back`, `Forward`, and `History` menu items every time the drawer opens.
+ navigationBackMenuItem.setEnabled(mainWebView.canGoBack());
+ navigationForwardMenuItem.setEnabled(mainWebView.canGoForward());
+ navigationHistoryMenuItem.setEnabled((mainWebView.canGoBack() || mainWebView.canGoForward()));
+
+ // Hide the keyboard so we can see the navigation menu. `0` indicates no additional flags.
+ inputMethodManager.hideSoftInputFromWindow(mainWebView.getWindowToken(), 0);
+ }
+ });
+