发表于2024-11-05
Irrlicht(鬼火)引擎是一款用C++编写的高性能3D引擎,是经典的3D游戏引擎之一,可以应用于在C++程序中开发3D游戏。本书以实例的形式向读者展示Irrlicht的编程精髓,融入了3D游戏设计的理论基础、技巧等方面的知识。
本书内容共分为15章,包括Irrlicht概述与游戏引擎安装,编写一个Irrlicht程序,Irrlicht图形学基础,网格、纹理、覆盖层,场景管理,摄像机,地形、纹理和渲染,光照与材质,声音,粒子系统,碰撞检测,数据和文件的处理,着色器,游戏人工智能,部署Irrlicht程序等。
本书适合C++游戏编程初学者和具有一定编程经验的C++游戏编程人员,也可作为高等院校和培训学校游戏软件开发课程的教学参考书。
许志闻,吉林大学计算机科学与技术学院教授、博士生导师,中国计算机学会多媒体专业委员会委员,中国图形、图像学会多媒体专业委员会委员。2006年,美国佐治亚大学高级访问学者。主要研究方向为计算机图形学、动画与游戏、虚拟现实、图像处理、网络多媒体和生物信息学等。
第1章 Irrlicht游戏引擎 1
1.1 Irrlicht使用许可与系统要求 1
1.2 获得Irrlicht引擎 2
1.3 在Windows下设置编译器 4
1.3.1 设置编译器的原理 4
1.3.2 设置动态链接库的方法 5
1.3.3 其他设置方法 10
1.3.4 环境变量的设置方法 11
1.3.5 设置过程中常见的问题 12
1.4 重新编译Irrlicht引擎 13
1.5 测试是否已经正确设置 15
1.6 在Linux环境中使用鬼火游戏引擎 16
1.6.1 在Linux下编译静态库 16
1.6.2 编译Hello World程序并运行 17
1.6.3 在Linux下创建第一个项目 18
1.6.4 第三方编程工具Code::Blocks 19
第2章 编写第一个Irrlicht程序 20
2.1 Irrlicht引擎的结构 20
2.1.1 引入命名空间 20
2.1.2 了解Irrlicht引擎的结构 21
2.2 分析简单的代码 21
2.3 简单的扩展 24
2.4 类的形式 26
2.5 让窗口显示内容 28
2.6 比较成型的模式 29
2.7 让我们的程序发生变化 30
第3章 图形学基础 33
3.1 计算机显示原理 33
3.1.1 图形系统的硬件 33
3.1.2 光栅扫描系统 34
3.1.3 计算机图形标准 35
3.2 图形学的数学基础 36
3.2.1 向量及向量运算 36
3.2.2 坐标 36
3.2.3 基本几何变换 38
3.2.4 三维空间的变换 40
3.3 双缓存和垂直同步 42
3.4 纹理 43
3.5 Z缓冲 45
3.6 摄像机 46
3.7 粒子系统 47
第4章 网格、纹理、覆盖层 50
4.1 网格简介 50
4.2 不同格式网格模型的区别 52
4.3 初识纹理 54
4.4 动态网格模型 56
4.5 覆盖层 59
4.6 使用精灵表 63
4.7 绘制基本图形 67
第5章 场景管理 69
5.1 场景节点和实体 69
5.1.1 场景节点 69
5.1.2 实体 71
5.2 场景节点类型 72
5.3 场景管理器 74
5.4 动态节点 74
5.5 场景的应用示例 77
5.5.1 场景节点的应用 77
5.2.2 动态节点的应用 81
5.5.3 自定义场景节点 83
第6章 摄像机 87
6.1 摄像机投影 87
6.1.1 正交投影 88
6.1.2 透视投影 89
6.1.3 两种投影在代码上的实现 90
6.2 裁剪 92
6.3 摄像机观看视角的类型 95
6.3.1 普通摄像机 95
6.3.2 第一人称射击摄像机 95
6.3.3 Maya摄像机 96
6.4 FPS摄像机的使用示例 96
第7章 地形、纹理和渲染 99
7.1 地形场景节点类 99
7.2 高度图 101
7.3 纹理 102
7.3.1 纹理简介 102
7.3.2 使用纹理 103
7.4 渲染示例 106
7.4.1 渲染地形 106
7.4.2 纹理渲染 111
7.5 创建地形 114
第8章 光照与材质 119
8.1 光照模型 119
8.2 光源 119
8.3 深入光源 120
8.3.1 模拟环境光 121
8.3.2 模拟漫射光 123
8.3.3 灯光的衰减 123
8.4 光源 124
8.4.1 光源的类型 124
8.4.2 光源属性 125
8.4.3 添加灯光 126
8.5 一些简单的光照示例 127
8.5.1 用代码实现环境光 127
8.5.2 用代码实现漫射光 129
8.5.3 用代码实现镜面反射光 132
8.6 材质 135
8.7 阴影 136
8.8 着色 137
8.8.1 着色模式 137
8.8.2 设置着色模式 138
8.9 示例 138
8.9.1 光照和材质示例 138
8.9.2 显示实时动态阴影 140
第9章 声 音 144
9.1 声音基础 144
9.1.1 声音的生成 144
9.1.2 声音的编码存储 145
9.1.3 声音的合成 146
9.2 irrKlang简介 146
9.3 irrKlang的使用 147
9.3.1 实践 Hello World 147
9.3.2 播放3D声音文件 151
9.3.3 声音特效 154
第10章 粒子系统 157
10.1 粒子系统简介 157
10.2 粒子编辑器——irrEdit 158
10.2.1 添加自己的粒子系统 158
10.2.2 设置粒子系统 159
10.3 粒子系统各部分的代码实现 160
10.3.1 粒子结构 160
10.3.2 发射器 161
10.3.3 影响器 163
10.4 绘制一个粒子系统 164
10.4.1 编写代码完成一个简单的粒子系统 164
10.4.2 使用代码制作水面 169
10.4.3 环形粒子系统 173
第11章 碰撞检测 177
11.1 碰撞检测概述 177
11.2 几何和数学知识 178
11.2.1 多边形和多面体 178
11.2.2 BSP树 179
11.2.3 空间四叉树和空间八叉树 179
11.2.4 Minkowski和与Minkowski差 180
11.2.5 包围体 181
11.3 常用的碰撞检测算法 183
11.3.1 距离跟踪法 183
11.3.2 基于图像空间的碰撞检测法 183
11.3.3 空间分解法 184
11.3.4 层次包围盒法 185
11.4 代码解析 185
第12章 数据和文件的处理 192
12.1 Irrlicht文件系统简介 192
12.2 文件的读取和写入 194
12.2.1 写文件 194
12.2.2 普通文件的读写 195
12.2.3 一行一行读取和按分隔符读取 198
12.2.4 XML文件的读写 200
12.2.5 从XML文件中加载数据 201
12.2.6 向XML文件写入数据 204
12.2.7 从XML文件中读取特殊数据类型的数据 205
12.3 从档案中读取数据 207
第13章 着色器 210
13.1 图形渲染管线简介 210
13.2 着色器简介 211
13.2.1 顶点着色器 211
13.2.2 片断(像素)着色器 211
13.2.3 几何着色器 212
13.3 使用着色器 212
13.3.1 安装并使用GLSL demo 212
13.3.2 在Irrlicht引擎中使用着色器 214
13.4 进一步了解着色器 223
第14章 游戏人工智能 224
14.1 什么是智能 224
14.2 什么是游戏AI 225
14.3 AI的组成与设计 226
14.3.1 抉择与推理 226
14.3.2 解决方案的类型 226
14.3.3 智能体的反应能力 226
14.3.4 系统的真实性 226
14.3.5 游戏类型 227
14.3.6 游戏内容 227
14.3.7 游戏平台 227
14.4 AI的输入处理和感知 228
14.4.1 感知系统 228
14.4.2 更新规则 229
14.4.3 反应时间 229
14.4.4 门限 229
14.4.5 负荷平衡 229
14.4.6 计算代价与预处理 229
14.5 OpenSteer 230
第15章 部署一个Irrlicht应用程序 232
15.1 什么是部署 232
15.2 针对不同平台打包发布应用 232
15.2.1 在Windows平台下部署Irrlicht应用程序 232
15.2.2 在Linux平台下部署Irrlicht应用程序 233
15.2.3 在Mac OS X平台下部署Irrlicht应用程序 234
15.3 部署源代码 236
15.3.1 为什么要部署源代码 236
15.3.2 如何部署 236
第14章
?游戏人工智能?
游戏AI(ArtificialIntelligence,人工智能)是近来讨论较多的主题。随着游戏中画质与音效的稳步提高和改善,游戏控制玩家(gamecontrolledplayers)不用“聪明的”方式进行操作,这种情况变得越来越明显。游戏AI是编程人员为了给用户提供某种挑战或某种真实体验而设计出来的。在游戏中,站在一处从不移动的警卫显得非常不真实。如果你创建一个程序,使他不时朝四周张望或变换姿势,就会看起来更具活力,而且更加真实。通过创建一个在预设路径上行走的警卫,偶然还能够停下来与正在站岗的警卫谈话的情景,可以使玩家感觉到游戏的真实感有很大提高。
编写游AI是一个十分复杂的工程,里面包含的知识可以编撰成一本书了,但是AI是我们不可回避的问题,所以本章将为大家讲解AI的含义及相关概念,最后还会向大家推荐一些在Irrlicht中常使用的协助编写AI的类库。
学习目标
?了解游戏AI的想关概念
14.1什么是智能
AI是一门相对年轻的学科,其早期的一些研究工作完成于19世纪50年代初期。受早期游戏机计算能力和存储空间的限制,游戏采用真正AI技术的历史很短。由于AI在游戏中是一个崭新的概念,因此游戏AI的定义对于大多数人,甚至从事游戏开发的人来说都还很模糊。
在介绍游戏AI之前,我们应该先了解一下智能的概念。“智能”这个术语相当模糊,它是指“获取和应用知识的能力”,从字面上解释,该定义可能意味着自动调温器也是智能的。因为自动调温器可以获取房间太冷这个知识,从而应用它所学到的知识调节加热器。事实上,智能的“真正”定义已经是一个古老的争论了,而设计一个好的游戏并不需要这个定义。基于我们自己的目的,一个智能的游戏智能体是能够获取关于这个世界的知识,并对该知识做出反应的智能体。做出反应的质量和效果就是游戏需要权衡和设计的问题。
14.2什么是游戏AI
在AI的经典著作《ArtificalIntelligence:AModernApproach》(人工智能:一种现代方法)中,Russel和Norving指出,AI就是设计计算机程序可以像人一样行动和思考,同时是理性地行动和思考。这个定义包含智能的认知学和行为学的观点,并涵盖理性和“人性”。
简单地说,游戏AI就是游戏中的代码,使得在给定情形下,当游戏有多种选择时,计算机控制的竞争对手(或合作伙伴)采取看起来聪明的决策,从而产生相关、有用的行为。注意上述叙述中“看起来”这个词。游戏中由AI产生的行为是“结果”导向的,因此可以认为游戏界主要关注AI中的行为主义学派。的确,我们仅仅对系统将要做出的响应感兴趣,而不太关心系统是如何做出这个响应的。我们关心系统如何行动,而不关心如何思考。人们在玩游戏时并不会在意这个游戏是否运用庞大的决策脚本数据库,也不会在意是否对决策树进行直接搜索,或者是否建立所处环境的精确知识库,是否基于逻辑规则进行推理决策。正如这些AI所说,推理过程全由游戏AI实现。因此,纯粹的行为决策,如对手发动了哪项攻击、他是如何接近玩家的、他如何在环境中使用各种要素以及其他游戏细节,全部是由游戏AI系统完成的。
现代游戏发展过程中也使用AI这个术语描述其他游戏行为,比如人类输入接口的工作方式。有时甚至支配运动和碰撞的算法(如果游戏运动通过动画驱动而非物理模拟)也属于这一类。可见,AI是游开发界中一个被广泛使用的名词。当与其他同行讨论AI时,大家必须一致认同这个术语的内涵和范围。这点非常重要,否则一个人关于AI的观念与其他人的观念相差太远,就容易产生误解。本章涉及AI时,将使用非常狭窄的定义,即“基于角色的行为智能”。其中的术语“角色”源于大多数游戏的角色驱动本质。
以前,AI编程普遍被称为“游戏玩法编程”,因为CPU控制的角色所展现出来的行为的确不含任何智能成分。在视频游戏早期,大多数程序员都为他们游戏中的人物使用一些模式或重复运动。在某种程度上,玩这些游戏时都要找到预先确定的行为模式,以便能够轻易击倒对手并继续前往另一个地点。这是由早期处理器速度和存储空间的极端限制所决定的。模式很容易存储,只需要最少的代码来驱动,并且几乎不需要进行计算;无论在顶层表现什么行为,它都简单地使人物按规则模式运动。事实上,一些游戏采用所谓随机的运动,但由于早期游戏中的随机数产生器使用伪随机数的硬编码表,因此这些模式能够在整个游戏行为中最终预见。
过去,为了让游戏看起来更加智能,经常使用另一种技术,即让计算机对手作弊,也就是让其拥有人类玩家所不拥有的关于该游戏的额外信息,从而使下一步所做的决策看起来非常巧妙。计算机读入玩家所按的按钮后,以一个阻碍的走步作为系统的响应。一个实时策略作弊器可以使使用者在游戏早期还没有找到有价值资源的区域时便前往这些地点。当游戏赋予计算机对手额外的能力、资源以及一些可直接使用的东西,而不是依靠自己提前规划和了解对这些资源的需要,就可以实现AI的作弊。这些策略能够带来更具挑战性,但是最终还是不能让人满意的对手。
14.3AI的组成与设计
几乎所有AI引擎都将以某种形式使用决策与推理、感知、导航等基本系统。
14.3.1抉择与推理
决策系统是AI引擎中使用最广泛的部分,是决定用户构建的AI引擎类型的底层结构。推理可定义为从实际知识或假定为真的前提中获取逻辑或合理结论的行为。用游戏术语来说,意味着AI控制的对手获取关于世界的信息并响应智能、合理的决策。因此,AI系统受获取的外界信息限制,也受游戏设计时定义的响应集丰富程度的限制。游戏允许AI角色做的事情越来越多,游戏的响应集或状态空间就越来越大。用户选择的技术应该由用户要构建的游戏规模和状态空间的大小决定。
所有决策系统都可归结于这个定义:利用可得到的输入获取解决方案。这些技术之间的差别将决定用户选择使用的类型。我们关注的主要区别有:解决方案的类型、智能体的反应能力、系统的真实性、游戏类型、游戏内容、游戏平台等。
14.3.2解决方案的类型
游戏解决方案的主要类型有两种:战略型和战术型。战略型解决方案通常针对长期、高层次并需要多个行动共同完成的目标。而战术型解决方案更多针对短期、低层次并只包含一个物理动作和技巧的目标。两者的区别在于游戏中关注整体行动还是个体行动。许多游戏同时需要战略型和战术型两种解决方案,因此开发人员根据这种划分将问题分离成几个独立的部分,并结合不同的结束实现。
14.3.3智能体的反应能力
游戏元素应该如何反应?脚本化系统趋向于设计具有更多程式化和语境响应的角色,但它们容易受困于这些行动脚本,从而失去反应。与此相反,完全反应式系统容易被认为过于机械或作弊,并且不符合人类的感情。强响应系统需要一个非常丰富的响应集,否则它们表现的行为将是可预测和无新意的。然而这对街机式游戏或所谓的twitch游戏非常合适,需要在所设计的游戏类型和对所期望设计的玩法经验正确权衡的基础上进行阐述。
14.3.4系统的真实性
要被认为是“真实的”,AI元素做出的决策和行动必须类似于人类。在游戏的限制条件下,每个AI实体都需要智能决定所要做的正确的事情,但类似于人类也意味着会犯错误。因此,AI角色也需要很好地体现人类的弱点。化解玩家所有拳击或射击永远不会落空的对手和Scrabble游戏中对整个字典了如指掌的对手都不会让玩家高兴,反而会让他们感到沮丧,我们的目标是在竞赛和娱乐之间找到平衡,从而使玩家被游戏的挑战性所吸引,同时通过击败游戏形成一个持续的积极反馈。真实性问题还包括对游戏使用物理定律的实际认同数量。玩家能跳得比实际生活中更高吗?他能飞吗?是否能很快痊愈?这些都得由开发人员决定,意味着“真实性”可定义为“特定游戏世界中的真实性”。在幻想世界中尤其要小心,因为肆意破坏规则的敌人将被认为是在作弊而不是具有魔法,必须采取措施以确保玩家了解并遵守游戏世界中的规则。还要记住,大多数玩家都知道地球物理定律,但在他们设法习惯开发人员设定的规则时,这些特殊定律最初很有可能成为他们的绊脚石。
14.3.5游戏类型
不同类型的游戏需要不同类型的AI系统。在游戏层面上,必须记住以下几项:
(1)输入(或感知)类型。要注意的事项包括输入的数量、频率、信息传递方式(轮询、事件、回调函数等)以及输入之间的层次关系。街机式游戏只有非常有限的输入,而实时策略游戏中的角色可能需要非常多关于世界的感知,以便导航地形、保持编队、帮助友好单元、接收人类发出的命令并对攻击的敌人做出响应。
(2)输出(或决策)类型。根据感知,系统赋予引擎决策部分信息,AI系统将做出一个决策或产生一个输出。输出可以是模拟的、数字的或在周边行为上的一连串事件,可以包含整个角色(如潜水以寻求掩护)、部分角色(如扭头以响应噪声)或多个角色(如让市民们挖更多石头)。输出可以是具体的,也可以是高层的,其中后者将影响许多AI角色的行为,并改变许多决策的进程。
(3)游戏类型需要的决策整体结构。有的游戏具有非常简单或单一性的决策,Robotron游戏就是一个例子。怪物以一定的速度和运动类型向玩家靠近,并试图杀死玩家。在复杂的游戏中(如《帝国时代》),需要在游戏中进行许多不同类型的决策,可以使用小组级策略、单元战术、一系列路径搜索问题以及其他更深奥的问题,如外交手段等。其中每一个问题都可能代表AI中的一个子系统,而且这 Irrlicht 3D游戏引擎程序设计 下载 mobi epub pdf txt 电子书 格式
Irrlicht 3D游戏引擎程序设计 下载 mobi pdf epub txt 电子书 格式 2024
Irrlicht 3D游戏引擎程序设计 下载 mobi epub pdf 电子书Irrlicht 3D游戏引擎程序设计 mobi epub pdf txt 电子书 格式下载 2024