そのため、フランス語から始めてさまざまな言語にアプリをローカライズしている最中で、奇妙な問題に遭遇しました。
アクティビティを作成したら、 を呼び出しますgetActionBar().setDisplayHomeAsUpEnabled(true);
。これは、Nexus 7 で英語とフランス語の両方でテストするときに問題なく動作し、デフォルト (英語) のリソースを使用すると、Nexus 4 でも問題なく動作します。
ただし、Nexus 4で問題のアクティビティをフランス語で開始しようとすると(つまり、電話がフランス語に設定されていますが、アプリをフランス語に強制しようとすると問題が発生します)、アプリがクラッシュし、Eclipseが通知します私にはヌルポインタ例外がありました。setDisplayHomeAsUpEnabled()
問題は電話だと判断しました。
クラッシュするfalse
代わりに渡します。true
それ以上呼び出しgetActionBar()
を行わずに呼び出しても、アプリはクラッシュしません。アプリはマスター/ディテール フローに従ってセットアップされます (つまり、アプリのコアは 2 つのアクティビティ フラグメント ペア、1 つのリストと 1 つの詳細です)。これが、Nexus 4 バージョンにもかかわらず、Nexus 7 バージョンが正常に動作する理由だと思います。クラッシュ。
と のフォルダを再確認values
しvalues-fr
ましたが、 に不足しているリソースや余分なリソースがないことを確認していvalues-fr
ます。
なぜこれが起こっているのかについての手がかりはありますか?
LogCatが教えてくれることは次のとおりです。
04-27 15:13:44.968: D/AndroidRuntime(4244): Shutting down VM
04-27 15:13:44.968: W/dalvikvm(4244): threadid=1: thread exiting with uncaught exception (group=0x41429930)
04-27 15:13:44.978: E/AndroidRuntime(4244): FATAL EXCEPTION: main
04-27 15:13:44.978: E/AndroidRuntime(4244): java.lang.RuntimeException: Unable to start activity ComponentInfo{ca.hachesoftware.soilbearingcapacity/ca.hachesoftware.soilbearingcapacity.ScreenDetailActivity}: java.lang.NullPointerException
04-27 15:13:44.978: E/AndroidRuntime(4244): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2180)
04-27 15:13:44.978: E/AndroidRuntime(4244): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230)
04-27 15:13:44.978: E/AndroidRuntime(4244): at android.app.ActivityThread.access$600(ActivityThread.java:141)
04-27 15:13:44.978: E/AndroidRuntime(4244): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234)
04-27 15:13:44.978: E/AndroidRuntime(4244): at android.os.Handler.dispatchMessage(Handler.java:99)
04-27 15:13:44.978: E/AndroidRuntime(4244): at android.os.Looper.loop(Looper.java:137)
04-27 15:13:44.978: E/AndroidRuntime(4244): at android.app.ActivityThread.main(ActivityThread.java:5041)
04-27 15:13:44.978: E/AndroidRuntime(4244): at java.lang.reflect.Method.invokeNative(Native Method)
04-27 15:13:44.978: E/AndroidRuntime(4244): at java.lang.reflect.Method.invoke(Method.java:511)
04-27 15:13:44.978: E/AndroidRuntime(4244): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
04-27 15:13:44.978: E/AndroidRuntime(4244): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
04-27 15:13:44.978: E/AndroidRuntime(4244): at dalvik.system.NativeStart.main(Native Method)
04-27 15:13:44.978: E/AndroidRuntime(4244): Caused by: java.lang.NullPointerException
04-27 15:13:44.978: E/AndroidRuntime(4244): at ca.hachesoftware.soilbearingcapacity.ScreenDetailActivity.onCreate(ScreenDetailActivity.java:34)
04-27 15:13:44.978: E/AndroidRuntime(4244): at android.app.Activity.performCreate(Activity.java:5104)
04-27 15:13:44.978: E/AndroidRuntime(4244): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1080)
04-27 15:13:44.978: E/AndroidRuntime(4244): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2144)
04-27 15:13:44.978: E/AndroidRuntime(4244): ... 11 more