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

Java LWJGL体素引擎-VBO上的纹理,java,textures,lwjgl,vbo,voxel,Java,Textures,Lwjgl,Vbo,Voxel,我目前正在开发一个类似于Minecraft的体素引擎。最近我一直在尝试在系统中实现纹理。我的系统使用了纹理图谱和coord系统,但是我遇到了一些问题,比如启动时程序崩溃,Java没有响应,如果启动了,块就没有纹理。那么,我将如何修复代码以解决这些错误并正确实现纹理呢。谢谢 块类: public class Chunk extends RenderBlock{ byte CHUNK_SIZE = 32; private Block[][][] BlockType = new Block[CHUNK

我目前正在开发一个类似于Minecraft的体素引擎。最近我一直在尝试在系统中实现纹理。我的系统使用了纹理图谱和coord系统,但是我遇到了一些问题,比如启动时程序崩溃,Java没有响应,如果启动了,块就没有纹理。那么,我将如何修复代码以解决这些错误并正确实现纹理呢。谢谢

块类:

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);
}

}
试着改变

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.glDrawArrays(GL11.GL_QUADS, 0, 24 * CHUNK_SIZE * CHUNK_SIZE * CHUNK_SIZE);

我不确定这是否可行,我还没有测试它,我也不知道这是否是导致错误的原因,但这应该有助于渲染纹理。不管怎么说,它对我很有用

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);