首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >VAO绘制错误指数

VAO绘制错误指数
EN

Stack Overflow用户
提问于 2018-07-30 18:37:45
回答 1查看 150关注 0票数 1

我目前正在尝试从一个3d引擎中绘制形状,这个引擎已经为我制作,它将输出一个具有顶点和三角形的形状。顶点只列出一次,三角形是逆时针建立的。我对绘图部分有一个问题,因为在某个时候,OpenGL开始使用我没有指定的索引。

将形状设置为缓冲区和VBO的代码如下:

代码语言:javascript
复制
//Reset index Count
    indicesCount.add(s.triangles().size() * 3);
    int vertexCount = s.getVertices().size() * 3;

    //Set Hash Map
    s.setHashMap();

    for (int i = 0; i < s.getVertices().size(); i++) {
        System.err.println(s.getVertices().get(i));
    }

    //Initialize the Buffers
    vertBuff = BufferUtils.createFloatBuffer(vertexCount);
    normalBuff = BufferUtils.createFloatBuffer(vertexCount);
    indicesBuff = BufferUtils.createIntBuffer(indicesCount.get(this.objectCount - 1));

    //Place all the indices into the ByteBuffer
    ArrayList<Triangle> tempTriangles = s.triangles();

    for (Triangle t : tempTriangles) {
        for (int i = 0; i < 3; i++) {
            indicesBuff.put((s.getHashMap().get(t.vertex.get(i))));
            System.err.print(s.getHashMap().get(t.vertex.get(i)));
        }
        System.err.print('\n');
    }

    System.out.println("Hashmap: " + s.getHashMap().toString());

    //Place all the vertices in the FloatBuffer
    for (Vector v : s.getVertices()) {
        vertBuff.put((float) v.x);
        vertBuff.put((float) v.y);
        vertBuff.put((float) v.z);
        normalBuff.put((float) v.normalized().x);
        normalBuff.put((float) v.normalized().y);
        normalBuff.put((float) v.normalized().z);
    }

    //Close the Buffer for input
    vertBuff.flip();
    indicesBuff.flip();
    normalBuff.flip();

    generateOneVBO();
    setChanged(true);
}
 private void generateOneVBO() {

    vao_IDs.add(glGenVertexArrays());
    glBindVertexArray(vao_IDs.get(this.objectCount - 1));
    i_IDs.add(glGenBuffers());
    glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, i_IDs.get(this.objectCount - 1));
    glBufferData(GL_ELEMENT_ARRAY_BUFFER, indicesBuff, GL_STATIC_DRAW);
    // glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, 0);

    //Generate Buffers and get IDs
    v_IDs.add(glGenBuffers());
    glBindBuffer(GL_ARRAY_BUFFER, v_IDs.get(this.objectCount - 1));
    glBufferData(GL_ARRAY_BUFFER, vertBuff, GL_STATIC_DRAW);
    glVertexAttribPointer(0, 3, GL_FLOAT, false, 0, 0);
    glBindBuffer(GL_ARRAY_BUFFER, 0);
}

这是我的呈现函数(每当发生更改时,它都会循环)

代码语言:javascript
复制
private synchronized void render(int p_Id) {
    Vector4f selectedColor = new Vector4f(1, 0, 0, 1f);
    Vector4f normalColor = new Vector4f(0.5f, 0.5f, 0.5f, 1f);

    // glMatrixMode(GL_PROJECTION_MATRIX);
    for (int index = 0; index < v_IDs.size(); index++) {

        glBindVertexArray(vao_IDs.get(index));
        glEnableVertexAttribArray(0);
        glEnableVertexAttribArray(1);

        //  glPointSize(3.0f);
        // glEnable(GL_POINT_SMOOTH);
        //Draw triangles
        if (selected.get(index)) {
            shader.setUniform(p_Id, "shapeColor", selectedColor);
        } else {
            shader.setUniform(p_Id, "shapeColor", normalColor);
        }
        //glDrawElements(GL_TRIANGLES, indicesCount.get(index), GL_UNSIGNED_INT, 0);
        //Draw Wireframe
        shader.setUniform(p_Id, "shapeColor", new Vector4f(1, 1, 1, 0.75f));
        //glDrawElements(GL_LINE_STRIP, indicesCount.get(index), GL_UNSIGNED_INT, 0);
        int num = 0;
        glPolygonMode(GL_FRONT_AND_BACK, GL_LINE);

        Vector4f[] arr = {
            new Vector4f(1f, 0, 0, 1),
            new Vector4f(0f, 1, 0, 1),
            new Vector4f(0f, 0, 1, 1)
        };

        for (int i = 0; i < toDraw; i += 3) {
            if (i % 3 == 0) {
                num++;
            }
            shader.setUniform(p_Id, "shapeColor", arr[num % 3]);
              glDrawElements(GL_POLYGON, i + 3, GL_UNSIGNED_INT, i);
        }

        glDisableVertexAttribArray(0);
        glDisableVertexAttribArray(1);
        glBindVertexArray(0);

    }
}

我通过添加一个点击监听器并将3添加到toDraw变量中,使呈现循环一步一步地绘制我的三角线框/三角形,这样我就可以第一次看到它搞砸了。除了代码之外,我还打印了用于从顶点转换为索引的hashmap,以及在将每个索引添加到缓冲区后打印的索引的输出。

代码语言:javascript
复制
 Hashmap: {15.0 -15.0 15.0=2, -15.0 -15.0 15.0=3, 15.0 15.0 15.0=0, -15.0 15.0 15.0=1, -15.0 -15.0 -15.0=7, 15.0 -15.0 -15.0=6, -15.0 15.0 -15.0=5, 15.0 15.0 -15.0=4}

指数:

代码语言:javascript
复制
201
213
315
357
045
051
264
240
675
654
623
637.

每个数字的三重奏都是一个三角形,所以第一个是指向指数2->0->1等的三角形。

这是第一个三角形之后的窗口

第二次单击后的

窗口,在第三次单击之后,该窗口首先会被弄乱。

我已经调试了几天了,我不知道出了什么问题。我认为这可能是我画它的方式(我给它的参数),但这只是猜测。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-07-30 19:08:06

你不能画三角形:

代码语言:javascript
复制
          glDrawElements(GL_POLYGON, i + 3, GL_UNSIGNED_INT, i);

你画的多边形有n个顶点。对于i=0,您将最终得到一个三角形。对于i=3 (在循环中按步骤3增加i ),最后使用索引缓冲区的6个元素绘制一个六边形,从第四个字节开始。诸若此类。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51600293

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档