我为我的应用程序创建了一个侧面菜单(导航菜单),并重写了OnOptionsItemSelected(MenuItem项)方法,以便在单击每个菜单项时添加一些自定义行为。但是,在编写了一些代码后,当单击第一个菜单项(nav_home< -id)时,将显示Toast,当我点击它时没有任何反应,我无法在这里找出问题......
@Override
public boolean onOptionsItemSelected(MenuItem item) {
if(mToggle.onOptionsItemSelected(item)) {
return true;
}
// When a menu item is clicked, then depending on it's id start a new Activity
switch (item.getItemId()) {
case R.id.nav_home:
Toast.makeText(this, "Clicked", Toast.LENGTH_SHORT).show();
break;
default:
return super.onOptionsItemSelected(item);
}
return true;
}
这是我的整个MainActivity类:
package com.dcv.spdesigns.dokkancards;
import android.content.Intent;
import android.support.v4.widget.DrawerLayout;
import android.support.v7.app.ActionBarDrawerToggle;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.support.v7.widget.Toolbar;
import android.util.DisplayMetrics;
import android.view.MenuItem;
import android.view.View;
import android.widget.AdapterView;
import android.widget.GridView;
import android.widget.Toast;
import com.dcv.spdesigns.dokkancards.model.ImageAdapter;
import com.dcv.spdesigns.dokkancards.ui.CardViewActivity;
public class MainActivity extends AppCompatActivity {
GridView gridView;
// NavMenu member vars
private DrawerLayout mDrawerLayout;
private ActionBarDrawerToggle mToggle; // Button for toggling the side menu
private Toolbar mToolbar;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
// Get Screen Size Details
DisplayMetrics displayMetrics = new DisplayMetrics();
getWindowManager().getDefaultDisplay().getMetrics(displayMetrics);
int height = displayMetrics.heightPixels;
final int width = displayMetrics.widthPixels;
gridView = (GridView) findViewById(R.id.gridViewLayout);
gridView.setAdapter(new ImageAdapter(this)); // used to set the contents of the GridView-in this case images-
// When an item from the GridView gets clicked
gridView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
// Create a new Intent...
Toast.makeText(MainActivity.this, "Position: " + position, Toast.LENGTH_SHORT).show();
Intent intent = new Intent(MainActivity.this,CardViewActivity.class);
intent.putExtra("Card Index",position);
intent.putExtra("SCREEN_WIDTH",width);
startActivity(intent);
}
});
mToolbar = (Toolbar) findViewById(R.id.navActionBar);
setSupportActionBar(mToolbar); // check quick doq
getSupportActionBar().setDisplayShowTitleEnabled(false);
mToolbar.setTitle("");
getSupportActionBar().setDisplayHomeAsUpEnabled(true);
mDrawerLayout = (DrawerLayout) findViewById(R.id.drawerLayout);
mToggle = new ActionBarDrawerToggle(this,mDrawerLayout,R.string.drawer_open,R.string.drawer_closed); // Instantiating our button
mDrawerLayout.addDrawerListener(mToggle);
mToggle.syncState();
}
// When an item from the Action Bar gets tapped, then...
@Override
public boolean onOptionsItemSelected(MenuItem item) {
if(mToggle.onOptionsItemSelected(item)) {
return true;
}
// When a menu item is clicked, then depending on it's id start a new Activity
switch (item.getItemId()) {
case R.id.nav_home:
Toast.makeText(this, "Clicked", Toast.LENGTH_SHORT).show();
break;
default:
return super.onOptionsItemSelected(item);
}
return true;
}
}
主xml文件:
<?xml version="1.0" encoding="utf-8"?>
<android.support.v4.widget.DrawerLayout 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:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@color/colorPrimary"
tools:context="com.dcv.spdesigns.dokkancards.MainActivity"
android:id="@+id/drawerLayout">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<!-- Include the custom Action Bar we created -->
<include layout="@layout/navigation_action_bar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="center"/>
<GridView
android:layout_width="match_parent"
android:layout_height="match_parent"
android:columnWidth="90dp"
android:numColumns="4"
android:verticalSpacing="10dp"
android:horizontalSpacing="10dp"
android:stretchMode="columnWidth"
android:gravity="center"
android:id="@+id/gridViewLayout"/>
<!-- Add text & images -->
</LinearLayout>
<!-- The actual side menu Nav View -->
<android.support.design.widget.NavigationView
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_gravity="start"
app:headerLayout="@layout/navigation_header"
app:menu="@menu/navigation_menu">
</android.support.design.widget.NavigationView>
</android.support.v4.widget.DrawerLayout>
答案 0 :(得分:2)
没有完整的代码很难说,但这个问题的一个常见原因是导航不在所有其他元素之上。为了确保这一点,请将布局中的标题/导航参考放在完整的底部。布局xml中的项目越低,其z-index就越高。
布局的最后几行应如下所示:
...
<include layout="@layout/header" />
<include layout="@layout/navigation" />
</android.support.v4.widget.DrawerLayout>
此外,我还没有看到你关闭了DrawerLayout标签。
我在导航中检测点击的方式通常也有些不同。我实现了这样的标题和导航::
protected void setUpHeader(int headerRequestingActivity) {
setContentView(headerRequestingActivity);
headerPresenter = new HeaderPresenterImpl(this);
drawerHeaderView = findViewById(R.id.navigationheader);
toolbar = (Toolbar) findViewById(R.id.tbHeader);
setSupportActionBar(toolbar);
final DrawerLayout drawer = (DrawerLayout) findViewById(R.id.drawer);
final NavigationView navigationView = (NavigationView) findViewById(R.id.navigation);
navigationView.setNavigationItemSelectedListener(this);
ActionBarDrawerToggle toggle = new ActionBarDrawerToggle(
this, drawer, toolbar, R.string.navigation_drawer_open, R.string.navigation_drawer_close) {
@Override
public void onDrawerStateChanged(int newState) {
if (drawer.isDrawerOpen(GravityCompat.START)) {
//do something on opening the navigation
} else {
//optional actions when navigation menu closes
}
}
};
drawer.setDrawerListener(toggle);
toggle.syncState();
}
使用以下方法收听点击次数:
@Override
public boolean onNavigationItemSelected(MenuItem item) {
int id = item.getItemId();
switch (id) {
case R.id.nav_changelanguage:
//change language logic
break;
case R.id.nav_logout:
//logout user
break;
}
return true;
}
希望这有帮助。