java - LWJGL 体素引擎 - VBO 上的纹理

标签 java textures lwjgl vbo voxel

我目前正在开发类似于 Minecraft 的体素引擎。最近我一直在尝试在系统中实现纹理。我的系统使用纹理图集和坐标系统,但是我遇到了一些问题,例如程序在启动时崩溃,只是“Java 没有响应”,如果启动了,则 block 没有纹理。那么我将如何修复我的代码来解决这些错误并正确实现纹理。谢谢!

block 类:

public class Chunk extends RenderBlock{
byte CHUNK_SIZE = 32;
private Block[][][] BlockType = new Block[CHUNK_SIZE][CHUNK_SIZE][CHUNK_SIZE];
static final float CUBE_LENGTH= RenderBlock.CUBE_LENGTH;
private static Texture texture = TextureLoad.getTexture();
private int VBOTextureHandle;
private int VBOVertexHandle;
//Texture Handle
public void drawChunk() {
    GL11.glPushMatrix();
    GL11.glEnable(GL15.GL_VERTEX_ARRAY_BUFFER_BINDING);

    GL11.glEnableClientState(GL11.GL_VERTEX_ARRAY);
    GL15.glBindBuffer(GL15.GL_ARRAY_BUFFER, VBOVertexHandle);
    GL11.glVertexPointer(3, GL11.GL_FLOAT, 0, 0);

    GL11.glEnableClientState(GL11.GL_TEXTURE_2D);
    GL15.glBindBuffer(GL15.GL_ARRAY_BUFFER, VBOTextureHandle);
    GL11.glTexCoordPointer(2, GL11.GL_FLOAT, 0, 0L);

    GL11.glBindTexture(GL11.GL_TEXTURE_2D, texture.getTextureID());
    texture.bind();
    GL13.glActiveTexture(VBOTextureHandle);

    GL11.glDrawArrays(GL11.GL_QUADS, 0, 24 * CHUNK_SIZE * CHUNK_SIZE * CHUNK_SIZE);
    GL11.glPopMatrix();
}
public Chunk(int x, int y, int z, HeightMap height) {
    for(int chunkx=0; chunkx<CHUNK_SIZE; chunkx++) {
        for(int chunky=0; chunky<CHUNK_SIZE; chunky++) {
            for(int chunkz=0; chunkz<CHUNK_SIZE; chunkz++) {
                BlockType[chunkx][chunky][chunkz] = new BlockDirt();
            }
        }
    }
    VBOTextureHandle = GL15.glGenBuffers();
    VBOVertexHandle = GL15.glGenBuffers();

    makeChunk(x, y, z, height);
}
public void makeChunk(int startx, int starty, int startz, HeightMap map) {
    VBOVertexHandle = GL15.glGenBuffers();  
    VBOTextureHandle = GL15.glGenBuffers();
    FloatBuffer VertexPositionData = BufferUtils.createFloatBuffer(CHUNK_SIZE*CHUNK_SIZE*CHUNK_SIZE*(3 * 4 * 6));
    FloatBuffer VertexTextureData = BufferUtils.createFloatBuffer(CHUNK_SIZE*CHUNK_SIZE*CHUNK_SIZE*(4 * 4 * 6));
    for(int x=0; x<CHUNK_SIZE; x++) {
        for(int y=0; y<CHUNK_SIZE; y++) {
            for(int z=0; z<CHUNK_SIZE; z++) {
                VertexPositionData.put(putVertices((float) (startx + x)* CUBE_LENGTH, (float) (starty + y) * CUBE_LENGTH, (float) (startz + z) * CUBE_LENGTH));
                VertexTextureData.put(TexturePos(getTexturePosX(BlockType[x][y][z]), getTexturePosY(BlockType[x][y][z])));
            }
        }
    }
    VertexPositionData.flip();
    VertexTextureData.flip();

    GL15.glBindBuffer(GL15.GL_ARRAY_BUFFER, VBOVertexHandle);
    GL15.glBufferData(GL15.GL_ARRAY_BUFFER, VertexPositionData,
            GL15.GL_STATIC_DRAW);
    GL15.glBindBuffer(GL15.GL_ARRAY_BUFFER, 0);

    GL15.glBindBuffer(GL15.GL_ARRAY_BUFFER, VBOTextureHandle);
    GL15.glBufferData(GL15.GL_ARRAY_BUFFER, VertexTextureData,
            GL15.GL_STATIC_DRAW);
    GL15.glBindBuffer(GL15.GL_ARRAY_BUFFER, 0);
}

}

RenderCube 类

public class RenderBlock extends Block{
static final public float CUBE_LENGTH=2;
Block block = new Block();
//verticies
public float[] putVertices(float x, float y, float z) {
    float offset = CUBE_LENGTH / 2;
    return new float[] {
            // BOTTOM QUAD(DOWN=+Y)
            x + offset, y + offset, z, 
            x - offset, y + offset, z,
            x - offset, y + offset, z - CUBE_LENGTH,
            x + offset, y + offset, z - CUBE_LENGTH,
            // TOP!
            x + offset, y - offset, z - CUBE_LENGTH,
            x - offset, y - offset, z - CUBE_LENGTH,
            x - offset, y - offset, z,
            x + offset, y - offset, z,
            // FRONT QUAD
            x + offset, y + offset, z - CUBE_LENGTH, 
            x - offset, y + offset, z - CUBE_LENGTH, 
            x - offset, y - offset, z - CUBE_LENGTH, 
            x + offset, y - offset, z - CUBE_LENGTH,
            // BACK QUAD
            x + offset, y - offset, z, 
            x - offset, y - offset, z,
            x - offset, y + offset, z,
            x + offset, y + offset, z,
            // LEFT QUAD
            x - offset, y + offset, z - CUBE_LENGTH,
            x - offset, y + offset, z,
            x - offset, y - offset, z, 
            x - offset, y - offset, z - CUBE_LENGTH,
            // RIGHT QUAD
            x + offset, y + offset, z,
            x + offset, y + offset, z - CUBE_LENGTH,
            x + offset, y - offset, z - CUBE_LENGTH,
            x + offset, y - offset, z };
}

public float[] TexturePos(int posx, int posy) {
    return new float[]{
            posx,posy,
            posx+32,posy,
            posx+32,posy+32,
            posx,posy+32
        };
}
}

最佳答案

尝试改变

GL11.glEnableClientState(GL11.GL_TEXTURE_2D);
GL15.glBindBuffer(GL15.GL_ARRAY_BUFFER, VBOTextureHandle);
GL11.glTexCoordPointer(2, GL11.GL_FLOAT, 0, 0L);

GL11.glBindTexture(GL11.GL_TEXTURE_2D, texture.getTextureID());
texture.bind();

GL11.glEnableClientState(GL11.GL_TEXTURE_COORD_ARRAY);
GL11.glBindTexture(GL11.GL_TEXTURE_2D, texture.getTextureID());
GL15.glBindBuffer(GL15.GL_ARRAY_BUFFER, VBOTextureHandle);
GL11.glTexCoordPointer(2, GL11.GL_FLOAT, 0, 0L);

此外,当使用多个纹理或某些纹理形状和其他空白或仅着色时,之后

GL11.glDrawArrays(GL11.GL_QUADS, 0, 24 * CHUNK_SIZE * CHUNK_SIZE * CHUNK_SIZE);

添加

GL11.glBindTexture(GL11.GL_TEXTURE_2D, 0);

我不确定这是否有效,我还没有测试过它,而且我不知道这是否是导致错误的原因,但这应该有助于渲染纹理。无论如何,它对我有用。

关于java - LWJGL 体素引擎 - VBO 上的纹理,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29419839/

相关文章:

java - 重复drawLine()来绘制垂直条Java

java - 识别图片上的 SWT 和 JFace 小部件

java - 如何使用 Jsoup 将 "Security : low"作为 cookie 参数发送到 DVWA?

c++ - 无法将纹理应用于 Qt OpenGL 中的顶点网格

floating-point - Three.js 支持 OES_texture_float 吗?

java - 无法在 AMD 64 位平台 LWJGL 上加载 IA 32 位 .dll

java - 无法从 START_OBJECT token 中反序列化 my.package.name.PlaceData[] 的实例

c++ - Torus 的纹理应用不正确

java - 如何在 Eclipse 中设置 JVM 启动参数?

java - 尝试使用 LWJGL 运行简单的 GLSL 着色器程序,但此代码不起作用