【发布时间】:2014-10-24 09:21:16
【问题描述】:
我正在尝试为 android 创建一个应用程序,但遇到了以下问题:
当我按下菜单按钮时,应用程序在特定手机中崩溃。让我先给你一些细节。
- 该错误仅发生在装有 Android 4.1.2 的 LG Optimus L3 II e430 上(目前已在其他四款手机上测试过)
- 应用程序以初始屏幕启动,没有操作栏。此时菜单按钮没有任何作用。
- 通过简单的触摸,我们就可以越过初始屏幕,然后转到实现 ActionBar 活动并具有导航抽屉的 Main Activity。
- 从现在开始,每次我尝试点击菜单按钮时,应用都会崩溃。
这里是菜单的布局和onCreateOptionsMenu函数:
res/menu/main.xml
<menu xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto">
<item android:id="@+id/action_settings"
android:title="@string/action_settings"
android:orderInCategory="100"
app:showAsAction="never" />
</menu>
来自 MainActivity.java 的部分
@Override
public boolean onCreateOptionsMenu(Menu menu) {
if (!mNavigationDrawerFragment.isDrawerOpen()) {
// Only show items in the action bar relevant to this screen
// if the drawer is not showing. Otherwise, let the drawer
// decide what to show in the action bar.
getMenuInflater().inflate(R.menu.main, menu);
restoreActionBar();
return true;
}
return super.onCreateOptionsMenu(menu);
}
请注意,此代码是从 Android Studio 生成的。
到目前为止我已经尝试过:
- 尝试从 sdk 源(API 级别 16 和 21)查看有问题的文件,但它们与堆栈跟踪无关(堆栈跟踪中显示的行指向一个没有意义的位置)。
- 尝试安装 XPosed 修复程序以解决 Google PlayStore 崩溃的菜单按钮错误。这里也没有。
- 发现了一个与 Firefox 的错误跟踪系统类似的错误报告,因此我尝试安装 Firefox,并查看当我按下菜单按钮时它是否在我的手机上崩溃; Firefox 没有崩溃。 (Link to firefox's bug)
这是来自 LogCat 的堆栈跟踪:
10-24 09:08:02.710 4712-4712/com.scaryboxstudios.unrealestateapp E/AndroidRuntime﹕ FATAL EXCEPTION: main
java.lang.NullPointerException
at com.android.internal.policy.impl.PhoneWindow.onKeyUpPanel(PhoneWindow.java:1004)
at com.android.internal.policy.impl.PhoneWindow.onKeyUp(PhoneWindow.java:1712)
at com.android.internal.policy.impl.PhoneWindow$DecorView.dispatchKeyEvent(PhoneWindow.java:2125)
at android.view.ViewRootImpl.deliverKeyEventPostIme(ViewRootImpl.java:3611)
at android.view.ViewRootImpl.handleImeFinishedEvent(ViewRootImpl.java:3581)
at android.view.ViewRootImpl$ViewRootHandler.handleMessage(ViewRootImpl.java:2831)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:4929)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:798)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:565)
at de.robv.android.xposed.XposedBridge.main(XposedBridge.java:132)
at dalvik.system.NativeStart.main(Native Method)
【问题讨论】:
-
@TalkLittle 谢谢!我会留意的!
-
LG L9 与 4.1.2 出现同样的问题