不能混合使用OpenGL缓冲区和CPU缓冲区
创始人
2024-12-27 03:30:35
0

在使用OpenGL缓冲区和CPU缓冲区时,最好避免混合使用,因为这可能会导致同步问题和性能下降。以下是一个解决方法的示例代码:

#include 
#include 
#include 

void error_callback(int error, const char* description)
{
    std::cout << "Error: " << description << std::endl;
}

int main()
{
    glfwSetErrorCallback(error_callback);

    if (!glfwInit())
    {
        std::cout << "Failed to initialize GLFW" << std::endl;
        return -1;
    }

    glfwWindowHint(GLFW_CONTEXT_VERSION_MAJOR, 3);
    glfwWindowHint(GLFW_CONTEXT_VERSION_MINOR, 3);
    glfwWindowHint(GLFW_OPENGL_PROFILE, GLFW_OPENGL_CORE_PROFILE);

    GLFWwindow* window = glfwCreateWindow(800, 600, "OpenGL Buffer Example", nullptr, nullptr);
    if (!window)
    {
        std::cout << "Failed to create GLFW window" << std::endl;
        glfwTerminate();
        return -1;
    }

    glfwMakeContextCurrent(window);

    glewExperimental = GL_TRUE;
    if (glewInit() != GLEW_OK)
    {
        std::cout << "Failed to initialize GLEW" << std::endl;
        glfwTerminate();
        return -1;
    }

    // 创建和绑定OpenGL缓冲区
    GLuint vbo;
    glGenBuffers(1, &vbo);
    glBindBuffer(GL_ARRAY_BUFFER, vbo);

    // 将数据上传到OpenGL缓冲区
    GLfloat vertices[] = {
        // 顶点坐标
        0.5f, 0.5f, 0.0f,
        0.5f, -0.5f, 0.0f,
        -0.5f, -0.5f, 0.0f,
        -0.5f, 0.5f, 0.0f
    };
    glBufferData(GL_ARRAY_BUFFER, sizeof(vertices), vertices, GL_STATIC_DRAW);

    // 定义顶点属性指针
    glVertexAttribPointer(0, 3, GL_FLOAT, GL_FALSE, 3 * sizeof(GLfloat), (void*)0);
    glEnableVertexAttribArray(0);

    // 创建和绑定CPU缓冲区
    GLfloat cpuBuffer[4];

    // 从OpenGL缓冲区读取数据到CPU缓冲区
    glGetBufferSubData(GL_ARRAY_BUFFER, 0, sizeof(cpuBuffer), cpuBuffer);

    // 打印CPU缓冲区数据
    std::cout << "CPU Buffer Data: ";
    for (int i = 0; i < 4; ++i)
    {
        std::cout << cpuBuffer[i] << " ";
    }
    std::cout << std::endl;

    while (!glfwWindowShouldClose(window))
    {
        glClearColor(0.2f, 0.3f, 0.3f, 1.0f);
        glClear(GL_COLOR_BUFFER_BIT);

        // 渲染OpenGL缓冲区中的数据
        glDrawArrays(GL_QUADS, 0, 4);

        glfwSwapBuffers(window);
        glfwPollEvents();
    }

    glfwTerminate();
    return 0;
}

在上面的示例代码中,我们首先创建并绑定了一个OpenGL缓冲区,并将顶点数据上传到该缓冲区。然后,我们创建了一个CPU缓冲区,并使用glGetBufferSubData函数从OpenGL缓冲区中读取数据到CPU缓冲区。最后,我们打印出CPU缓冲区中的数据。

请注意,混合使用OpenGL缓冲区和CPU缓冲区可能会导致同步问题,因此在实际应用程序中,最好避免混合使用。

相关内容

热门资讯

最新款2分钟!wepokeai... 最新款2分钟!wepokeai代打微扑克ai机器人(果然真的有挂)-知乎;1、上手简单,内置详细流程...
苹果版一分钟!wepoke软件... 苹果版一分钟!wepoke软件透明下载渠道aapoker ai软件(一般真的有挂)-小红书;1、该软...
下载7分钟!约局吧辅助工具获取... 下载7分钟!约局吧辅助工具获取方法德州最新辅助器(一贯真的有挂)-知乎1、约局吧辅助工具获取方法系统...
大厅房2分钟!wpk有外挂微扑... 大厅房2分钟!wpk有外挂微扑克wpk安全(就是真的有挂)-百度知乎1、微扑克wpk安全ai机器人多...
新版四分钟!wepoke打伙牌... 新版四分钟!wepoke打伙牌德扑之星用刷数据(本来真的有挂)-知乎1、金币登录送、破产送、升级送、...
脚本一分钟!aapoker发牌... 脚本一分钟!aapoker发牌逻辑鱼扑克app ai(果然真的有挂)-今日头条1、每一步都需要思考,...
漏洞9分钟!aapoker发牌... 漏洞9分钟!aapoker发牌机制微扑克机器人代打(一般真的有挂)-哔哩哔哩;1、每一步都需要思考,...
新版9分钟!德州之星有辅助挂w... 新版9分钟!德州之星有辅助挂wepoke ai(一直真的有挂)-知乎;1、全新机制【德州之星有辅助挂...
最新款两分钟!wpk发牌wpk... 最新款两分钟!wpk发牌wpk怎输赢机制(其实真的有挂)-小红书暗藏猫腻,小编详细说明wpk怎输赢机...
测试7分钟!aapoker是有... 测试7分钟!aapoker是有软件wpk可以玩胜率高(本来真的有挂)-今日头条;小薇(透视辅助)致您...