Zxing导致Android应用程序被迫关闭

时间:2011-11-09 02:24:03

标签: android zxing

每当启动扫描的活动发​​生时,android应用程序强制关闭。它在某一点上起作用,突然间不再起作用了。 Core.jar位于lib文件夹中。

logcat的:

11-08 18:13:16.490: E/AndroidRuntime(1667): FATAL EXCEPTION: main
11-08 18:13:16.490: E/AndroidRuntime(1667): java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.picky.pickyeater/libcom.google.zxing.client.android.CaptureActivity}: java.lang.ClassNotFoundException: libcom.google.zxing.client.android.CaptureActivity in loader dalvik.system.PathClassLoader[/data/app/com.picky.pickyeater-1.apk]
11-08 18:13:16.490: E/AndroidRuntime(1667):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2585)
11-08 18:13:16.490: E/AndroidRuntime(1667):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679)
11-08 18:13:16.490: E/AndroidRuntime(1667):     at android.app.ActivityThread.access$2300(ActivityThread.java:125)
11-08 18:13:16.490: E/AndroidRuntime(1667):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033)
11-08 18:13:16.490: E/AndroidRuntime(1667):     at android.os.Handler.dispatchMessage(Handler.java:99)
11-08 18:13:16.490: E/AndroidRuntime(1667):     at android.os.Looper.loop(Looper.java:123)
11-08 18:13:16.490: E/AndroidRuntime(1667):     at android.app.ActivityThread.main(ActivityThread.java:4627)
11-08 18:13:16.490: E/AndroidRuntime(1667):     at java.lang.reflect.Method.invokeNative(Native Method)
11-08 18:13:16.490: E/AndroidRuntime(1667):     at java.lang.reflect.Method.invoke(Method.java:521)
11-08 18:13:16.490: E/AndroidRuntime(1667):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
11-08 18:13:16.490: E/AndroidRuntime(1667):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
11-08 18:13:16.490: E/AndroidRuntime(1667):     at dalvik.system.NativeStart.main(Native Method)
11-08 18:13:16.490: E/AndroidRuntime(1667): Caused by: java.lang.ClassNotFoundException: libcom.google.zxing.client.android.CaptureActivity in loader dalvik.system.PathClassLoader[/data/app/com.picky.pickyeater-1.apk]
11-08 18:13:16.490: E/AndroidRuntime(1667):     at dalvik.system.PathClassLoader.findClass(PathClassLoader.java:243)
11-08 18:13:16.490: E/AndroidRuntime(1667):     at java.lang.ClassLoader.loadClass(ClassLoader.java:573)
11-08 18:13:16.490: E/AndroidRuntime(1667):     at java.lang.ClassLoader.loadClass(ClassLoader.java:532)
11-08 18:13:16.490: E/AndroidRuntime(1667):     at android.app.Instrumentation.newActivity(Instrumentation.java:1021)
11-08 18:13:16.490: E/AndroidRuntime(1667):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2577)

的OnCreate():

protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        Intent intent = new Intent("com.google.zxing.client.android.SCAN");
        intent.putExtra("SCAN_MODE", "PRODUCT_MODE");
        startActivityForResult(intent, 0);
    }

AndroidManifest.xml摘录:

<activity
            android:configChanges="orientation|keyboardHidden"
            android:name="com.google.zxing.client.android.CaptureActivity"
            android:screenOrientation="landscape"
            android:theme="@android:style/Theme.NoTitleBar.Fullscreen"
            android:windowSoftInputMode="stateAlwaysHidden" >
            <intent-filter >
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.DEFAULT" />
            </intent-filter>
            <intent-filter >
                <action android:name="com.google.zxing.client.android.SCAN" />

                <category android:name="android.intent.category.DEFAULT" />
            </intent-filter>
        </activity>

的.classpath:

<?xml version="1.0" encoding="UTF-8"?>
<classpath>
        <classpathentry kind="src" path="src"/>
        <classpathentry kind="src" path="gen"/>
        <classpathentry exported="true" kind="con" path="com.android.ide.eclipse.adt.ANDROID_FRAMEWORK"/>
        <classpathentry exported="true" kind="con" path="com.android.ide.eclipse.adt.LIBRARIES"/>
        <classpathentry kind="lib" path="lib/gson-1.7.1.jar"/>
        <classpathentry kind="lib" path="lib/jsoup-1.6.1.jar"/>
        <classpathentry kind="lib" path="lib/core.jar"/>
        <classpathentry kind="output" path="bin/classes"/>
</classpath>

4 个答案:

答案 0 :(得分:5)

zxing在这里没有做任何事情。您复制并粘贴了我们的代码,但未将其包含在您的JAR中。你只是看到ClassNotFoundException;你甚至没有达到使用我们代码的程度。

FWIW我们强烈反对我们的开源代码的这种复制和粘贴级别。请编写您自己的应用程序以启动,并重用您需要的部分。从错误来看,这似乎不是你要去的。

更强烈的是,您不应该使用我们的包名。

答案 1 :(得分:5)

我知道根据上面的肖恩,这在技术上是不正确的,但这是通过将其作为库链接来解决的。

在ZXing:
1.右键单击项目
2.单击属性
3.单击左侧菜单中的 Android 4.选中是库

在我的应用中:
1.右键单击项目
2.单击属性
3.单击左侧菜单中的 Android 4.单击添加
5.选择ZXing项目

答案 2 :(得分:2)

根据我的经验,我遇到了同样的问题。但是如果你正在使用eclipse,请确保在你自己的项目中包含真正库(CaptureActivity)。

要重新检查它:右键单击您的项目 - &gt;属性 - &gt; Android部分 - &gt;请参阅您的图书馆绿色。如果没有,那意味着你没有正确包含库。

要解决此问题,尝试从现有图书馆创建图书馆时,您可以检查将其复制到您的磁盘

希望有所帮助

答案 3 :(得分:0)

您应该尝试清除所有zxing库项目,所有其他引用的库和您的应用程序项目。这帮我解决了这个错误信息。