2012-08-01 86 views
7

的超我的系统使用WelcomeActivity延伸FragmentActivity的项目。我使用支持库,因此android-support-v4.jarlibs文件夹中。当我运行这个应用程序时,没有问题。无法解析Landroid /支持/ V4 /应用/ FragmentActivity

不过,我想ActionBarSherlock添加到项目中。在ABS项目中,我使用libs文件夹中的actionbarsherlock-plugin-maps-4.1.0.jarandroid-support-v4-r6-googlemaps.jar。在我的应用项目,我添加了ABS库,当我尝试运行应用程序时,会出现此错误:

UNEXPECTED TOP-LEVEL EXCEPTION: 
java.lang.IllegalArgumentException: already added: Landroid/support/v4/accessibilityservice/AccessibilityServiceInfoCompat$AccessibilityServiceInfoStubImpl; 

为了解决这个问题,我从我的应用程序的libs文件夹中删除的android-support-v4.jar。当我现在开始我的应用程序,该应用程序崩溃,与此logcat的:

08-01 18:59:11.182: W/dalvikvm(13338): Unable to resolve superclass of Landroid/support/v4/app/FragmentActivity; (620) 
08-01 18:59:11.182: W/dalvikvm(13338): Link of class 'Landroid/support/v4/app/FragmentActivity;' failed 
08-01 18:59:11.182: W/dalvikvm(13338): Unable to resolve superclass of Lcom/myapp/welcome/WelcomeActivity; (109) 
08-01 18:59:11.182: W/dalvikvm(13338): Link of class 'Lcom/myapp/welcome/WelcomeActivity;' failed 
08-01 18:59:11.182: E/dalvikvm(13338): Could not find class 'com.myapp.welcome.WelcomeActivity', referenced from method com.myapp.MainDispatcherActivity.startWelcomeActivity 
08-01 18:59:11.182: W/dalvikvm(13338): VFY: unable to resolve const-class 690 (Lcom/myapp/welcome/WelcomeActivity;) in Lcom/myapp/MainDispatcherActivity; 
08-01 18:59:11.182: D/dalvikvm(13338): VFY: replacing opcode 0x1c at 0x0002 
08-01 18:59:11.182: D/dalvikvm(13338): VFY: dead code 0x0004-000b in Lcom/myapp/MainDispatcherActivity;.startWelcomeActivity()V 
08-01 18:59:11.182: D/AndroidRuntime(13338): Shutting down VM 
08-01 18:59:11.182: W/dalvikvm(13338): threadid=1: thread exiting with uncaught exception (group=0x40015560) 
08-01 18:59:11.182: E/AndroidRuntime(13338): FATAL EXCEPTION: main 
08-01 18:59:11.182: E/AndroidRuntime(13338): java.lang.NoClassDefFoundError: com.myapp.welcome.WelcomeActivity 
08-01 18:59:11.182: E/AndroidRuntime(13338): at com.myapp.MainDispatcherActivity.startWelcomeActivity(MainDispatcherActivity.java:33) 
08-01 18:59:11.182: E/AndroidRuntime(13338): at com.myapp.MainDispatcherActivity.startProperActivity(MainDispatcherActivity.java:26) 
08-01 18:59:11.182: E/AndroidRuntime(13338): at com.myapp.MainDispatcherActivity.onCreate(MainDispatcherActivity.java:19) 
08-01 18:59:11.182: E/AndroidRuntime(13338): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047) 
08-01 18:59:11.182: E/AndroidRuntime(13338): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611) 
08-01 18:59:11.182: E/AndroidRuntime(13338): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663) 
08-01 18:59:11.182: E/AndroidRuntime(13338): at android.app.ActivityThread.access$1500(ActivityThread.java:117) 
08-01 18:59:11.182: E/AndroidRuntime(13338): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931) 
08-01 18:59:11.182: E/AndroidRuntime(13338): at android.os.Handler.dispatchMessage(Handler.java:99) 
08-01 18:59:11.182: E/AndroidRuntime(13338): at android.os.Looper.loop(Looper.java:130) 
08-01 18:59:11.182: E/AndroidRuntime(13338): at android.app.ActivityThread.main(ActivityThread.java:3683) 
08-01 18:59:11.182: E/AndroidRuntime(13338): at java.lang.reflect.Method.invokeNative(Native Method) 
08-01 18:59:11.182: E/AndroidRuntime(13338): at java.lang.reflect.Method.invoke(Method.java:507) 
08-01 18:59:11.182: E/AndroidRuntime(13338): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:862) 
08-01 18:59:11.182: E/AndroidRuntime(13338): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:620) 
08-01 18:59:11.182: E/AndroidRuntime(13338): at dalvik.system.NativeStart.main(Native Method) 

我该如何解决这个问题?

编辑
我有一个使用相同的ABS库,并运行良好另一个项目。我不知道我做了什么不同,或者哪些设置是错误的。

回答

13

这似乎是因为我没有在AndroidManifest.xml文件中这一行,在<application>标签出现此错误:

<uses-library android:name="com.google.android.maps" /> 
0

我自己还没有碰到它,但我认为对于ActionBarSherlock说你需要延长SherlockFragmentActivity而不是FragmentActivity。它可能不是问题,但它是一个问题

+0

的'WelcomeActivity'并不需要一个动作条,所以'FragmentActivity'就够了。然而,我已经用'SherlockFragmentActivity'试过了,它没有工作。 – nhaarman 2012-08-01 17:22:30

+0

对不起,更有帮助!也许这个ABS教程(http://www.youtube.com/watch?v=4GJ6yY1lNNY)会对你有用吗?我确实在ABS的google group上发现了一个帖子,其中有人遇到类似的问题:标准支持lib和googlemaps:(https://groups.google.com/forum/?fromgroups#!searchin/actionbarsherlock/library/ actionbarsherlock/UlmlYAyUruY/rFGrA86gVx0J),但没有回答。恐怕这就是我所拥有的一切。 – 2012-08-01 17:30:24

2

有您为actionbarsherlock库项目的编译器合规?右键单击库项目,转到属性。在java编译器下,确保合规性设置为1.6。我有类似的问题,并发现合规性设置为1.5。

+0

这确实设置为1.6。 – nhaarman 2012-08-01 17:58:25

9

点击here

我认为这是同样的问题Build Path-> Configure Build Path - > Order and Export,需要检查“android-support-v4.jar”。

希望这是对你有用。

+0

这个评论是非常有帮助的。 – 2013-06-17 22:59:48

+0

谢谢你!就是这个。支持Jar包含在列表中,但未被检查。 – asgs 2013-07-16 04:23:43

+0

非常感谢你,它的作品像魅力:)。非常感谢 – 2013-10-20 08:07:39

相关问题