glUniformMatrix4fv导致GL_INVALID_OPERATION

用户名

当我在下面的代码中调用glUniformMatrix4fv或glUniform4fv时,每次都会引发GL_INVALID_OPERATION,我尝试更改传递矩阵数据的方式,传递ID的计数,已经检查了模型ID和着色器程序,但无法弄清楚为什么这样做。

这是着色器:

330版

uniform vec4 projection; /* view port / perspective */
uniform vec4 model; /* object */
uniform vec4 view; /*camera */
in vec3 position;

void main() {
    gl_Position = projection * view * model * vec4(position, 1.0);
}

这是我的代码:

#include <iostream>
#include <GL/glew.h>
#include <GLFW/glfw3.h>
#include <glm/glm.hpp>
#include <glm/gtc/type_ptr.hpp>
#include <glm/gtc/matrix_transform.hpp>
#include <glm/gtx/transform.hpp>
#include <fstream>
#include <stdlib.h>

GLuint getShader(const char* shaderName, GLenum shaderType) {
    /* Read file */
    std::ifstream shaderFile;
    shaderFile.open(shaderName, std::ios_base::in);

    if(!shaderFile) {
        std::cout <<  shaderName << " not found" << std::endl;
        return 0;
    }

    std::string line;
    std::string shaderData;
    while(std::getline(shaderFile, line)) {
        shaderData += line + "\n";
    }

    shaderFile.close();

    /* Create shader */
    GLuint shader = glCreateShader(shaderType);

    if(shader == 0) {
        std::cout << "Failed to create shader for " << shaderName << std::endl;
        return 0;
    }

    const char *shaderStr = shaderData.c_str();

    glShaderSource(shader, 1, &shaderStr, nullptr);
    glCompileShader(shader);

    /* Check compile status */
    GLint status;
    glGetShaderiv(shader, GL_COMPILE_STATUS, &status);
    if(status != GL_TRUE) {
        GLint logLength;
        glGetShaderiv(shader, GL_INFO_LOG_LENGTH, &logLength);

        GLchar* infoLog = new GLchar[logLength + 1];
        glGetShaderInfoLog(shader, logLength, nullptr, infoLog);

        std::cout << shaderName << " failed to compile: " << infoLog << std::endl;
        return 0;
    }

    return shader;
}

int end(const char* message) {
    glfwTerminate();

    if(message != nullptr) {
        std::cout << message << std::endl;
        system("PAUSE");
    }
    return 1;
}

int main() {
    /* Initial checks */
    if (!glfwInit()) {
        return end("Failed to startup GLFW");
    }

    /* Create the window */
    GLFWwindow *window = glfwCreateWindow(500, 500, "3D world prototyping", nullptr, nullptr);

    if (!window) {
        return end("Failed to create window.");
    }

    glfwMakeContextCurrent(window); //make the window active

    /* Startup GLEW */
    glewExperimental = GL_TRUE;
    if (glewInit() != GLEW_OK) {
        return end("Failed to startup GLEW");
    }

    /* Start OpenGL constants */
    glEnable(GL_DEPTH_TEST);
    glViewport(0, 0, 500, 500);

    /* Support for multiple shaders without the need to switch attributes */
    GLuint vertexArray;
    glGenVertexArrays(1, &vertexArray);
    glBindVertexArray(vertexArray);

    /* Create buffers */
    GLuint vertexBuffer;
    glGenBuffers(1, &vertexBuffer);

    /* Shape vectors */
    GLfloat verticies[] = { //X, Y, Z
            -0.5f, -0.5f, -0.5f,
            0.5f, -0.5f, -0.5f,
            0.5f, 0.5f, -0.5f,
            0.5f, 0.5f, -0.5f,
            -0.5f, 0.5f, -0.5f,
            -0.5f, -0.5f, -0.5f,

            -0.5f, -0.5f, 0.5f,
            0.5f, -0.5f, 0.5f,
            0.5f, 0.5f, 0.5f,
            0.5f, 0.5f, 0.5f,
            -0.5f, 0.5f, 0.5f,
            -0.5f, -0.5f, 0.5f,

            -0.5f, 0.5f, 0.5f,
            -0.5f, 0.5f, -0.5f,
            -0.5f, -0.5f, -0.5f,
            -0.5f, -0.5f, -0.5f,
            -0.5f, -0.5f, 0.5f,
            -0.5f, 0.5f, 0.5f,

            0.5f, 0.5f, 0.5f,
            0.5f, 0.5f, -0.5f,
            0.5f, -0.5f, -0.5f,
            0.5f, -0.5f, -0.5f,
            0.5f, -0.5f, 0.5f,
            0.5f, 0.5f, 0.5f,

            -0.5f, -0.5f, -0.5f,
            0.5f, -0.5f, -0.5f,
            0.5f, -0.5f, 0.5f,
            0.5f, -0.5f, 0.5f,
            -0.5f, -0.5f, 0.5f,
            -0.5f, -0.5f, -0.5f,

            -0.5f, 0.5f, -0.5f,
            0.5f, 0.5f, -0.5f,
            0.5f, 0.5f, 0.5f,
            0.5f, 0.5f, 0.5f,
            -0.5f, 0.5f, 0.5f,
            -0.5f, 0.5f, -0.5f,

            -1.0f, -1.0f, -0.5f,
            1.0f, -1.0f, -0.5f,
            1.0f, 1.0f, -0.5f,
            1.0f, 1.0f, -0.5f,
            -1.0f, 1.0f, -0.5f,
            -1.0f, -1.0f, -0.5f
    };
    glBindBuffer(GL_ARRAY_BUFFER, vertexBuffer);
    glBufferData(GL_ARRAY_BUFFER, sizeof(verticies), verticies, GL_STATIC_DRAW);

    /* Load in the shaders */
    GLuint fragmentShader = getShader("fragmentShader.glsl", GL_FRAGMENT_SHADER);
    GLuint vertexShader = getShader("vertexShader.glsl", GL_VERTEX_SHADER);

    if (fragmentShader == 0 || vertexShader == 0) {
        return end("Failed to load shaders");
    }

    /* Setup the shaders */
    /* Create the shader program and use it */
    GLuint shaderProgram = glCreateProgram();

    if (shaderProgram == 0) {
        return end("Failed to create shader program");
    }

    glAttachShader(shaderProgram, vertexShader);
    glAttachShader(shaderProgram, fragmentShader);
    glBindFragDataLocation(shaderProgram, 0, "outColor"); //tell opengl about the out color variable
    glLinkProgram(shaderProgram);

    if(glIsProgram(shaderProgram) != GL_TRUE) {
        return end("Failed to create shader program");
    }

    /* Positioning */
    //FOV, Screen ratio, display range short, display range long
    glm::mat4 projection = glm::perspective(glm::radians(45.0f), 4.0f / 3.0f, 0.1f, 100.0f);
    glm::mat4 view = glm::lookAt(
        glm::vec3(4.0f, 3.0f, 3.0f), // Camera
        glm::vec3(0.0f, 0.0f, 0.0f), // Where the camera looks up
        glm::vec3(0.0f, 1.0f, 0.0f)  // Pitch of the head
    );
    glm::mat4 model = glm::mat4(1.0f);

    /* Rendering and logic */
    while (!glfwWindowShouldClose(window)) {
        /* Shutdown logic */
        if (glfwGetKey(window, GLFW_KEY_ESCAPE)) {
            break;
        }

        /* Clear */
        glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
        glClearColor(0.2f, 0.2f, 0.2f, 1.0f);

        /* Logic */
        glUseProgram(shaderProgram);

        GLint projectionId = glGetUniformLocation(shaderProgram, "projection");
        GLint viewId = glGetUniformLocation(shaderProgram, "view");
        GLint modelId = glGetUniformLocation(shaderProgram, "model");

GLenum error = glGetError();
        if(error != GL_NO_ERROR) {
            std::cout << "Uniform error " << error << ": " << glewGetErrorString(error) << std::endl;
            return end("");
        }
        else if(projectionId == -1) {
            return end("Projection ID failed to load");
        }
        else if(viewId == -1) {
            return end("View ID failed to load");
        }
        else if(modelId == -1) {
            return end("Model ID failed to load");
        }

        glUniformMatrix4fv(viewId, 3, GL_FALSE, glm::value_ptr(view));

        error = glGetError();
        if(error != GL_NO_ERROR) {
            std::cout << "View uniform matrix error " << error << ": " << glewGetErrorString(error) << std::endl;
        }

        glUniformMatrix4fv(projectionId, 3, GL_FALSE, glm::value_ptr(projection));

        error = glGetError();
        if(error != GL_NO_ERROR) {
            std::cout << "Projection matrix error " << error << ": " << glewGetErrorString(error) << std::endl;
        }

        glUniformMatrix4fv(modelId, 3, GL_FALSE, glm::value_ptr(model));

        error = glGetError();
        if(error != GL_NO_ERROR) {
            std::cout << "Model uniform matrix error " << error << ": " << glewGetErrorString(error) << std::endl;
        }

        /* Tell opengl about all the attributes */
        GLint positionAttribute = glGetAttribLocation(shaderProgram, "position");

        if(positionAttribute == -1) {
            std::cout << "Error: position attribute failed to load" << std::endl;
            end("");
        }
        error = glGetError();
        if(error != GL_NO_ERROR) {
            std::cout << "Position attribute error " << error << ": " << glewGetErrorString(error) << std::endl;
        }

        glEnableVertexAttribArray(positionAttribute);

        error = glGetError();
        if(error != GL_NO_ERROR) {
            std::cout << "Vertex enable error " << error << ": " << glewGetErrorString(error) << std::endl;
        }

        glBindBuffer(GL_ARRAY_BUFFER, vertexBuffer);

        error = glGetError();
        if(error != GL_NO_ERROR) {
            std::cout << "Buffer bind error " << error << ": " << glewGetErrorString(error) << std::endl;
        }

        glVertexAttribPointer(positionAttribute, 3, GL_FLOAT, GL_FALSE, 0, 0); //because not just XYZ need to tell opengl the size of the stride

        error = glGetError();
        if(error != GL_NO_ERROR) {
            std::cout << "Vertex attrib pointer error " << error << ": " << glewGetErrorString(error) << std::endl;
        }

        /* Draw */
        glDrawArrays(GL_TRIANGLES, 0, 36);

        error = glGetError();
        if(error != GL_NO_ERROR) {
            std::cout << "gl draw arrays " << error << ": " << glewGetErrorString(error) << std::endl;
        }

        glDisableVertexAttribArray(positionAttribute);

        error = glGetError();
        if(error != GL_NO_ERROR) {
            std::cout << "gl disable attrib error " << error << ": " << glewGetErrorString(error) << std::endl;
        }

        glfwSwapBuffers(window);
        glfwPollEvents();

        error = glGetError();
        if(error != GL_NO_ERROR) {
            std::cout << "Error " << error << ": " << glewGetErrorString(error) << std::endl;
        }
    }

    glfwDestroyWindow(window);
    glDeleteProgram(shaderProgram);
    glDeleteShader(fragmentShader);
    glDeleteShader(vertexShader);
    glDeleteBuffers(1, &vertexBuffer);
    glDeleteVertexArrays(1, &vertexArray);
    return end(nullptr);
}
安东·科尔曼(Andon M.Coleman)

对于有问题的特定制服,您使用了错误的API调用来设置它们。

这些是向量,而不是矩阵。您将使用glUniform4fv (...)而不是glUniformMatrix4fv (...)后一个函数假定您要设置1个或更多4x4矩阵均匀(您传递的参数告诉它projection应该是3 mat4s的数组)。


我相信适当的函数调用在您的情况下将如下所示:

glUniform4fv (modelId, 1, glm::value_ptr(model)); // Fill 1 4D vector, not an array of vectors

本文收集自互联网,转载请注明来源。

如有侵权,请联系[email protected] 删除。

编辑于
0

我来说两句

0条评论
登录后参与评论

相关文章

来自分类Dev

threejs纹理导致“ GL错误:GL_INVALID_OPERATION:glDrawElements”

来自分类Dev

ios-将4x4矩阵传递给glUniformMatrix4fv

来自分类Dev

glNamedBufferData触发GL_INVALID_OPERATION

来自分类Dev

glVertexAttribPointer(Offset?)提供GL_INVALID_OPERATION

来自分类Dev

OpenGL / JOGL投掷GL_INVALID_OPERATION

来自分类Dev

glNamedBufferData触发GL_INVALID_OPERATION

来自分类Dev

glBufferData生成GL_INVALID_OPERATION

来自分类Dev

与glUniformMatrix4fv一起使用时,PyOpenGL中的glm的value_ptr返回错误

来自分类Dev

镶嵌着色器上的GL_INVALID_OPERATION

来自分类Dev

glVertexAttribPointer GL_INVALID_OPERATION无效vao vbo指针用法

来自分类Dev

为什么glDrawBuffer生成GL_INVALID_OPERATION?

来自分类Dev

glVertexAttribPointer引发不可能的GL_INVALID_OPERATION?

来自分类Dev

glGenerateMipmap在特定平台上引发GL_INVALID_OPERATION

来自分类Dev

OpenGL中的怪异GL_INVALID_OPERATION错误

来自分类Dev

带有GL_PIXEL_UNPACK_BUFFER的glTexSubImage2D得到GL_INVALID_OPERATION

来自分类Dev

copyTexImage2D — GL错误:GL_INVALID_OPERATION:glCopyTexImage2D:

来自分类Dev

LWJGL Wiki上的示例代码因GL_INVALID_OPERATION而失败

来自分类Dev

加载均匀矩阵1104 GL_Invalid_Operation Android OpenGLES 2.0

来自分类Dev

glreadpixels模具缓冲区总是抛出GL_INVALID_OPERATION

来自分类Dev

“ GL_INVALID_OPERATION:缓冲区大小不足。” 在可变数量的渲染调用之后

来自分类Dev

LWJGL Wiki上的示例代码因GL_INVALID_OPERATION而失败

来自分类Dev

glUniform1i无法解释的GL_INVALID_OPERATION(OpenGL认为int是浮点数?)

来自分类Dev

电子修复“ ERROR:buffer_manager.cc(488)] [.DisplayCompositor] GL错误:GL_INVALID_OPERATION:glBufferData:<-来自先前GL命令的错误”

来自分类Dev

Chrome GL_INVALID_OPERATION 上的 Three.js 自定义着色器错误:缺少片段着色器输出的活动绘制缓冲区

来自分类Dev

lwjgl 3,glUniformMatrix4导致jre崩溃

来自分类Dev

在Android上写入gl_FragColor会导致INVALID_OPERATION

来自分类Dev

glGenBuffers-GL_INVALID_OPERATION

来自分类Dev

带有Android GLES20的Samsung Galaxy Tab Pro上的glUniformMatrix2fv-适用于Droid Bionic

来自分类Dev

为什么对glfwWindowHint()进行一些调用后glewInit()导致GL_INVALID_ENUM

Related 相关文章

  1. 1

    threejs纹理导致“ GL错误:GL_INVALID_OPERATION:glDrawElements”

  2. 2

    ios-将4x4矩阵传递给glUniformMatrix4fv

  3. 3

    glNamedBufferData触发GL_INVALID_OPERATION

  4. 4

    glVertexAttribPointer(Offset?)提供GL_INVALID_OPERATION

  5. 5

    OpenGL / JOGL投掷GL_INVALID_OPERATION

  6. 6

    glNamedBufferData触发GL_INVALID_OPERATION

  7. 7

    glBufferData生成GL_INVALID_OPERATION

  8. 8

    与glUniformMatrix4fv一起使用时,PyOpenGL中的glm的value_ptr返回错误

  9. 9

    镶嵌着色器上的GL_INVALID_OPERATION

  10. 10

    glVertexAttribPointer GL_INVALID_OPERATION无效vao vbo指针用法

  11. 11

    为什么glDrawBuffer生成GL_INVALID_OPERATION?

  12. 12

    glVertexAttribPointer引发不可能的GL_INVALID_OPERATION?

  13. 13

    glGenerateMipmap在特定平台上引发GL_INVALID_OPERATION

  14. 14

    OpenGL中的怪异GL_INVALID_OPERATION错误

  15. 15

    带有GL_PIXEL_UNPACK_BUFFER的glTexSubImage2D得到GL_INVALID_OPERATION

  16. 16

    copyTexImage2D — GL错误:GL_INVALID_OPERATION:glCopyTexImage2D:

  17. 17

    LWJGL Wiki上的示例代码因GL_INVALID_OPERATION而失败

  18. 18

    加载均匀矩阵1104 GL_Invalid_Operation Android OpenGLES 2.0

  19. 19

    glreadpixels模具缓冲区总是抛出GL_INVALID_OPERATION

  20. 20

    “ GL_INVALID_OPERATION:缓冲区大小不足。” 在可变数量的渲染调用之后

  21. 21

    LWJGL Wiki上的示例代码因GL_INVALID_OPERATION而失败

  22. 22

    glUniform1i无法解释的GL_INVALID_OPERATION(OpenGL认为int是浮点数?)

  23. 23

    电子修复“ ERROR:buffer_manager.cc(488)] [.DisplayCompositor] GL错误:GL_INVALID_OPERATION:glBufferData:<-来自先前GL命令的错误”

  24. 24

    Chrome GL_INVALID_OPERATION 上的 Three.js 自定义着色器错误:缺少片段着色器输出的活动绘制缓冲区

  25. 25

    lwjgl 3,glUniformMatrix4导致jre崩溃

  26. 26

    在Android上写入gl_FragColor会导致INVALID_OPERATION

  27. 27

    glGenBuffers-GL_INVALID_OPERATION

  28. 28

    带有Android GLES20的Samsung Galaxy Tab Pro上的glUniformMatrix2fv-适用于Droid Bionic

  29. 29

    为什么对glfwWindowHint()进行一些调用后glewInit()导致GL_INVALID_ENUM

热门标签

归档