java - 在 Android 上运行 libgdx 应用程序时出现异常

标签 java android intellij-idea libgdx

我正在尝试在 Android 上运行 libgdx 游戏,但无法运行。我可以毫无问题地运行桌面项目,但是当我尝试运行 android 项目时,应用程序崩溃了。

我正在使用 Intellij IDEA、Debian Sid 64 位并使用 Nexus 4 来部署应用程序(当我使用模拟器时它也会崩溃)。

我的同事可以毫无问题地运行该应用程序。他使用 Windows 7 64 位、Eclipse ADT 并在 Xperia ZQ 上运行该应用程序。

我尝试遵循针对以下答案提出的建议,但它们对我不起作用,因此我们将不胜感激。

Trying to run Android game using libgdx on Genymotion

Couldn't load shared library 'gdx' for target

堆栈跟踪:

04-22 16:11:17.261    9615-9615/? E/AndroidRuntime﹕ FATAL EXCEPTION: main
    Process: com.sofq.candies, PID: 9615
    java.lang.ExceptionInInitializerError
            at java.lang.Class.newInstanceImpl(Native Method)
            at java.lang.Class.newInstance(Class.java:1208)
            at android.app.Instrumentation.newActivity(Instrumentation.java:1061)
            at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2112)
            at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2245)
            at android.app.ActivityThread.access$800(ActivityThread.java:135)
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1196)
            at android.os.Handler.dispatchMessage(Handler.java:102)
            at android.os.Looper.loop(Looper.java:136)
            at android.app.ActivityThread.main(ActivityThread.java:5017)
            at java.lang.reflect.Method.invokeNative(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:515)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
            at dalvik.system.NativeStart.main(Native Method)
     Caused by: com.badlogic.gdx.utils.GdxRuntimeException: Couldn't load shared library 'gdx' for target: Linux, 32-bit
            at com.badlogic.gdx.utils.SharedLibraryLoader.load(SharedLibraryLoader.java:104)
            at com.badlogic.gdx.utils.GdxNativesLoader.load(GdxNativesLoader.java:34)
            at com.badlogic.gdx.backends.android.AndroidApplication.<clinit>(AndroidApplication.java:61)
            at java.lang.Class.newInstanceImpl(Native Method)
            at java.lang.Class.newInstance(Class.java:1208)
            at android.app.Instrumentation.newActivity(Instrumentation.java:1061)
            at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2112)
            at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2245)
            at android.app.ActivityThread.access$800(ActivityThread.java:135)
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1196)
            at android.os.Handler.dispatchMessage(Handler.java:102)
            at android.os.Looper.loop(Looper.java:136)
            at android.app.ActivityThread.main(ActivityThread.java:5017)
            at java.lang.reflect.Method.invokeNative(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:515)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
            at dalvik.system.NativeStart.main(Native Method)
     Caused by: java.lang.UnsatisfiedLinkError: Couldn't load gdx from loader dalvik.system.PathClassLoader[DexPathList[[zip file "/data/app/com.mypackage.myapp-2.apk"],nativeLibraryDirectories=[/data/app-lib/com.mypackage.myapp-2, /vendor/lib, /system/lib]]]: findLibrary returned null
            at java.lang.Runtime.loadLibrary(Runtime.java:358)
            at java.lang.System.loadLibrary(System.java:526)
            at com.badlogic.gdx.utils.SharedLibraryLoader.load(SharedLibraryLoader.java:100)
            at com.badlogic.gdx.utils.GdxNativesLoader.load(GdxNativesLoader.java:34)
            at com.badlogic.gdx.backends.android.AndroidApplication.<clinit>(AndroidApplication.java:61)
            at java.lang.Class.newInstanceImpl(Native Method)
            at java.lang.Class.newInstance(Class.java:1208)
            at android.app.Instrumentation.newActivity(Instrumentation.java:1061)
            at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2112)
            at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2245)
            at android.app.ActivityThread.access$800(ActivityThread.java:135)
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1196)
            at android.os.Handler.dispatchMessage(Handler.java:102)
            at android.os.Looper.loop(Looper.java:136)
            at android.app.ActivityThread.main(ActivityThread.java:5017)
            at java.lang.reflect.Method.invokeNative(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:515)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
            at dalvik.system.NativeStart.main(Native Method)

最佳答案

对于面临相同错误的任何人,我通过下载基于 libgdx Gradle 的设置应用程序解决了问题,该应用程序下载了所有必需的依赖项。

http://libgdx.badlogicgames.com/download.html

关于java - 在 Android 上运行 libgdx 应用程序时出现异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23228594/

相关文章:

java - Linux 后台运行和终止 java 程序

java - Eclipse 版本控制 - 项目不再显示在工作区中的问题

intellij-idea - 未在 Intellij 中加载 SceneBuilder

java - 如何从 intellij 中的调试变量值生成模拟?

java - Netbeans 平台 : InstalledFileLocator

java - 在 Fragment 中使用 ListActivity

Android widget更新频率0,究竟是什么意思?

java - 如何为多模块 Maven 项目的每个模块创建自包含(独立)jar

java - 尝试从作为 Pair 类的自定义对象创建二维数组。不会编译

java - Base 64 编码问题 (MIME-NO-LINEFEEDS)