2

そのため、フランス語から始めてさまざまな言語にアプリをローカライズしている最中で、奇妙な問題に遭遇しました。

アクティビティを作成したら、 を呼び出しますgetActionBar().setDisplayHomeAsUpEnabled(true);。これは、Nexus 7 で英語とフランス語の両方でテストするときに問題なく動作し、デフォルト (英語) のリソースを使用すると、Nexus 4 でも問題なく動作します。

ただし、Nexus 4で問題のアクティビティをフランス語で開始しようとすると(つまり、電話がフランス語に設定されていますが、アプリをフランス語に強制しようとすると問題が発生します)、アプリがクラッシュし、Eclipseが通知します私にはヌルポインタ例外がありました。setDisplayHomeAsUpEnabled()問題は電話だと判断しました。

クラッシュするfalse代わりに渡します。trueそれ以上呼び出しgetActionBar()を行わずに呼び出しても、アプリはクラッシュしません。アプリはマスター/ディテール フローに従ってセットアップされます (つまり、アプリのコアは 2 つのアクティビティ フラグメント ペア、1 つのリストと 1 つの詳細です)。これが、Nexus 4 バージョンにもかかわらず、Nexus 7 バージョンが正常に動作する理由だと思います。クラッシュ。

と のフォルダを再確認valuesvalues-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
4

2 に答える 2

0

2 つのことを確認してください: 1) onCreate メソッドの上部に @SuppressLint("NewApi") を配置することで、Lint エラーを抑制しました。(おそらく既に行っていると思います!) 2) Android マニフェスト ファイルで指定された minSdk を含める必要があります。次の行を保持します: (manifest タグの直後)

 <uses-sdk
        android:minSdkVersion="8"
        android:targetSdkVersion="18" /> 

それが役立つことを願っています!

于 2013-08-20T05:04:21.757 に答える