0

Android lib jar を作成し、lib フォルダーをテスト アプリケーションに配置します。jar ファイルでアクティビティを開始しますが、次のエラーが発生します。

10-22 00:14:59.349: E/AndroidRuntime(670): FATAL EXCEPTION: main
10-22 00:14:59.349: E/AndroidRuntime(670): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.testapplication/com.example.test.MainActivity}: android.content.res.Resources$NotFoundException: File res/drawable-hdpi/ic_launcher.png from xml type layout resource ID #0x7f020000
10-22 00:14:59.349: E/AndroidRuntime(670):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1647)
10-22 00:14:59.349: E/AndroidRuntime(670):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663)
10-22 00:14:59.349: E/AndroidRuntime(670):  at android.app.ActivityThread.access$1500(ActivityThread.java:117)
10-22 00:14:59.349: E/AndroidRuntime(670):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931)
10-22 00:14:59.349: E/AndroidRuntime(670):  at android.os.Handler.dispatchMessage(Handler.java:99)
10-22 00:14:59.349: E/AndroidRuntime(670):  at android.os.Looper.loop(Looper.java:130)
10-22 00:14:59.349: E/AndroidRuntime(670):  at android.app.ActivityThread.main(ActivityThread.java:3683)
10-22 00:14:59.349: E/AndroidRuntime(670):  at java.lang.reflect.Method.invokeNative(Native Method)
10-22 00:14:59.349: E/AndroidRuntime(670):  at java.lang.reflect.Method.invoke(Method.java:507)
10-22 00:14:59.349: E/AndroidRuntime(670):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
10-22 00:14:59.349: E/AndroidRuntime(670):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
10-22 00:14:59.349: E/AndroidRuntime(670):  at dalvik.system.NativeStart.main(Native Method)
10-22 00:14:59.349: E/AndroidRuntime(670): Caused by: android.content.res.Resources$NotFoundException: File res/drawable-hdpi/ic_launcher.png from xml type layout resource ID #0x7f020000
10-22 00:14:59.349: E/AndroidRuntime(670):  at android.content.res.Resources.loadXmlResourceParser(Resources.java:1916)
10-22 00:14:59.349: E/AndroidRuntime(670):  at android.content.res.Resources.loadXmlResourceParser(Resources.java:1871)
10-22 00:14:59.349: E/AndroidRuntime(670):  at android.content.res.Resources.getLayout(Resources.java:731)
10-22 00:14:59.349: E/AndroidRuntime(670):  at android.view.LayoutInflater.inflate(LayoutInflater.java:318)
10-22 00:14:59.349: E/AndroidRuntime(670):  at android.view.LayoutInflater.inflate(LayoutInflater.java:276)
10-22 00:14:59.349: E/AndroidRuntime(670):  at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:207)
10-22 00:14:59.349: E/AndroidRuntime(670):  at android.app.Activity.setContentView(Activity.java:1657)
10-22 00:14:59.349: E/AndroidRuntime(670):  at com.example.test.MainActivity.onCreate(MainActivity.java:12)
10-22 00:14:59.349: E/AndroidRuntime(670):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
10-22 00:14:59.349: E/AndroidRuntime(670):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611)
10-22 00:14:59.349: E/AndroidRuntime(670):  ... 11 more
10-22 00:14:59.349: E/AndroidRuntime(670): Caused by: java.io.FileNotFoundException: Corrupt XML binary file
10-22 00:14:59.349: E/AndroidRuntime(670):  at android.content.res.AssetManager.openXmlAssetNative(Native Method)
10-22 00:14:59.349: E/AndroidRuntime(670):  at android.content.res.AssetManager.openXmlBlockAsset(AssetManager.java:486)
10-22 00:14:59.349: E/AndroidRuntime(670):  at android.content.res.Resources.loadXmlResourceParser(Resources.java:1898)
10-22 00:14:59.349: E/AndroidRuntime(670):  ... 20 more

この問題を解決するのを手伝ってください。英語が下手で申し訳ありません

4

1 に答える 1

3

リソースを jar に入れることはできないため、ライブラリを jar にエクスポートすることはできません。これがあなたが得ている理由ですResources#NotFoundException。これは、ドキュメントが言うことです:

真のライブラリの場合とは異なり、ライブラリ プロジェクトを自己完結型の JAR ファイルにエクスポートすることはできません。代わりに、依存アプリケーションでライブラリを参照してそのアプリケーションをビルドすることにより、ライブラリを間接的にコンパイルする必要があります。

于 2013-10-21T18:56:24.710 に答える