java - LibGDX 'MyFirstTriangle' 示例在启动时崩溃

标签 java android eclipse libgdx

完成后this tutorial对于 libGDX android 库,桌面项目运行良好,eclipse 指出的任何地方都没有错误。当我在我的 Nexus 7 上运行它时,(运行 Android 4.3)白屏闪烁(大概是应用程序的默认背景)然后它回到主屏幕并说“不幸的是我的第一个三角形安卓有停止了。”

这是我从 LogCat 得到的错误:

08-02 20:11:52.940: E/AndroidRuntime(4095): FATAL EXCEPTION: main
08-02 20:11:52.940: E/AndroidRuntime(4095): java.lang.NoClassDefFoundError: com.test.myfirsttriangle.MyFirstTriangle
08-02 20:11:52.940: E/AndroidRuntime(4095):     at com.example.my_first_triangle_android.MainActivity.onCreate(MainActivity.java:12)
08-02 20:11:52.940: E/AndroidRuntime(4095):     at android.app.Activity.performCreate(Activity.java:5133)
08-02 20:11:52.940: E/AndroidRuntime(4095):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087)
08-02 20:11:52.940: E/AndroidRuntime(4095):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2175)
08-02 20:11:52.940: E/AndroidRuntime(4095):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2261)
08-02 20:11:52.940: E/AndroidRuntime(4095):     at android.app.ActivityThread.access$600(ActivityThread.java:141)
08-02 20:11:52.940: E/AndroidRuntime(4095):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1256)
08-02 20:11:52.940: E/AndroidRuntime(4095):     at android.os.Handler.dispatchMessage(Handler.java:99)
08-02 20:11:52.940: E/AndroidRuntime(4095):     at android.os.Looper.loop(Looper.java:137)
08-02 20:11:52.940: E/AndroidRuntime(4095):     at android.app.ActivityThread.main(ActivityThread.java:5103)
08-02 20:11:52.940: E/AndroidRuntime(4095):     at java.lang.reflect.Method.invokeNative(Native Method)
08-02 20:11:52.940: E/AndroidRuntime(4095):     at java.lang.reflect.Method.invoke(Method.java:525)
08-02 20:11:52.940: E/AndroidRuntime(4095):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:737)
08-02 20:11:52.940: E/AndroidRuntime(4095):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
08-02 20:11:52.940: E/AndroidRuntime(4095):     at dalvik.system.NativeStart.main(Native Method)

项目:我的第一个三角形

MyFirstTriangle.java:

package com.test.myfirsttriangle;

import com.badlogic.gdx.ApplicationListener;
import com.badlogic.gdx.graphics.GL10;
import com.badlogic.gdx.graphics.Mesh;
import com.badlogic.gdx.graphics.VertexAttribute;
import com.badlogic.gdx.graphics.VertexAttributes.Usage;

public class MyFirstTriangle implements ApplicationListener {
    private Mesh mesh;

    @Override
    public void create() {
        if (mesh == null) {
            mesh = new Mesh(true, 3, 3, 
                    new VertexAttribute(Usage.Position, 3, "a_position"));      

            mesh.setVertices(new float[] { -0.5f, -0.5f, 0,
                                           0.5f, -0.5f, 0,
                                           0, 0.5f, 0 });   
            mesh.setIndices(new short[] { 0, 1, 2 });           
        }
    }

    @Override
    public void dispose() { }

    @Override
    public void pause() { }

    @Override
    public void render() {
        mesh.render(GL10.GL_TRIANGLES, 0, 3);
    }

    @Override
    public void resize(int width, int height) { }

    @Override
    public void resume() { }
}

MyFirstTriangleDesktop.java

package com.test.myfirsttriangle;

import com.badlogic.gdx.backends.jogl.JoglApplication;

public class MyFirstTriangleDesktop {
    public static void main (String[] argv) {
        new JoglApplication(new MyFirstTriangle(), "My First Triangle", 480, 320, false);       
    }
}

项目:my-first-triangle-android

主要 Activity .java:

package com.example.my_first_triangle_android;

import android.os.Bundle;

import com.badlogic.gdx.backends.android.AndroidApplication;
import com.test.myfirsttriangle.MyFirstTriangle;

public class MainActivity extends AndroidApplication {
    @Override
        public void onCreate (Bundle savedInstanceState) {
                super.onCreate(savedInstanceState);
                initialize(new MyFirstTriangle(), false);               
        }
}

额外信息: 我正在运行这个 eclipse : http://developer.android.com/sdk/installing/bundle.html

编辑

似乎是 log cat 的错误

08-02 20:11:52.940: E/AndroidRuntime(4095): FATAL EXCEPTION: main
08-02 20:11:52.940: E/AndroidRuntime(4095): java.lang.NoClassDefFoundError: com.test.myfirsttriangle.MyFirstTriangle
08-02 20:11:52.940: E/AndroidRuntime(4095):     at com.example.my_first_triangle_android.MainActivity.onCreate(MainActivity.java:12)

这一行有问题:

initialize(new MyFirstTriangle(), false);               

最佳答案

从多个项目中构建 Android 应用程序远比应有的繁琐得多。基本上,当 ADT 构建您的 Android 包时,它忘记在构建中包含您的 Libgdx“核心”包(my-first-triangle)。

在 Package Explorer 中右键单击您的 Android 项目,单击 Properties,选择 Java Build Path。问题很可能出在 Order and Export 选项卡上。确保您的 my-first-triangle 项目被标记为导出(它应该有一个复选标记集)。

这不是 Libgdx 问题。只是 Libgdx 将应用程序分成多个包,因此比普通 Android 用户更容易被这个问题绊倒。

关于java - LibGDX 'MyFirstTriangle' 示例在启动时崩溃,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18027859/

相关文章:

java - Spring boot服务从oracle数据库返回大数据集

java - 程序中得到意外的输出

java - 在 Eclipse Neon "An error occurred while collecting items to be installed"中安装 Saros

java - 如何让 Tycho 将特定于平台的片段加载到任何操作系统的测试运行时中?

适用于 Xperia X10a 的安卓 USB 驱动程序

java - 为什么我的程序不能正确找到主类?

java - Intellij IDEA 中的 GWT SuperDevMode 参数

java - 如何管理多个微服务中的安全上下文

android - 没有 rsDebug,RenderScript 代码无法工作

java - 我可以在自身内部存储 Activity 或 Fragment 的静态实例吗?