概要
LG端末でだけ謎のクラッシュレポートが届いていたので調べた結果をメモ。
結論としては、LGの4.1以下端末に向けた回避コードが必要orz
なお、手元には該当の端末が無いため未検証。
クラッシュレポート
こんなレポートが送られてくる。
java.lang.NullPointerException
at com.android.internal.policy.impl.PhoneWindow.onKeyUpPanel(PhoneWindow.java:987)
at com.android.internal.policy.impl.PhoneWindow.onKeyUp(PhoneWindow.java:1686)
at com.android.internal.policy.impl.PhoneWindow$DecorView.dispatchKeyEvent(PhoneWindow.java:2097)
at android.view.ViewRootImpl.deliverKeyEventPostIme(ViewRootImpl.java:3618)
at android.view.ViewRootImpl.handleImeFinishedEvent(ViewRootImpl.java:3588)
at android.view.ViewRootImpl$ViewRootHandler.handleMessage(ViewRootImpl.java:2834)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:4849)
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:795)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:562)
at dalvik.system.NativeStart.main(Native Method)
うん、自分の書いたコードに関する部分は全くないね。。。
原因と回避策
回避策はこのスレッドで議論されてた。
原因はLGカスタマイズAndroidのバグとのこと(参考) 死ねばいいのに。
onKeyUp
とonKeyDown
をオーバーライドしてLG端末かつAPIレベル16以下で判定して回避処理を入れる。
@Override
public boolean onKeyDown(int keyCode, KeyEvent event) {
if ((keyCode == KeyEvent.KEYCODE_MENU) &&
(Build.VERSION.SDK_INT <= 16) &&
(Build.MANUFACTURER.compareTo("LGE") == 0)) {
return true;
}
return super.onKeyDown(keyCode, event);
}
@Override
public boolean onKeyUp(int keyCode, KeyEvent event) {
if ((keyCode == KeyEvent.KEYCODE_MENU) &&
(Build.VERSION.SDK_INT <= 16) &&
(Build.MANUFACTURER.compareTo("LGE") == 0)) {
openOptionsMenu();
return true;
}
return super.onKeyUp(keyCode, event);
}
雑感
ただこれ、クラッシュレポート見てもどのActivityで起きてるかわからんのよね。
全部のActivityに入れるしか無いのか...