- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我准备在 Windows 10、最新的 Eclipse Mars.2、最新的 Android SDK 和最新版本的 libGDX 上开发 libGDX Android 应用程序。我正在按照此处的设置说明进行操作: Project Setup Gradle
这里:
Setting up your Development Environment (Eclipse, Intellij IDEA, NetBeans)
这里
当我运行我的 android 应用程序时,它崩溃并在 logcat 中输出:
04-09 02:01:56.357: E/Trace(20747): error opening trace file: No such file or directory (2)
04-09 02:01:56.367: D/ActivityThread(20747): setTargetHeapUtilization:0.25
04-09 02:01:56.367: D/ActivityThread(20747): setTargetHeapIdealFree:8388608
04-09 02:01:56.367: D/ActivityThread(20747): setTargetHeapConcurrentStart:2097152
04-09 02:01:56.548: W/dalvikvm(20747): Unable to resolve superclass of Lcom/mygdx/game/AndroidLauncher; (3)
04-09 02:01:56.548: W/dalvikvm(20747): Link of class 'Lcom/mygdx/game/AndroidLauncher;' failed
04-09 02:01:56.548: W/dalvikvm(20747): threadid=1: thread exiting with uncaught exception (group=0x41367438)
04-09 02:01:56.568: E/AndroidRuntime(20747): FATAL EXCEPTION: main
04-09 02:01:56.568: E/AndroidRuntime(20747): java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.mygdx.game/com.mygdx.game.AndroidLauncher}: java.lang.ClassNotFoundException: com.mygdx.game.AndroidLauncher
04-09 02:01:56.568: E/AndroidRuntime(20747): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2005)
04-09 02:01:56.568: E/AndroidRuntime(20747): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2106)
04-09 02:01:56.568: E/AndroidRuntime(20747): at android.app.ActivityThread.access$600(ActivityThread.java:138)
04-09 02:01:56.568: E/AndroidRuntime(20747): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1204)
04-09 02:01:56.568: E/AndroidRuntime(20747): at android.os.Handler.dispatchMessage(Handler.java:99)
04-09 02:01:56.568: E/AndroidRuntime(20747): at android.os.Looper.loop(Looper.java:137)
04-09 02:01:56.568: E/AndroidRuntime(20747): at android.app.ActivityThread.main(ActivityThread.java:4921)
04-09 02:01:56.568: E/AndroidRuntime(20747): at java.lang.reflect.Method.invokeNative(Native Method)
04-09 02:01:56.568: E/AndroidRuntime(20747): at java.lang.reflect.Method.invoke(Method.java:511)
04-09 02:01:56.568: E/AndroidRuntime(20747): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:790)
04-09 02:01:56.568: E/AndroidRuntime(20747): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:557)
04-09 02:01:56.568: E/AndroidRuntime(20747): at dalvik.system.NativeStart.main(Native Method)
04-09 02:01:56.568: E/AndroidRuntime(20747): Caused by: java.lang.ClassNotFoundException: com.mygdx.game.AndroidLauncher
04-09 02:01:56.568: E/AndroidRuntime(20747): at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:61)
04-09 02:01:56.568: E/AndroidRuntime(20747): at java.lang.ClassLoader.loadClass(ClassLoader.java:501)
04-09 02:01:56.568: E/AndroidRuntime(20747): at java.lang.ClassLoader.loadClass(ClassLoader.java:461)
04-09 02:01:56.568: E/AndroidRuntime(20747): at android.app.Instrumentation.newActivity(Instrumentation.java:1056)
04-09 02:01:56.568: E/AndroidRuntime(20747): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1996)
04-09 02:01:56.568: E/AndroidRuntime(20747): ... 11 more
知道我做错了什么吗?
这是我的 android 代码,未更改并由 libGDX 设置过程生成。
package com.mygdx.game;
import android.os.Bundle;
import com.badlogic.gdx.backends.android.AndroidApplication;
import com.badlogic.gdx.backends.android.AndroidApplicationConfiguration;
import com.mygdx.game.MyGdxGame;
public class AndroidLauncher extends AndroidApplication {
@Override
protected void onCreate (Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
AndroidApplicationConfiguration config = new AndroidApplicationConfiguration();
initialize(new MyGdxGame(), config);
}
}
这是我的 AndroidManifest.xml(同样完全没有改变)
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.mygdx.game"
android:versionCode="1"
android:versionName="1.0" >
<uses-sdk android:minSdkVersion="8" android:targetSdkVersion="23" />
<application
android:allowBackup="true"
android:icon="@drawable/ic_launcher"
android:label="@string/app_name"
android:theme="@style/GdxTheme" >
<activity
android:name="com.mygdx.game.AndroidLauncher"
android:label="@string/app_name"
android:screenOrientation="landscape"
android:configChanges="keyboard|keyboardHidden|orientation|screenSize">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
</manifest>
这里是android目录下的gradle.build,也是我没改的。
android {
buildToolsVersion "23.0.3"
compileSdkVersion 23
sourceSets {
main {
manifest.srcFile 'AndroidManifest.xml'
java.srcDirs = ['src']
aidl.srcDirs = ['src']
renderscript.srcDirs = ['src']
res.srcDirs = ['res']
assets.srcDirs = ['assets']
jniLibs.srcDirs = ['libs']
}
instrumentTest.setRoot('tests')
}
defaultConfig {
applicationId "com.mygdx.game"
minSdkVersion 8
targetSdkVersion 23
}
}
// called every time gradle gets executed, takes the native dependencies of
// the natives configuration, and extracts them to the proper libs/ folders
// so they get packed with the APK.
task copyAndroidNatives() {
file("libs/armeabi/").mkdirs();
file("libs/armeabi-v7a/").mkdirs();
file("libs/arm64-v8a/").mkdirs();
file("libs/x86_64/").mkdirs();
file("libs/x86/").mkdirs();
configurations.natives.files.each { jar ->
def outputDir = null
if(jar.name.endsWith("natives-arm64-v8a.jar")) outputDir = file("libs/arm64-v8a")
if(jar.name.endsWith("natives-armeabi-v7a.jar")) outputDir = file("libs/armeabi-v7a")
if(jar.name.endsWith("natives-armeabi.jar")) outputDir = file("libs/armeabi")
if(jar.name.endsWith("natives-x86_64.jar")) outputDir = file("libs/x86_64")
if(jar.name.endsWith("natives-x86.jar")) outputDir = file("libs/x86")
if(outputDir != null) {
copy {
from zipTree(jar)
into outputDir
include "*.so"
}
}
}
}
task run(type: Exec) {
def path
def localProperties = project.file("../local.properties")
if (localProperties.exists()) {
Properties properties = new Properties()
localProperties.withInputStream { instr ->
properties.load(instr)
}
def sdkDir = properties.getProperty('sdk.dir')
if (sdkDir) {
path = sdkDir
} else {
path = "$System.env.ANDROID_HOME"
}
} else {
path = "$System.env.ANDROID_HOME"
}
def adb = path + "/platform-tools/adb"
commandLine "$adb", 'shell', 'am', 'start', '-n', 'com.mygdx.game/com.mygdx.game.AndroidLauncher'
}
// sets up the Android Eclipse project, using the old Ant based build.
eclipse {
// need to specify Java source sets explicitly, SpringSource Gradle Eclipse plugin
// ignores any nodes added in classpath.file.withXml
sourceSets {
main {
java.srcDirs "src", 'gen'
}
}
jdt {
sourceCompatibility = 1.6
targetCompatibility = 1.6
}
classpath {
plusConfigurations += [ project.configurations.compile ]
containers 'com.android.ide.eclipse.adt.ANDROID_FRAMEWORK', 'com.android.ide.eclipse.adt.LIBRARIES'
}
project {
name = appName + "-android"
natures 'com.android.ide.eclipse.adt.AndroidNature'
buildCommands.clear();
buildCommand "com.android.ide.eclipse.adt.ResourceManagerBuilder"
buildCommand "com.android.ide.eclipse.adt.PreCompilerBuilder"
buildCommand "org.eclipse.jdt.core.javabuilder"
buildCommand "com.android.ide.eclipse.adt.ApkBuilder"
}
}
// sets up the Android Idea project, using the old Ant based build.
idea {
module {
sourceDirs += file("src");
scopes = [ COMPILE: [plus:[project.configurations.compile]]]
iml {
withXml {
def node = it.asNode()
def builder = NodeBuilder.newInstance();
builder.current = node;
builder.component(name: "FacetManager") {
facet(type: "android", name: "Android") {
configuration {
option(name: "UPDATE_PROPERTY_FILES", value:"true")
}
}
}
}
}
}
}
如果我尝试在调试器中运行该应用程序,我会在尝试跨过第一条指令时立即在 logcat 中获取此信息:
04-09 19:23:54.285: D/AndroidRuntime(2419): Shutting down VM
04-09 19:23:54.286: E/AndroidRuntime(2419): FATAL EXCEPTION: main
04-09 19:23:54.286: E/AndroidRuntime(2419): Process: com.mygdx.game, PID: 2419
04-09 19:23:54.286: E/AndroidRuntime(2419): java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.mygdx.game/com.mygdx.game.AndroidLauncher}: java.lang.ClassNotFoundException: Didn't find class "com.mygdx.game.AndroidLauncher" on path: DexPathList[[zip file "/data/app/com.mygdx.game-1/base.apk"],nativeLibraryDirectories=[/data/app/com.mygdx.game-1/lib/x86_64, /data/app/com.mygdx.game-1/base.apk!/lib/x86_64, /vendor/lib64, /system/lib64]]
04-09 19:23:54.286: E/AndroidRuntime(2419): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2327)
04-09 19:23:54.286: E/AndroidRuntime(2419): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2476)
04-09 19:23:54.286: E/AndroidRuntime(2419): at android.app.ActivityThread.-wrap11(ActivityThread.java)
04-09 19:23:54.286: E/AndroidRuntime(2419): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1344)
04-09 19:23:54.286: E/AndroidRuntime(2419): at android.os.Handler.dispatchMessage(Handler.java:102)
04-09 19:23:54.286: E/AndroidRuntime(2419): at android.os.Looper.loop(Looper.java:148)
04-09 19:23:54.286: E/AndroidRuntime(2419): at android.app.ActivityThread.main(ActivityThread.java:5417)
04-09 19:23:54.286: E/AndroidRuntime(2419): at java.lang.reflect.Method.invoke(Native Method)
04-09 19:23:54.286: E/AndroidRuntime(2419): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726)
04-09 19:23:54.286: E/AndroidRuntime(2419): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)
04-09 19:23:54.286: E/AndroidRuntime(2419): Caused by: java.lang.ClassNotFoundException: Didn't find class "com.mygdx.game.AndroidLauncher" on path: DexPathList[[zip file "/data/app/com.mygdx.game-1/base.apk"],nativeLibraryDirectories=[/data/app/com.mygdx.game-1/lib/x86_64, /data/app/com.mygdx.game-1/base.apk!/lib/x86_64, /vendor/lib64, /system/lib64]]
04-09 19:23:54.286: E/AndroidRuntime(2419): at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56)
04-09 19:23:54.286: E/AndroidRuntime(2419): at java.lang.ClassLoader.loadClass(ClassLoader.java:511)
04-09 19:23:54.286: E/AndroidRuntime(2419): at java.lang.ClassLoader.loadClass(ClassLoader.java:469)
04-09 19:23:54.286: E/AndroidRuntime(2419): at android.app.Instrumentation.newActivity(Instrumentation.java:1067)
04-09 19:23:54.286: E/AndroidRuntime(2419): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2317)
04-09 19:23:54.286: E/AndroidRuntime(2419): ... 9 more
04-09 19:23:54.286: E/AndroidRuntime(2419): Suppressed: java.lang.NoClassDefFoundError: com.mygdx.game.AndroidLauncher
04-09 19:23:54.286: E/AndroidRuntime(2419): at dalvik.system.DexFile.defineClassNative(Native Method)
04-09 19:23:54.286: E/AndroidRuntime(2419): at dalvik.system.DexFile.defineClass(DexFile.java:226)
04-09 19:23:54.286: E/AndroidRuntime(2419): at dalvik.system.DexFile.loadClassBinaryName(DexFile.java:219)
04-09 19:23:54.286: E/AndroidRuntime(2419): at dalvik.system.DexPathList.findClass(DexPathList.java:338)
04-09 19:23:54.286: E/AndroidRuntime(2419): at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:54)
04-09 19:23:54.286: E/AndroidRuntime(2419): ... 13 more
04-09 19:23:54.286: E/AndroidRuntime(2419): Suppressed: java.lang.ClassNotFoundException: com.mygdx.game.AndroidLauncher
04-09 19:23:54.286: E/AndroidRuntime(2419): at java.lang.Class.classForName(Native Method)
04-09 19:23:54.286: E/AndroidRuntime(2419): at java.lang.BootClassLoader.findClass(ClassLoader.java:781)
04-09 19:23:54.286: E/AndroidRuntime(2419): at java.lang.BootClassLoader.loadClass(ClassLoader.java:841)
04-09 19:23:54.286: E/AndroidRuntime(2419): at java.lang.ClassLoader.loadClass(ClassLoader.java:504)
04-09 19:23:54.286: E/AndroidRuntime(2419): ... 12 more
04-09 19:23:54.286: E/AndroidRuntime(2419): Caused by: java.lang.NoClassDefFoundError: Class not found using the boot class loader; no stack trace available
最佳答案
默认情况下,您的 libgdx Assets “badlogic.jpg”位于“project_direcotry/android/assets”。
当您没有正确设置工作目录时会发生该错误,这会导致您的应用程序无法找到数据文件。要解决此问题,您需要正确设置工作目录。
如果您使用的是 intelij idea 或 android studio(基于 idea),请检查此链接: Libgdx project Exception in thread "LWJGL Application". Couldn't load file. Error log inside
检查这个,如果你使用的是eclipse: "File not found" when running new LibGDX project
关于java - 大多数基本的 libgdx 应用程序崩溃,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36514876/
我有一段代码看起来像这样: void update_clock(uint8_t *time_array) { time_t time = *((time_t *) &time_array[0]
应用程序崩溃了 :( 请帮助我.. 在这方面失败了。我找不到错误?该应用程序可以连接到 iTunesConnect 但它会出错。 谁能根据下面的崩溃报告判断问题出在哪里? share_with_app
小二是新来的实习生,作为技术 leader,我给他安排了一个非常简单的练手任务,把前端 markdown 编辑器里上传的图片保存到服务器端,结果他真的就把图片直接保存到了服务器上,这下可把我气坏了,就
我正在创建一个函数,它将目录路径作为参数传递,或者如果它留空,则提示用户输入。 我已经设置了我的 PATH_MAX=100 和 if 语句来检查 if ((strlen(folder path) +
我已将“arial.ttf”文件(从我的/Windows/Fonts 文件夹中获取)加载到内存中,但是将其传递到 FT_New_Memory_Face 时会崩溃(在 FT_Open_Face 中的某处
我正在尝试在我的计算机上的两个控制台之间进行 rtsp 流。 在控制台 1 上,我有: ffmpeg -rtbufsize 100M -re -f dshow -s 320x240 -i video=
我正在尝试使用 scio_beast在一个项目中。我知道它还没有完成,但这并不重要。我已经设法让它工作得很好。 我现在正在尝试连接到 CloudFlare 后面的服务器,我知道我需要 SNI 才能工作
我有一个带有关联宏的下拉列表,如下所示: Sub Drop() If Range("Hidden1!A1") = "1" Then Sheets("Sheet1").Se
我对 bash 很陌生。我要做的就是运行这个nvvp -vm /usr/lib64/jvm/jre-1.8.0/bin/java无需记住最后的路径。我认为 instafix 就是这样做...... n
我在 Windows 上使用 XAMPP 已经两年左右了,它运行完美,没有崩溃没有问题。 (直到四个月前。) 大约四个月前,我们将服务器/系统升级到了更快的规范。 这是旧规范的内容 - Windows
我面临着一个非常烦人的 android 崩溃,它发生在大约 1% 的 PRODUCTION session 中,应用程序始终在后台运行。 Fatal Exception: android.app.Re
尝试使用下面的函数: public void createObjectType() { try { mCloudDB.createObjectType(ObjectTypeIn
由于我正在进行的一个项目,我在 CF11 管理员中弄乱了类路径,我设法使服务器崩溃,以至于我唯一得到的是一个漂亮的蓝屏和 500 错误.我已经检查了日志,我会把我能做的贴在帖子的底部,但我希望有人会启
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 10 个月前关闭。 Improve
我最近从 xcode 3.x 更新到 4.2,当我在 4.2 中运行应用程序时,我遇到了核心数据问题。我还更新到了 iOS 5,所以问题可能就在那里,我不太确定。 这些应用程序在 3.x 中运行良好,
我是一个相对较新的 iPhone 应用程序开发人员,所以我的知识有点粗略,所以如果这是一个微不足道的问题,请原谅我。 我有一个导航应用程序,它通过在navigationController对象上调用p
if ([MFMailComposeViewController canSendMail]) { MFMailComposeViewController *mailViewController
你能帮我吗? 我正在设置 UILocalNotification,当我尝试设置其 userInfo 字典时,它崩溃了。 fetchedObjects 包含 88 个对象。 这是代码: NSDi
为什么我的代码中突然出现 NSFastEnumeration Mutation Handler 崩溃。我很茫然为什么会突然出现这个崩溃以及如何解决它。 最佳答案 崩溃错误: **** 由于未捕获的异常
当我从表中删除行时,我的应用程序崩溃了。这是我检测到错误和堆栈跟踪的来源。谢谢! //delete row from database - (void)tableView:(UITableView *
我是一名优秀的程序员,十分优秀!