2012-07-25 83 views
0

我有一个测试项目,它使用OI FileManager。我将该项目作为Android库添加到我的测试项目中,然后在库中调用Activitity。它显示错误:ActivityNotFoundException当包括Android库

E/AndroidRuntime(1359): FATAL EXCEPTION: main 
E/AndroidRuntime(1359): android.content.ActivityNotFoundException: Unable to find explicit activity class {com.androidcoretest/org.openintents.filemanager.FileManagerActivity}; have you declared this activity in your AndroidManifest.xml? 
E/AndroidRuntime(1359): at android.app.Instrumentation.checkStartActivityResult(Instrumentation.java:1404) 
E/AndroidRuntime(1359): at android.app.Instrumentation.execStartActivity(Instrumentation.java:1378) 
E/AndroidRuntime(1359): at android.app.Activity.startActivityForResult(Activity.java:2817) 
E/AndroidRuntime(1359): at android.app.Activity.startActivity(Activity.java:2923) 
E/AndroidRuntime(1359): at com.androidcoretest.FileExplorerTest$1.onClick(FileExplorerTest.java:24) 
E/AndroidRuntime(1359): at android.view.View.performClick(View.java:2408) 
E/AndroidRuntime(1359): at android.view.View$PerformClick.run(View.java:8816) 
E/AndroidRuntime(1359): at android.os.Handler.handleCallback(Handler.java:587) 
E/AndroidRuntime(1359): at android.os.Handler.dispatchMessage(Handler.java:92) 
E/AndroidRuntime(1359): at android.os.Looper.loop(Looper.java:123) 
E/AndroidRuntime(1359): at android.app.ActivityThread.main(ActivityThread.java:4627) 
E/AndroidRuntime(1359): at java.lang.reflect.Method.invokeNative(Native Method) 
E/AndroidRuntime(1359): at java.lang.reflect.Method.invoke(Method.java:521) 
E/AndroidRuntime(1359): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868) 
E/AndroidRuntime(1359): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626) 
E/AndroidRuntime(1359): at dalvik.system.NativeStart.main(Native Method) 

当我在Manifest中添加该活动的完整路径时,它会生成另一个错误。

<activity 
     android:label="@string/app_name" 
     android:name="org.openintents.filemanager.FileManagerActivity" >  
    </activity> 

它显示:

E/AndroidRuntime(1393): FATAL EXCEPTION: main 
E/AndroidRuntime(1393): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.androidcoretest/org.openintents.filemanager.FileManagerActivity}: android.content.ActivityNotFoundException: Unable to find explicit activity class {com.androidcoretest/org.openintents.distribution.EulaActivity}; have you declared this activity in your AndroidManifest.xml? 
E/AndroidRuntime(1393): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2663) 
E/AndroidRuntime(1393): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679) 
E/AndroidRuntime(1393): at android.app.ActivityThread.access$2300(ActivityThread.java:125) 
E/AndroidRuntime(1393): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033) 
E/AndroidRuntime(1393): at android.os.Handler.dispatchMessage(Handler.java:99) 
E/AndroidRuntime(1393): at android.os.Looper.loop(Looper.java:123) 
E/AndroidRuntime(1393): at android.app.ActivityThread.main(ActivityThread.java:4627) 
E/AndroidRuntime(1393): at java.lang.reflect.Method.invokeNative(Native Method) 
E/AndroidRuntime(1393): at java.lang.reflect.Method.invoke(Method.java:521) 
E/AndroidRuntime(1393): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868) 
E/AndroidRuntime(1393): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626) 
E/AndroidRuntime(1393): at dalvik.system.NativeStart.main(Native Method) 
E/AndroidRuntime(1393): Caused by: android.content.ActivityNotFoundException: Unable to find explicit activity class {com.androidcoretest/org.openintents.distribution.EulaActivity}; have you declared this activity in your AndroidManifest.xml? 
E/AndroidRuntime(1393): at android.app.Instrumentation.checkStartActivityResult(Instrumentation.java:1404) 
E/AndroidRuntime(1393): at android.app.Instrumentation.execStartActivity(Instrumentation.java:1378) 
E/AndroidRuntime(1393): at android.app.Activity.startActivityForResult(Activity.java:2817) 
E/AndroidRuntime(1393): at android.app.Activity.startActivity(Activity.java:2923) 
E/AndroidRuntime(1393): at org.openintents.distribution.EulaOrNewVersion.startForwardActivity(EulaOrNewVersion.java:127) 
E/AndroidRuntime(1393): at org.openintents.distribution.EulaOrNewVersion.showEula(EulaOrNewVersion.java:69) 
E/AndroidRuntime(1393): at org.openintents.distribution.DistributionLibrary.showEulaOrNewVersion(DistributionLibrary.java:53) 
E/AndroidRuntime(1393): at org.openintents.filemanager.FileManagerActivity.onCreate(FileManagerActivity.java:312) 
E/AndroidRuntime(1393): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047) 
E/AndroidRuntime(1393): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2627) 
E/AndroidRuntime(1393): ... 11 more 
W/ActivityManager( 59): Force finishing activity com.androidcoretest/org.openintents.filemanager.FileManagerActivity 

我会说这是Eclipse中的一个bug。 Eclipse和ADT最近在构建过程中有许多错误:ClassNotFound和ActivityNotFound。

更新: 我的代码只需使用一条线路:

  final Intent intent = new Intent(FileExplorerTest.this, FileManagerActivity.class); 
      startActivity(intent); 

其实我有3个项目。 2个图书馆项目和1个测试项目。库“OI文件管理器”使用库“OI分布”,然后测试项目C使用库“IO文件管理器”。

+0

清洁项目。 – 2012-07-25 07:51:24

+0

显示如何开始活动。当项目被添加为Android库时,您不需要在清单中添加活动标签。 – pawelzieba 2012-07-25 07:51:58

+0

你试过android:name =“。filemanager.FileManagerActivity”或者android:name =“。org.openintents.filemanager.FileManagerActivity”这个点(。) – 2012-07-25 07:53:31

回答

1

确保您链接OI文件管理项目作为一个库,而不是外部的罐子。转到项目属性> Android>库,然后单击添加库。

然后当你正在做的项目清单定义活动(但与ADT 20,我认为这是自动的)

<activity 
     android:label="@string/app_name" 
     android:name="org.openintents.filemanager.FileManagerActivity" >  
    </activity> 
+0

当然,正确的方法是将它添加为Android库。不使用jar文件。 – Emerald214 2012-07-25 08:07:09

0

我想它找不到com.androidcoretest/org.openintents.distribution.EulaActivity而不是FileManager活动。清单中是否有EulaActivity

查看日志:

Caused by: android.content.ActivityNotFoundException: Unable to find explicit activity class {com.androidcoretest/org.openintents.distribution.EulaActivity}; have you declared this activity in your AndroidManifest.xml?