Xcode配置GLFW GLAD (MAC)

这里的GLFW用的是静态链接

博主反复修改,实在是没能找到为什么用动态会出现线程报错

下载GLAD:版本我一般是选倒数第二新,profile记得选coreXcode配置GLFW GLAD (MAC)_第1张图片

 Xcode配置GLFW GLAD (MAC)_第2张图片

点击GENRATE

 Xcode配置GLFW GLAD (MAC)_第3张图片

点glad.zip获得下载

下载GLFW

点击download 

Xcode配置GLFW GLAD (MAC)_第4张图片 

最后,将两个文件都放到项目里面去

Xcode配置GLFW GLAD (MAC)_第5张图片

打开Xcode创建一个C++项目,点击这个

Xcode配置GLFW GLAD (MAC)_第6张图片

在进入到设置页面,搜索search Xcode配置GLFW GLAD (MAC)_第7张图片

 将两个不同的include直接拖到里面去(要点击header search path 旁边,会弹出来一个框)Xcode配置GLFW GLAD (MAC)_第8张图片

 

 Xcode配置GLFW GLAD (MAC)_第9张图片Xcode配置GLFW GLAD (MAC)_第10张图片

拖到里面去后,如图所示,添加(拖拽)这些文件即可,黄色的点+搜索添加Xcode配置GLFW GLAD (MAC)_第11张图片

 

 Xcode配置GLFW GLAD (MAC)_第12张图片

 

最后测试代码运行

#include 
#include 
#include 

// 对窗口注册一个回调函数(Callback Function),它会在每次窗口大小被调整的时候被调用。
// 参数:window - 被改变大小的窗口,width、height-窗口的新维度。
void framebuffer_size_callback(GLFWwindow* window, int width, int height)
{
    // 改变视口大小的函数
    glViewport(0, 0, width, height);
}

// 实现输入控制的函数
void processInput(GLFWwindow *window)
{
    // glfwGetKey两个参数:窗口,按键
    // 没有被按下返回 GLFW_PRESS
    std::cout << "是否点击ESC?" << std::endl;
    std::cout << glfwGetKey(window, GLFW_KEY_ESCAPE) << std::endl;
    if(glfwGetKey(window, GLFW_KEY_ESCAPE) == GLFW_PRESS)
        // 被按下则将 WindowShouldClose 属性置为 true
        // 以便于关闭 渲染循环
        glfwSetWindowShouldClose(window, true);
}

int main()
{
    glfwInit(); // 初始化GLFW
    // glfwWindowHint函数的第一个参数代表选项的名称
    // 第二个参数接受一个整型,用来设置这个选项的值
    
    // 将主版本号(Major)和次版本号(Minor)都设为3
    glfwWindowHint(GLFW_CONTEXT_VERSION_MAJOR, 3);
    glfwWindowHint(GLFW_CONTEXT_VERSION_MINOR, 3);
    // 使用的是核心模式(Core-profile)
    glfwWindowHint(GLFW_OPENGL_PROFILE, GLFW_OPENGL_CORE_PROFILE);
    glfwWindowHint(GLFW_OPENGL_FORWARD_COMPAT, GL_TRUE);

    // 参数依次为:宽、高、窗口的名称,显示器用于全屏模式,设为NULL是为窗口
    // 窗口的上下文为共享资源,NULL为不共享资源
    GLFWwindow* window = glfwCreateWindow(800, 600, "FirstWindow", NULL, NULL);
    if (window == NULL)
    {
        std::cout << "Failed to create GLFW window" << std::endl;
        // 释放空间,防止内存溢出
        glfwTerminate();
        return -1;
    }
    
    // 创建完毕之后,需要让window的context成为当前线程的current context
    glfwMakeContextCurrent(window);
    
    // glfwGetProcAddress是glfw提供的用来加载 系统相关的OpenGL函数指针地址 的函数
    // 用gladLoadGLLoader函数根据使用者的系统定义了正确的函数
    if (!gladLoadGLLoader((GLADloadproc)glfwGetProcAddress))
    {
        std::cout << "Failed to initialize GLAD" << std::endl;
        return -1;
    }
    
    // 告诉OpenGL渲染窗口的尺寸大小,即视口(Viewport)
    // 这样OpenGL才只能知道怎样根据窗口大小显示数据和坐标
    // 调用glViewport函数来设置窗口的维度(Dimension)
    // 前两个参数控制窗口左下角的位置。第三个和第四个参数控制渲染窗口的宽度和高度(像素)
    glViewport(0, 0, 800, 600);
    
    // 窗口大小改变时视口也要随之改变,这通过对窗口注册 framebuffer_size_callback 实现。
    // 它会在每次窗口大小被调整时调用
    glfwSetFramebufferSizeCallback(window, framebuffer_size_callback);
    
    /* 渲染循环(Render Loop) */
    // glfwWindowShouldClose 检查一次GLFW是否被要求退出
    // 为true时渲染循环结束
    while(!glfwWindowShouldClose(window))
    {
        // 监测键盘输入
        processInput(window);
        
        /* 渲染 */
        // 状态设置函数,设置清空屏幕所用的颜色
        glClearColor(0.2f, 0.3f, 0.3f, 1.0f);
        // 状态使用函数,使用设定好的颜色来清除旧的颜色缓冲
        glClear(GL_COLOR_BUFFER_BIT);
        
        // 上面两种函数起到的作用也可以用 glClearBufferfv 来现实
        /*GLfloat color[] = {0.2, 0.3, 0.3, 1.0};
        glClearBufferfv(GL_COLOR, 0, color);*/

        // glfwSwapBuffers 交换颜色缓冲,用来绘制并作为输出显示在屏幕
        glfwSwapBuffers(window);
        // glfwPollEvents 检查是否有触发事件
        glfwPollEvents();
    }
    
    glfwTerminate();
    
    return 0;
}

 

你可能感兴趣的:(C++,macos)