《游戏编程精粹 6》PDF下载

  • 购买积分:16 如何计算积分?
  • 作  者:(美)迪克黑森尔(Dickheiser,M.)编;孟宪武等译
  • 出 版 社:北京:人民邮电出版社
  • 出版年份:2007
  • ISBN:7115167265
  • 页数:508 页
图书介绍:游戏开发精粹系列书目前在国内已出版前5卷,对国内游戏研发产生了深刻的影响。《游戏编程精粹系列6》是游戏编程精粹系列图书最新版本,内容增添了游戏测试、手机游戏和脚本管理部分,具有时效性较强。除了各种专业文章外,丛书中随书附带光盘中包含了全书所有的源程序、演示程序及需要的各种游戏开发的第三方工具。

第1章 通用编程 2

简介&Adam Lake  2

1.1 Lock-Free算法&Toby Jones 4

1.1.1 Compare-And-Swap及其他通用原语 4

1.1.2 Lock-Free参数化的堆栈 6

1.1.3 Lock-Free参数化的队列 9

1.1.4 Lock-Free参数化的Freelist 11

1.1.5 总结 13

1.1.6 参考文献 13

1.1.7 相关资源 14

1.2 通过OpenMP来充分利用多核处理器的能力&Pete Isensee  15

1.2.1 OpenMP应用实例:粒子系统 15

1.2.2 好处 16

1.2.3 性能 16

1.2.4 OpenMP应用实例:碰撞检测 17

1.2.5 线程组 18

1.2.6 函数的并行化 18

1.2.7 缺陷 19

1.2.8 结论 20

1.2.9 参考文献 21

1.2.10 相关资源 21

1.3 用OpenCV库实现游戏中的计算机视觉&Arnau Ramisa、Enric Vergara、Enric Marti  22

1.3.1 引子 22

1.3.2 游戏中的计算机视觉 22

1.3.3 开放的计算机视觉库 22

1.3.4 计算机视觉在游戏中一个简单的应用 23

1.3.5 未来的工作 31

1.3.6 参考文献 31

1.4 游戏对象的地理网格注册&Roger Smith  33

1.4.1 引子 33

1.4.2 四叉树和八叉树 34

1.4.3 游戏对象的组织形式 35

1.4.4 总结 39

1.4.5 参考文献 39

1.5 BSP技术&Octavian Marius Chincisan  40

1.5.1 什么是BSP?为什么要使用BSP? 40

1.5.2 基于节点的BSP 41

1.5.3 渲染一个基于节点的BSP树 43

1.5.4 基于节点的BSP树(不进行分割) 43

1.5.5 凸状叶子BSP树 44

1.5.6 凸状叶子BSP树出入口生成 47

1.5.7 凸状叶子BSP树潜在可视集 48

1.5.8 PVS压缩 51

1.5.9 地形BSP 53

1.5.10 总结 53

1.5.11 参考文献 54

1.6 最相似字串匹配算法&James Boer  55

1.6.1 基于字符串的ID查找难题 55

1.6.2 问题的定义 56

1.6.3 现有的一些解决方案 56

1.6.4 我们自己定制的字串匹配解决方案 56

1.6.5 解决方案的实际应用 62

1.6.6 总结 63

1.6.7 参考文献 63

1.7 利用CppUnit实现单元测试&Blake Madden  64

1.7.1 单元测试技术概览 64

1.7.2 CppUnit概述 65

1.7.3 运行测试夹具 67

1.7.4 利用CppUnit进行模型类测试 68

1.7.5 私有函数的单元测试 74

1.7.6 用CppUnit测试底层功能 75

1.7.7 总结 79

1.7.8 参考文献 80

1.8 为游戏的预发布版本添加数字指纹,威慑并侦测盗版行为&Steve Rabin  81

1.8.1 威慑策略 81

1.8.2 利用水印和指纹来进行侦测 82

1.8.3 添加数字指纹的流程 83

1.8.4 数字指纹添加过程的安全性 83

1.8.5 数字指纹的添加策略 83

1.8.6 破解数字指纹 85

1.8.7 总结 86

1.8.8 参考文献 86

1.9 通过基于访问顺序的二次文件排序,实现更快速的文件加载&David Koenig  87

1.9.1 问题的提出 87

1.9.2 解决方案 88

1.9.3 基于访问的二次文件排序的工作流程 89

1.9.4 优化效果 90

1.9.5 影响最终优化结果的因素 90

1.9.6 潜在的问题 91

1.9.7 其他一些通用的最佳实践方法 91

1.9.8 总结 92

1.9.9 参考文献 92

1.10 你不必退出游戏:资产热加载技术可以实现快速的反复调整&Charles Nicholson  93

1.10.1 资产热加载的工作流程 93

1.10.2 资产热加载过程的剖析 94

1.10.3 实际应用中需要考虑的事项 97

1.10.4 示范程序 98

1.10.5 总结 99

1.10.6 进阶参阅 99

第2章 数学与物理 102

简介&Jim Van Verth  102

2.1 浮点编程技巧&Chris Lomont  104

2.1.1 浮点数的格式 105

2.1.2 例程的设计 108

2.1.3 总结 117

2.1.4 参考文献 118

2.2 利用齐次坐标实现投影空间中的GPU计算&Vaclav Skala  119

2.2.1 相关的数学背景知识 119

2.2.2 利用齐次坐标进行计算 121

2.2.3 直线交叉 124

2.2.4 总结 125

2.2.5 附录A 125

2.2.6 附录B 126

2.2.7 致谢 127

2.2.8 参考文献 127

2.3 利用叉乘积求解线性方程组&Anders Hast  128

2.3.1 简介 128

2.3.2 隐式直线 130

2.3.3 高效的扫描转换的设置运算 132

2.3.4 求解三元一次方程组 134

2.3.5 总结 135

2.3.6 致谢 135

2.3.7 参考文献 135

2.4 适用于游戏开发的序列索引技术&Palem GopalaKrishna  137

2.4.1 相关术语 137

2.4.2 序列 138

2.4.3 范围序列 139

2.4.4 排列序列 142

2.4.5 组合序列 144

2.4.6 总结 147

2.4.7 参考文献 149

2.5 多面体浮力的精确计算&Erin Catto  150

2.5.1 浮力 150

2.5.2 多边形的面积 152

2.5.3 多面体的体积 153

2.5.4 物体部分没入水中的情况 154

2.5.5 算法的鲁棒性 157

2.5.6 阻力 158

2.5.7 关于源代码 159

2.5.8 总结 159

2.5.9 致谢 159

2.5.10 参考文献 159

2.6 带有刚体交互作用的基于粒子的实时流体仿真系统&Takashi Amada  161

2.6.1 流体仿真与平滑粒子的流体动力学 161

2.6.2 扩展SPH方法,以支持流体和刚体的交互作用 165

2.6.3 与动态刚体的交互作用:仿真更新 169

2.6.4 具体的实现细节 170

2.6.5 相关的优化 173

2.6.6 总结 174

2.6.7 参考文献 174

第3章 人工智能 176

引言&Brain Schwab  176

3.1 游戏的制作方法——应用基于模型的决策——在雷神之锤Ⅲ中应用蝗虫人工智能引擎&Armand Prieditis Mukesh Dalal  178

3.1.1 引言 178

3.1.2 目前的游戏人工智能:基于规则 179

3.1.3 规则的问题 180

3.1.4 基于模型的游戏人工智能方法 182

3.1.5 对游戏的接口 182

3.1.6 对游戏人工智能开发者的好处和推论 183

3.1.7 雷神之锤Ⅲ竞技场和蝗虫人工智能引擎 184

3.1.8 相关工作 185

3.1.9 结论和未来的工作 186

3.1.10 参考文献 186

3.2 独立非玩家角色合作行为的实现&Diego Garcés  187

3.2.1 可能的解决方案 187

3.2.2 非玩家角色的结构 189

3.2.3 合作的机制 189

3.2.4 例子:合作寻找玩家 194

3.2.5 结论 195

3.2.6 参考文献 195

3.3 针对游戏的基于行为的机器人架构&HugoPinto、Luis Otavio Alvares  196

3.3.1 包容体结构 196

3.3.2 扩展的行为网络 199

3.3.3 讨论 201

3.3.4 结论 201

3.3.5 参考文献 202

3.4 使用模糊感知器、有限状态自动机和扩展的行为网络为虚幻竞技场游戏构建一个目标驱动的机器人&Hugo Pinto、Luis Otavio Alvares  203

3.4.1 扩展的行为网络设计 203

3.4.2 层次模糊感知器 208

3.4.3 有限状态自动机行为模块 210

3.4.4 结论 211

3.4.5 参考文献 212

3.5 一个目标驱动的虚幻竞技场游戏角色程序:使用扩展的行为网络制作目标驱动的具有个性的代理&Hugo Pinto、Luis Otavio Alvares  213

3.5.1 扩展的行为网络 214

3.5.2 行为选择的质量 216

3.5.3 个性设计 218

3.5.4 结论 220

3.5.5 参考文献 221

3.6 用支持向量机为短期记忆建模&Julien Hamaide  223

3.6.1 支持向量机简介 223

3.6.2 短期记忆模型化 226

3.6.3 CPU的消耗限制 227

3.6.4 结论 228

3.6.5 参考文献 228

3.7 使用战力值评估模型进行战争役分析&Michael Ramsey  229

3.7.1 基本公式 229

3.7.2 计算兵力 230

3.7.3 计算潜在兵力 230

3.7.4 为武器效力进行建模 231

3.7.5 获得一个理论上的战争结局 232

3.7.6 关于CEV 232

3.7.7 一个QJM系统的例子 232

3.7.8 局限性 233

3.7.9 结论 234

3.7.10 参考文献 234

3.8 设计一个多层可插拔的AI引擎&Sebastien Schertenleib  235

3.8.1 相关工作 235

3.8.2 AI引擎架构 236

3.8.3 数据驱动类和属性 237

3.8.4 分优先级的任务管理器 240

3.8.5 性能问题和技术 241

3.8.6 工具 243

3.8.7 结论 244

3.8.8 参考文献 245

3.9 一个管理场景复杂度的模糊控制方法&Gabriyel Wong、Jialiang Wang  247

3.9.1 关键思想 247

3.9.2 为什么使用模糊控制? 247

3.9.3 工具 248

3.9.4 系统设计 249

3.9.5 游戏中的应用 251

3.9.6 假设 251

3.9.7 实现考虑 252

3.9.8 测试和结果 252

3.9.9 结论 254

3.9.10 致谢 254

3.9.11 参考文献 254

第4章 脚本和数据驱动系统 256

简介&Graham Rhodes  256

4.1 脚本语言总述&Diego Garcés  258

4.1.1 为什么要使用脚本语言 258

4.1.2 简介 258

4.1.3 语言编码 259

4.1.4 与C++的整合 262

4.1.5 性能特点 267

4.1.6 开发支持特点 269

4.1.7 总结 271

4.1.8 参考文献 271

4.2 把C++对象绑定到Lua&Waldemar Celes、Luiz Henrique de Figueiredo Roberto Ierusalimschy  273

4.2.1 绑定函数 273

4.2.2 绑定宿主对象和Lua数值 276

4.2.3 绑定宿主对象和Lua对象 278

4.2.4 宿主和Lua表绑定 282

4.2.5 总结 283

4.2.6 参考文献 285

4.3 使用LUA协同程序实现高级控制机制&Luiz Henrique de Figueiredo、Waldemar Celes Roberto Ierusalimschy  286

4.3.1 Lua协同程序 286

4.3.2 过滤器 287

4.3.3 迭代器 288

4.3.4 任务安排 291

4.3.5 协作式多线程 291

4.3.6 总结 296

4.3.7 参考文献 296

4.4 在多线程环境里处理高级脚本执行&Sebastien Schertenleib  297

4.4.1 基于组件的软件和脚本的解释程序 297

4.4.2 协同程序与微线程程序 298

4.4.3 微线程管理器 298

4.4.4 嵌入Python 300

4.4.5 试验和结果 304

4.4.6 总结 305

4.4.7 参考文献 305

4.5 使用非插入型代理导出角色属性&Matthew Campbell、Curtiss Murphy  306

4.5.1 角色、代理和属性 306

4.5.2 非插入型和动态体系结构 308

4.5.3 角色属性 308

4.5.4 角色代理 311

4.5.5 从理论到实践 313

4.5.6 总结 314

4.5.7 参考文献 314

4.6 基于组件的游戏对象系统&Chris Stoy  315

4.6.1 游戏对象 315

4.6.2 基本的游戏对象组件 316

4.6.3 在游戏对象中实现组建管理 317

4.6.4 组件间的通信 319

4.6.5 游戏组件模板 320

4.6.6 游戏对象模板 322

4.6.7 数据驱动的游戏对象创建 323

4.6.8 总结 324

第5章 图形学 326

简介&Paul Rowan 326

5.1 交互角色真实的静止动作合成&Arjan Egges,Thomas Di Giacomo和Nadia Magnenat-Thalmann  328

5.1.1 简介 328

5.1.2 人体动画的主分量 329

5.1.3 姿势变换 331

5.1.4 姿势的连续微小变化 334

5.1.5 总结 337

5.1.6 参考文献 337

5.2 用自适应二叉树进行空间剖分&Martin Fleisz  339

5.2.1 如何建立自适应二叉树 339

5.2.2 ABT实现细节 340

5.2.3 找到合适的分割面 343

5.2.4 在动态场景中使用ABT 345

5.2.5 渲染ABT 346

5.2.6 总结 347

5.2.7 致谢 348

5.2.8 参考文献 348

5.3 用有向包围盒增强对象裁减&Ben St.John  349

5.3.1 方法概要 349

5.3.2 传统技术 350

5.3.3 针对二维的有效解决方案 350

5.3.4 传统技术上的改进 352

5.3.5 对包围盒进行筛选 354

5.3.6 进一步改进 355

5.3.7 总结 356

5.3.8 参考文献 356

5.4 皮肤分离的优化渲染&Dominic Filion  357

5.4.1 简介 357

5.4.2 分割的概念 358

5.4.3 权重分割的启发式算法 359

5.4.4 骨骼调色板的启发式算法 359

5.4.5 启发式算法的细节 361

5.4.6 总结 364

5.5 GPU地形渲染&Harald Vistnes  365

5.5.1 算法 365

5.5.2 细节层次 366

5.5.3 避免裂缝 368

5.5.4 视锥体裁减 369

5.5.5 法线计算 369

5.5.6 碰撞检测 370

5.5.7 实现细节 370

5.5.8 运行结果 371

5.5.9 总结 372

5.5.10 参考文献 372

5.6 基于GPU的交互式流体动力学与渲染&Frank Luna  373

5.6.1 数学背景知识 374

5.6.2 GPU实现 376

5.6.3 流体互动 382

5.6.4 补充材料 383

5.6.5 总结 384

5.6.6 参考文献 384

5.7 基于多光源的快速逐像素光照渲染&Frank Puig Placeres  386

5.7.1 延迟解决方案 386

5.7.2 高端硬件的延迟着色实现 387

5.7.3 基本存储优化 389

5.7.4 着色器优化和硬件限制 391

5.7.5 扩展图像空间(Extending Image-Space)的后处理特效(Post-Processing Effects) 394

5.7.6 总结 394

5.7.7 参考文献 394

5.8 路标渲染的清晰化&J?rn Loviscach  395

5.8.1 反走样阈值划分纹理(Antialiasing Thresholded Textures) 396

5.8.2 阈值划分的优化纹理(Optimal Textures for Thresholding) 400

5.8.3 创作程序(The Authoring Application) 403

5.8.4 总结与展望 405

5.8.5 参考文献 405

5.9 天空渲染在游戏中的实际运用&Aurelio Reis  407

5.9.1 所需与所得相悖 407

5.9.2 天空的组成 408

5.9.3 瓶颈 409

5.9.4 立方体天空贴图概要 411

5.9.5 特殊时间 412

5.9.6 演示程序的黎明 413

5.9.7 进入地平线之下 414

5.9.8 总结 414

5.9.9 参考文献 415

5.10 基于OpenGL帧缓冲区对象的高动态范围渲染&Allen Sherrod  416

5.10.1 帧缓冲区对象简介 416

5.10.2 设置帧缓冲区对象 417

5.10.3 基于帧缓冲区对象的高动态范围渲染 419

5.10.4 总结 421

5.10.5 补充材料 421

5.10.6 参考文献 422

第6章 音频 424

简介&Alexander Brandon  424

6.1 由可变形网格(Deformable Meshes)实时生成声音&Marq Singer  426

6.1.1 对《游戏编程精粹4》的回顾 426

6.1.2 概述 427

6.1.3 对模态分析的简要回顾 427

6.1.4 声音要求 429

6.1.5 从变形到声音 429

6.1.6 总结 430

6.1.7 进一步阅读 430

6.1.8 参考文献 431

6.2 实时音效轻量级生成器&Frank Luchs  432

6.2.1 环境声引擎 432

6.2.2 声音合成 432

6.2.3 真实世界范例 434

6.2.4 总结 435

6.2.5 范例 436

6.2.6 参考文献 436

6.3 实时混音总线&James Boer  437

6.3.1 并非不重要的任务 437

6.3.2 实现音量总线链 438

6.3.3 以比率或分贝的形式来表示音量 440

6.3.4 执行效率问题 440

6.3.5 其他增强 441

6.3.6 总结 441

6.3.7 参考文献 441

6.4 可听集(Potentially Audible Sets)&Dominic Filion  442

6.4.1 PVS入门 442

6.4.2 PAS基础 443

6.4.3 直接声音路径 443

6.4.4 为门窗创建动态PAS 447

6.4.5 PAS扩展:传导(transmission) 448

6.4.6 PAS扩展:反射 449

6.4.7 总结 450

6.4.8 参考文献 450

6.5 一种开销较低的多普勒效果&Julien Hamaide  451

6.5.1 多普勒效果 451

6.5.2 编写多普勒效果程序 454

6.5.3 线性插值 454

6.5.4 根据R来计算下标 455

6.5.5 非恒定速度 456

6.5.6 信号对齐(Aliasing) 457

6.5.7 实现 457

6.5.8 总结 457

6.5.9 资源 458

6.6 仿造实时DSP效果&Robert Sparks  459

6.6.1 仿造 459

6.6.2 例子:收音机在房间中播放音乐 459

6.6.3 声音能量恒定曲线(Constant Power Volume Curve) 461

6.6.4 对声道音量进行进一步控制 461

6.6.5 在DirectSound中播放多声道文件 462

6.6.6 代价和好处 462

6.6.7 总结 462

6.6.8 致谢 462

第7章 网络及多人在线 464

简介&Scott Jacobs  464

7.1 3D动画角色数据的动态自适应流&Thomas Di Giacomo、HyungSeok Kim、Stephane Garchery和Nadia Magnenat-Thalmann Chris Joslin  465

7.1.1 简介 465

7.1.2 背景介绍与相关方法 465

7.1.3 处理可缩放3D数据的准备和实施 466

7.1.4 自适应数据的传输 471

7.1.5 总结 473

7.1.6 参考文献 473

7.2 大规模多人在线游戏基于复杂系统的高阶架构&Viknashavaran Narayanasamy、Kok-Wai Wong和Chun Che Fung  475

7.2.1 复杂系统和突发性事件 475

7.2.2 多重架构 476

7.2.3 基于回馈的决策系统 484

7.2.4 总结 485

7.2.5 参考文献 485

7.3 为游戏物件生成全局唯一标识符&Yongha Kim  487

7.3.1 游戏物件GUID建立的需求 487

7.3.2 生成GUID 488

7.3.3 对于特殊情况的处理 489

7.3.4 总结 490

7.3.5 参考文献 490

7.4 利用Second Life为大规模多人在线游戏原形设计游戏概念原形&Peter A.Smith  491

7.4.1 简介 491

7.4.2 为什么要用到Second Life 491

7.4.3 初试“第二人生(Second Life)” 494

7.4.4 在Second Life中的设计要点 495

7.4.5 原形的开发 496

7.4.6 一个成功的例子 498

7.4.7 总结 499

7.4.8 参考文献 499

7.5 稳定的P2P游戏TCP连接及敏感NAT&Larry Shi  501

7.5.1 问题 501

7.5.2 技术水平 502

7.5.3 方法 503

7.5.4 应用方面 507

7.5.5 局限性 507

7.5.6 结论 508

7.5.7 参考文献 508