data:image/s3,"s3://crabby-images/13596/13596f46a18bfd3102acfe6c87f0a13db5946dfa" alt=""
---------------- 本文 ---------------
注意:笔者是以 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 <gl\GL.h>
然后右键打开文档、再在相应的选项卡上右键打开文件所在的文件夹,如下所示:
data:image/s3,"s3://crabby-images/52008/52008844bc516ab6c05deff838a5b8d9b984fdac" alt=""
data:image/s3,"s3://crabby-images/5ab1c/5ab1c9256acc173635a4eebb099fcc384b715355" alt=""
data:image/s3,"s3://crabby-images/ca620/ca620085b463cc7d6deb68ad0194d6589b31422a" alt=""
可以看到实例图片中,包含这两个OpenGL的头文件:
GL.h:OpenGL所使用的函数和常量声明。
GLU.h(OpenGL实用库)所使用的函数和常量声明。
不同的系统,这些文件的路径和名字(大小写)很可能是不同的,所以不用纠结这个问题,因为你若是直接引入这个头文件,编译则报错。
data:image/s3,"s3://crabby-images/4a079/4a079167fd246c22cde7204d0810a3f5d3aa0271" alt=""
此时先引入windows头文件即可:
// stdafx.h : 标准系统包含文件的包含文件,
// 或是经常使用但不常更改的
// 特定于项目的包含文件
//
#pragma once
#include "targetver.h"
#include <stdio.h>
#include <tchar.h>
// TODO: 在此处引用程序需要的其他头文件
#include <Windows.h>
#include <gl\GL.h>
#include <gl\GLU.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:
data:image/s3,"s3://crabby-images/400ff/400ff95551e387b49f5735aee6c4c3aaf891a784" alt=""
data:image/s3,"s3://crabby-images/78429/784294c93218e9da411645e4f60f3ea212af4b5d" alt=""
data:image/s3,"s3://crabby-images/53630/53630435ff9f1bc5df73ad7053b1b48d7bcd4197" alt=""
data:image/s3,"s3://crabby-images/ec902/ec9023d69ecbb366c00ae40da220af530d97d985" alt=""
下载FreeGLUT:
data:image/s3,"s3://crabby-images/07238/0723895549f2a0215b056e5859dad5e1555a6ec7" alt=""
data:image/s3,"s3://crabby-images/89c84/89c841403babf0725509302d44641b1a8b7f8641" alt=""
下载GLEW:
data:image/s3,"s3://crabby-images/2ff59/2ff59f32855492759654ee3a999bfdc5e71475b9" alt=""
下载完成
data:image/s3,"s3://crabby-images/98663/98663c8b2b3e31bcf8054cd52485dea58183d1eb" alt=""
data:image/s3,"s3://crabby-images/56277/562779052434eed6a54140d0bc21cbe01dde93a1" alt=""
安装CMake
没什么特别的,一路next下来即可。
data:image/s3,"s3://crabby-images/4df22/4df22a227ac22224bbc8990b9961af0dfda20b47" alt=""
data:image/s3,"s3://crabby-images/fe654/fe6541ad9ec8a134456a254aa2521af9bf3beef0" alt=""
data:image/s3,"s3://crabby-images/90e14/90e14e372aa717941f3b7cdf8aa49c2baa1f4ac3" alt=""
data:image/s3,"s3://crabby-images/1f92c/1f92c2b58231bf241f9953096ec1fab28bc1637f" alt=""
data:image/s3,"s3://crabby-images/a72d1/a72d1a15202be8751e13ae221c35eaa7af25f511" alt=""
data:image/s3,"s3://crabby-images/f6696/f6696f437b349108afbc61e45b50b8977600396b" alt=""
编译FreeGLUT文件
解压freeglut-3.0.0.tar,并创建CMake编译文件输出文件夹:
data:image/s3,"s3://crabby-images/32953/329534ee20eaa3741e72000a5b51749ee8347af2" alt=""
打开CMake(cmake-gui), 如下图二者之一:
data:image/s3,"s3://crabby-images/f2d01/f2d014395ed49620765897cd094b765bbf302e48" alt=""
data:image/s3,"s3://crabby-images/52ac9/52ac94ab62e8d11bdbfe36e321de799a6615d18f" alt=""
在 where is the source code 中选择解压freeglut的目录,注意这个目录内包含了CMakeLists.txt。
在where to build the binaries 中选择之前创建的CMake编译文件输出文件夹:
data:image/s3,"s3://crabby-images/a10d9/a10d97f88e297986fefb4da5da55aa0ad2ede4ed" alt=""
data:image/s3,"s3://crabby-images/13cbe/13cbe79e2c0758a5881bd15153c7433b0dad3cfb" alt=""
点击Configure:
data:image/s3,"s3://crabby-images/c8b43/c8b43e9c9b601e15151a3209cb5757be9b051aa9" alt=""
data:image/s3,"s3://crabby-images/45451/45451904b3303c13e35b7a2feeac907889721b68" alt=""
data:image/s3,"s3://crabby-images/0fed0/0fed0c84b43364b293aa5e2aa6c394780e72bf43" alt=""
注意,如果出现错误提示,则先点击File->Delete Cache之后,再点击Configure,然后选择不同的VS版本重试(前提是你的电脑确实安装了该版本的VS):
data:image/s3,"s3://crabby-images/86ff8/86ff85b4f3c6b3cdceb71afbb88c5233ac7e0eb9" alt=""
data:image/s3,"s3://crabby-images/89d5a/89d5a9bd861f1eb59cbd3b19f4c1277fc0caa36b" alt=""
Configur完成之后(注意勾选下图列出的项,特别是FREEGLUT_BUILD_SHARED_LIBS 和FREEGLUT_BULID_STATIC_LIBS),点击Generate生成VS工程文件:
data:image/s3,"s3://crabby-images/c31c3/c31c3000cb49870e898433b23a92e7421bbd8f39" alt=""
data:image/s3,"s3://crabby-images/6c755/6c755211e237500348238e768d369eebccffefb5" alt=""
打开CMake输出文件目录,找到freeglut.sln文件,双击打开:
data:image/s3,"s3://crabby-images/62e88/62e88e71cdeb21beaa198826ef05ea0743078625" alt=""
data:image/s3,"s3://crabby-images/798c5/798c59a5e6ff8e0fa2a789ec6dfeebe53ce3b9b4" alt=""
data:image/s3,"s3://crabby-images/d7d16/d7d160a5a89a9f7a501c07a091df25ffda9dee8e" alt=""
data:image/s3,"s3://crabby-images/cdab9/cdab93c2c4905ed2e96ac6c04fbc18d7c11ff9d3" alt=""
点击生成->生成解决方法:
data:image/s3,"s3://crabby-images/ccb73/ccb7381239252da699101ff28bddffbd45cb493f" alt=""
data:image/s3,"s3://crabby-images/a703d/a703d2505580194b86f514df0742380149d41a0b" alt=""
注意此时编译出来的是debug、win32版本的freeglut3.0.0文件——需要release版本,需要在Release下,再次编译一下即可(不过,原来的32位文件就被覆盖掉了):
data:image/s3,"s3://crabby-images/c5d08/c5d08d9c807b838fbcd9ee98ccba3972426352b3" alt=""
编译完成后,再次打开工程所在文件夹(即CMake输出文件夹);此时已经编译好了的freeglut文件就存放在lib、bin文件夹里面:
data:image/s3,"s3://crabby-images/afea3/afea3f304d8fa24da56a95b54c2aa27b2fd2bd65" alt=""
如果需要64位lib文件和dll文件,只需重新使用CMake 编译生成,只不过选择编译器时选择Win64而已:
data:image/s3,"s3://crabby-images/3c6c8/3c6c808339375da1e5fab7c715962413e077f9cd" alt=""
data:image/s3,"s3://crabby-images/fa20b/fa20b811a3efc4feb7e13ef6e2ea759141a8ef86" alt=""
data:image/s3,"s3://crabby-images/f9203/f9203f82bb6879fe4396cbbf81d91575b6e20789" alt=""
至此,准备工作完成,各种文件皆已准备妥当:
data:image/s3,"s3://crabby-images/3c286/3c286a5fc65a9d96648b60e516251866db3702ea" alt=""
以下内容未包含CMake生成的64位工程文件;笔者生成的64位的freeglut VS工程文件夹为:freeglut 2
data:image/s3,"s3://crabby-images/6bc14/6bc14b257a83182b45298b85ccdef11d40c7ee5d" alt=""
它编译出来的64 freegult 的 lib文件和 dll 文件在 下一篇中才会使用到。
搭建OpenGL开发环境
创建一个C++控制台工程,然后先运行或编译下程序:
data:image/s3,"s3://crabby-images/8a2a1/8a2a13654b601855b7a47187ae88616ca8030656" alt=""
data:image/s3,"s3://crabby-images/714ea/714eaf8ba1b7f877f0841d9dfe570a49fdba3bef" alt=""
data:image/s3,"s3://crabby-images/1e14d/1e14ddd1fc46241714c9911565169400f440fd9c" alt=""
配置包含目录、库目录
配置VS包含目录和库目录时,它们分别都需要设置两个路径——glew的include路径、freeglut的include路径以及glew的lib路径和freeglut的lib路径
点击项目->属性->VC++目录:
data:image/s3,"s3://crabby-images/fc161/fc16105a8331c668afbf2e5e5fa41802d7c4a29d" alt=""
data:image/s3,"s3://crabby-images/e74a0/e74a0b3156a530bbc90266fa8b8621e9742b022f" alt=""
data:image/s3,"s3://crabby-images/371d9/371d94a5ca7471b48152152ab4f9a0a83ec2c750" alt=""
注意,这里的包含目录简单是说就是我们需要包含.h文件的文件夹,你也可以在把这些.h直接添加到工程中:
data:image/s3,"s3://crabby-images/60177/601773c4a469162509beaa1de1f76ee8d5fcc8b0" alt=""
data:image/s3,"s3://crabby-images/23fce/23fce490656399caf14416c84fcf182510756af0" alt=""
data:image/s3,"s3://crabby-images/a2dd5/a2dd525812458a202daa668112875cd590128005" alt=""
data:image/s3,"s3://crabby-images/1356a/1356a81b03bfb9665a73d60e07ed2443cdbce01d" alt=""
data:image/s3,"s3://crabby-images/6729b/6729b4a6626e10952d72a74f5548ba10b84402f9" alt=""
data:image/s3,"s3://crabby-images/5f4c4/5f4c40005f2d7ba38f775a1acb72ca2f1a1ab066" alt=""
注意,freegult的库文件(.lib)文件是你自己用CMake、VS2015最终编译出来的,需要不同版本的 .lib 文件,只需要更改好后,重新编译即可。
上面已经详细的教给你钓鱼的方法,以后freeglut版本更新后,例如freegult 3.1.0,只需再次CMake、VS2015编译即可。
data:image/s3,"s3://crabby-images/f3d2b/f3d2b6c959e270ab9d73f61edf8894a8a7b998af" alt=""
data:image/s3,"s3://crabby-images/37b33/37b33cdfa7a4e3d47b80c04ebbed782fc18a64ac" alt=""
显式包含glew32.lib文件——以添加附加依赖项的方式:
data:image/s3,"s3://crabby-images/ec942/ec9421fbe93662424335d516d3f7fe3573431b89" alt=""
data:image/s3,"s3://crabby-images/baa3a/baa3a54d9fae49989f59b19afe204dd7e7bc0dc8" alt=""
data:image/s3,"s3://crabby-images/da5fc/da5fc3301f009fbc03ea5613754b7293d1aea9e6" alt=""
程序运行所必需的 .dll 链接文件:
data:image/s3,"s3://crabby-images/2ebe1/2ebe14e7fdc62984cc2dec34e801c083f4f37d96" alt=""
data:image/s3,"s3://crabby-images/4feb0/4feb0dda9fd7ee60d13dda971b36ff48c8eedd7b" alt=""
把这两个.dll文件复制到exe同目录下:
data:image/s3,"s3://crabby-images/669d5/669d58ce5fb911ae609d33da50622faf9c33596e" alt=""
至此,OpenGL 的开发环境配置完毕。
注意,本文使用了一种比较麻烦的配置方式,以后遇到其他的第三方库也可以这样配置。
这种方法比较安全,就算配置错误、复制错文件、误删文件,比较容易恢复,最坏的情景也不过是删除整个工程,重来一遍,而不会对系统造成伤害,在开发过程中埋下未知错误。
当然有一种一劳永逸的方法来配置OpenGL开发环境,这等到我们测试成功之后再介绍,不过这种方法不太安全,请你在确保你知道你在操作什么的时候再使用在这种一劳永逸的方法。
网友评论