zoukankan      html  css  js  c++  java
  • 踏入OpenGL大门 —— VS2015开发环境配置 (详细图文)

     

     
    眼睛熊

    ---------------- 本文 ---------------

    注意:笔者是以 Win10 + VS2015 为例

    内容:安装CMake、配置freeglut 、配置glew

    版本:Window10、VS2015、CMake 3.8.0-rc-1、freeglut 3.0.0、glew 2.0.0

    目标:使初学者不再为配置OpenGL相关环境苦恼

    预热

    需要说明的是:OpenGL不需要安装——它的实现早就在您的显卡中存在了。

    想要开发OpenGL程序,需要的只是它的一系列接口,而在真正开发时,也不需要在网上找OpenGL的头文件,编译器已经把关于OpenGL的头文件放置在某一个位置中了。

    查看OpenGL头文件的方式是用VS随便创建一工程(实例使用了预编译头),然后引入头文件:

    #include <glGL.h>
    

    然后右键打开文档、再在相应的选项卡上右键打开文件所在的文件夹,如下所示:


     
    打开文档
     
    右键打开文件所在的文件夹
     
    查看OpenGL头文件

    可以看到实例图片中,包含这两个OpenGL的头文件:

    GL.h:OpenGL所使用的函数和常量声明。
    GLU.h(OpenGL实用库)所使用的函数和常量声明。

    不同的系统,这些文件的路径和名字(大小写)很可能是不同的,所以不用纠结这个问题,因为你若是直接引入这个头文件,编译则报错。


     
    直接引入OpenGL头文件,编译报错

    此时先引入windows头文件即可:

    // stdafx.h : 标准系统包含文件的包含文件,
    // 或是经常使用但不常更改的
    // 特定于项目的包含文件
    //
    
    #pragma once
    
    #include "targetver.h"
    
    #include <stdio.h>
    #include <tchar.h>
    
    
    
    // TODO:  在此处引用程序需要的其他头文件
    #include <Windows.h>
    #include <glGL.h>
    #include <glGLU.h>
    

    然而,即使如此也并不能立即用代码创建一个窗口来瞧一瞧,因为:

    OpenGL自身并不包含任何窗口任务或者处理用户输入的函数。
    OpenGL也没有提供任何用于表达三维物体模型、或者读取图像文件(例如JPEG文件)的操作。

    所以热身完毕。

    准备

    OpenGL既然没有包含那些东西,那么我们自然需要用第三方软件库来完成这些功能,例如创建窗口、接受鼠标和键盘事件等。备选的第三方软件库还必须和OpenGL一样支持跨平台移植,于是出现两个大家都在用的第三方软件库:freeGLUT 和 GLEW。

    FreeGLUT 是GLUT的一个完全开源替代库。
    GLEW是一个简单的OpenGL扩展工具库

    本文与其说是OpenGL的开发环境配置教程,不如说是OpenGL相关的第三方软件库的开发环境配置教程。

    下载

    GLEW只需要去官网下载最新版本就可以了,里面包含了相关的头文件和编译好的lib、dll文件。

    而FreeGLUT在官网中下载到的文件需要在本地进一步编译,才能被我们使用,所以本文使用CMake来帮助我们编译FreeGLUT。

    各种官网地址
    OpenGL: https://www.opengl.org/
    FreeGLUT: http://freeglut.sourceforge.net/
    GLEW: http://glew.sourceforge.net/
    CMake: https://cmake.org/

    笔者提前准备了相应文件,不想麻烦的童鞋可以在这里下载它们

    下载CMake:
     
    打开CMake官网,点击Download

     
    下拉页面

     
    根据系统的不同,选择对应的安装文件,点击即可下载(笔者选择了第一个红框选中的文件)。

     
    下载完毕
    下载FreeGLUT:
     
    打开FreeGLUT官网,点击Download
     
    选中最新稳定版,点击即可下载
    下载GLEW:
     
    打开GLEW官网,点击二进制文件即可下载
    下载完成
     
    最终文件

     
    最终文件
    安装CMake

    没什么特别的,一路next下来即可。


     
    点击next
     
    勾选 I accept... ,点击next

     
    点击next

     
    点击next

     
    点击Install,如果弹出权限询问,选择是即可。
     
    点击Finish,安装完成
    编译FreeGLUT文件

    解压freeglut-3.0.0.tar,并创建CMake编译文件输出文件夹:


     
    解压freeglut-3.0.0.tar,并创建CMake编译文件输出文件夹

    打开CMake(cmake-gui), 如下图二者之一:

     
    打开CMake(cmake-gui)
     
    打开CMake(cmake-gui)

    在 where is the source code 中选择解压freeglut的目录,注意这个目录内包含了CMakeLists.txt。

    在where to build the binaries 中选择之前创建的CMake编译文件输出文件夹:


     
    点击箭头指向的按钮选择对应的文件夹
     
    freeglut解压的文件夹,注意该文件夹内包含了CMakeLists.txt

    点击Configure:
     
    点击Configure

     
    弹出的窗口中选择对应的VS版本,笔者选择的是VS2015,点击Finish

     
    等待完成,会出现 Configuring done 字样

    注意,如果出现错误提示,则先点击File->Delete Cache之后,再点击Configure,然后选择不同的VS版本重试(前提是你的电脑确实安装了该版本的VS):
     
    如果出现错误提示
     
    点击Delete Cache之后,再点击Configure,然后选择不同的VS版本重试

    Configur完成之后(注意勾选下图列出的项,特别是FREEGLUT_BUILD_SHARED_LIBS 和FREEGLUT_BULID_STATIC_LIBS),点击Generate生成VS工程文件:
     
    点击Generate

     
    Generate成功

    打开CMake输出文件目录,找到freeglut.sln文件,双击打开:


     
    打开CMake输出文件目录

     
    双击打开freeglut.sln

     
    等待VS2015加载完成

     
    注意测试工程环境:Dubug & Win32

    点击生成->生成解决方法:


     
    编译工程

     
    等待编译完成

    注意此时编译出来的是debug、win32版本的freeglut3.0.0文件——需要release版本,需要在Release下,再次编译一下即可(不过,原来的32位文件就被覆盖掉了):
     
    注意此时工程环境:Release & Win32

    编译完成后,再次打开工程所在文件夹(即CMake输出文件夹);此时已经编译好了的freeglut文件就存放在lib、bin文件夹里面:
     
    此时编译好了的freeglut文件就存放在lib、bin文件夹里面

    如果需要64位lib文件和dll文件,只需重新使用CMake 编译生成,只不过选择编译器时选择Win64而已:

     
    CMake生成Win64 VS工程文件

     
    Debug & 64位下编译工程

     
    Release & 64位下编译工程

    至此,准备工作完成,各种文件皆已准备妥当:

     
    glew、freeglut所需的文件。注意笔者并没有将它们的lib、dll、.h文件摘出来存放在一个单独的文件夹中,但后面你知道了必需哪些文件之后,就可以这么做了。

    以下内容未包含CMake生成的64位工程文件;笔者生成的64位的freeglut VS工程文件夹为:freeglut 2

     
    存放64位 freegult 的 lib 文件和 dll 所在的文件夹

    它编译出来的64 freegult 的 lib文件和 dll 文件在 下一篇中才会使用到

    搭建OpenGL开发环境

    创建一个C++控制台工程,然后先运行或编译下程序:


     
    创建一个C++控制台工程,名称随意取。
     
    笔者选择了默认设置,即包含了预编译头

     
    运行或编译刚刚创建的工程
    配置包含目录、库目录

    配置VS包含目录和库目录时,它们分别都需要设置两个路径——glew的include路径、freeglut的include路径以及glew的lib路径和freeglut的lib路径
    点击项目->属性->VC++目录:


     
    打开项目的属性

     
    找到VC++目录的包含目录和库目录

     
    点击编辑

    注意,这里的包含目录简单是说就是我们需要包含.h文件的文件夹,你也可以在把这些.h直接添加到工程中:


     
    配置包含目录

     
    这是glew的头文件所在目录,你可以打开文件夹去看看都是哪些.h文件。

     
    这是freeglut的头文件所在目录,你可以打开文件夹去看看都是哪些.h文件。

     
    包含目录配置完毕,点击确定
     
    配置库目录

     
    这是freeglut所需要的库文件路径,你可以看看freeglut都需要什么 .lib文件

    注意,freegult的库文件(.lib)文件是你自己用CMake、VS2015最终编译出来的,需要不同版本的 .lib 文件,只需要更改好后,重新编译即可。

    上面已经详细的教给你钓鱼的方法,以后freeglut版本更新后,例如freegult 3.1.0,只需再次CMake、VS2015编译即可。

     
    这是glew所需要的库文件路径,你可以到里面看看glew都需要什么 .lib 文件

     
    库目录配置完毕

    显式包含glew32.lib文件——以添加附加依赖项的方式:
     
    点击编辑
     
    输入glew.lib

     
    依次点击应用、确定,库文件配置完成

    程序运行所必需的 .dll 链接文件:

     
    这是glew的.dll文件所在路径
     
    这是freeglut的.dll文件所在路径,注意存在debug和release版本的 .dll 名称上的差异,你可以自己到 ../bin/Release文件夹里面看看。

    把这两个.dll文件复制到exe同目录下:


     
    把.dll复制到我们的exe执行程序的同目录下

    至此,OpenGL 的开发环境配置完毕。

    注意,本文使用了一种比较麻烦的配置方式,以后遇到其他的第三方库也可以这样配置。

    这种方法比较安全,就算配置错误、复制错文件、误删文件,比较容易恢复,最坏的情景也不过是删除整个工程,重来一遍,而不会对系统造成伤害,在开发过程中埋下未知错误。

    当然有一种一劳永逸的方法来配置OpenGL开发环境,这等到我们测试成功之后再介绍,不过这种方法不太安全,请你在确保你知道你在操作什么的时候再使用在这种一劳永逸的方法。

    测试OpenGL开发环境

    转接下文,测试我们配置好了的开发环境

  • 相关阅读:
    STM32——项目需求之低功耗的停机模式
    sscanf函数——强大的C语言库函数
    二级指针偏移
    RTX基础教程目录
    #pragma pack(push) 和#pragma pack(pop) 以及#pragma pack()
    Write thread-safe servlets [reproduced]
    C++程序员如何转Java
    How to implement equals() and hashCode() methods in Java[reproduced]
    The Java Enum: A Singleton Pattern [reproduced]
    VS Code
  • 原文地址:https://www.cnblogs.com/leoking01/p/11470320.html
Copyright © 2011-2022 走看看