`
igp92igp
  • 浏览: 16480 次
最近访客 更多访客>>
社区版块
存档分类
最新评论

关于如何学好游戏3D引擎编程的一些经验

 
阅读更多

关于如何学好游戏3D引擎编程的一些经验
2010年09月16日
  本人不才,姑且以自己经验来谈如何学游戏编程,这个话题我酝酿了很久,它确实很难写,因为我也不是资深高手,才刚刚登堂入室,游戏编程大师功力一般都十几年左右,所以让我这样的小卒写深入浅出更何谈容易,错误出现并不奇怪,高手见笑也在所难免,请大家指正,我会欣然笑纳。但这几年走过的路,让我知道这么学是正确的,大体过程经验告诉我,这样做是对的,高手的指引告诉我,这样做是对的。
  这篇文章主要讨论如何学习游戏图形编程和游戏引擎编程,告诉没有接触过游戏编程或者现在关于怎么学好游戏编程还迷惑的人所要走的方向,完全抛开技术和代码实现进行谈论。至于游戏逻辑,这几年的重点没有放到这个上面,很难总结。
  经验的限制,对于如何编写一个好的引擎(至于"好"这个词都是相对而言,能做的满意就是我所期望的),至今为止我还没有这个能力,但我相信经过我的努力,不久的将来,我会实现这个愿望,因为我的一个愿望就是实现一个好的引擎。
  我从下面几个方面来说明如何学习,记住只是如何学习,要想学好就要靠你自己。
  1、你真的喜欢游戏编程吗?
  2、要了解游戏编程
  3、学会读书,自学与思考,交流与合作
  4、游戏编程需要的基础知识
  5、2D游戏编程
  6、3D游戏编程
  7、游戏引擎编程
  8、浅谈游戏物理和AI
  一、游戏编程,你真的爱她吗?
  当你听完我的介绍后,你就要决定游戏编程是否适合你。
  游戏编程可简单可复杂,简单的2D 《蛇吃豆》,复杂的现在流行的3D游戏。咱们不说简单的,因为你不想学习游戏编程就为了做一个简单的游戏。确实每个人对他所向往的东西都想彻底了解清楚,可是我给你的第一个忠告:复杂的3D游戏,复杂到难以想象。 打开话题,游戏是一个结合体,它是一个音乐,美术,技术,创意相结合的艺术品,你要用艺术的眼光去欣赏的,因为好的游戏是用艺术的眼光来设计,除了某国的网游不算外,很多经典的游戏流芳百世,成为真正游戏玩家的佳话。
  中国的游戏为什么这么落后,你要联想下,当年中国为什么会被八国联军所侵略。腐朽的思想是根本原因,从而导致了腐朽的社会制度。游戏行业也是这样,看待游戏的中国人,始终带着眼镜,用腐朽思想看待游戏,所以现在出现腐朽的游戏行业,导致中国游戏发展缓慢,有人曾经说中国游戏不久就赶超日本和美国,我认为是扯淡,而且不是一般的扯淡,具体原因后面我会详细说明。
  从小的时候,国外的电子游戏产品就跑进了我的空间,废寝忘食的玩个没玩,因为耽误学习,从此电子游戏被老师和家长全部封杀,任何事物都有利有弊,鲁迅的《拿来主义》曾说过"去其糟粕,取其精华"。在中国,电子游戏被视为过街老鼠。确实要承认电子游戏有负面影响,但这些负面影响是谁产生的,本质上是我们自己,最后本来是精华的东西从我们身边擦肩而过,从小霸王以后的国外游戏机没有任何仿造,导致了游戏机技术从此断代,现在却又想起来赶超。
  而现在,国人知道努力了,国家看到有钱可赚开始支持了,腐朽的游戏思想却还在蔓延,网络游戏就是这样环境下成长的新生儿,国内网络游戏每年要大批量生产,但存活的基本没几个。不能否定,没有利益的事情没人干,但你还不能否定,有些事情即使没有利益,但还是有人干,哪怕知道自己并不能得到什么。国内的人,很少是第2种人,他们把游戏做为赚钱工具,垃圾游戏隔三差五的纷纷涌出。相比来讲,我只拿日本举例子,虽然小日本和咱们有仇,但我们不得不承认小日本在游戏这方面思想层次完完全全超越我们,他们有严格的游戏教育背景,他们做一款游戏,要按照严格的流程,从设计到编程,以至最后的测试,都有着干一行敬一行的精神,否则《生化危机》这样的游戏你是永远看不到的。
  所以你要改变自己的思想,游戏是一种艺术品,你要有一种艺术境界来去欣赏它。 也许我上面的话,你还能接受,残酷的在下面,以我的经验告诉我,如果你编程和游戏理论起步是零,你要对游戏编程达到略有小成的水平最少要4到5年,我比较蠢,花了6年。这6年来,几乎每天平均学习4-5个小时左右,当然假期都要算上。头3年半基本学习计算机基础知识,包括数学,数据结构,计算机体系结构,人工智能,汇编,编译原理,操作系统,网络,软件工程,离散数学,算法分析。我们大学4年基本就学这东西,这些都是基础,游戏编程都需要,还有一个就是高等物理我没有学,导致我现在对于一些物理微积分方程很难理解,当然这里并不一定是问题,只要你肯努力,没有学不会的。完全把这些学好,花4年时间真的不容易。我曾经抱怨自己没保研而痛苦的经历考研,现在我却认为是值得的,我很难有时间再集中精力的复习这些专业课了,尤其是数学。
  在游戏编程中,上面的基本知识都可以用到,所以我说游戏编程很复杂一点不假。就拿游戏中最难的部分--一个好的游戏引擎来说(这里说的好引擎),世界上能把她做出来的人很少,中国更是寥寥无几。
  上面只是理论基础,要走进游戏编程最基本的。过硬的编程技能更是需要的,其实这些理论学习可以和编程相结合,在编程中学习理论,为了学习理论而增长编程经验。
  有了基础,你才能进一步学习游戏编程,2D游戏和3D游戏理论都要学,这又要花费很长时间,这个是我下面要详细说的。
  看完我写的,你可能心惊胆寒,所以你要爱她,深深的爱她,否则你承受痛苦的时候享受不到暗含的乐趣。 很多人可能不解,游戏编程为什么要从游戏开始,玩游戏时,有很多潜移默化的东西影响着我们编写游戏程序,很多灵感确实从游戏中得来。一般的游戏编程高手,都是从小由于游戏对他们巨大吸引,从而走上游戏道路,虽然不是绝对,但按统计学角度讲可以说是一个事实。一个不爱玩游戏的人,爱上游戏编程的几率是很小的。其实很多人小的时候都爱玩游戏,他们都是从游戏厅长大,只有一少部分,走向了游戏开发这个行业,他们之间有着明显不同,走向游戏开发的人,是真的被游戏背后那种神秘东西所吸引,并想要揭开它,而另一些人,则是完全迎合了游戏开发的需要--玩的高兴。
  我想说的是,一个游戏编程高手,必定是一个游戏玩家,他们都是从玩游戏而爱上游戏,从而走上游戏编程道路。这条路充满了荆棘,不是一般人能走到最后的。所以你一定要爱她!
  当然任何事情都不绝对的,你可能就是那不爱游戏但爱游戏编程(或者和游戏性无关的那部分编程)小概率的人。 二、游戏编程,你真的了解她吗?
  1、广义上,我给的定义是,游戏引擎开发和游戏逻辑开发。
  游戏逻辑开发是集中力量只开发游戏中剧情部分,你只需要做的是什么时候显示什么,什么时候放出什么声音,什么时候通过网络传输什么数据,什么时候这个物体或者人物做什么动作。至于底层怎么显示,声音如何处理,网络如何传输,物体动作怎么实现的,你不用关心,关心这些的是游戏引擎。所以说游戏引擎负责技术方面,而游戏逻辑负责游戏文化内涵。
  成功的游戏是以好的游戏逻辑为基础的,而游戏引擎并不是成功游戏主要条件,但好的游戏配上好的游戏引擎,确实会给人一种震撼,相比同样的游戏逻辑,好的游戏引擎显示效果会给人一种全新视觉和听觉感受。
  至于游戏逻辑我不想过多解释,但并不是说游戏逻辑简单,游戏逻辑也可以复杂的要命,这取决于游戏复杂程度和游戏引擎与这个游戏的关联程度。为了解释这句话,我不得不从游戏引擎解释开始。
  早期的游戏是没有游戏引擎这个概念,都是一个游戏一套代码,随着游戏越来越多,大家发现开发有些游戏中,有很多可重用的代码,逐渐把这些重用代码封装起来,这就是早期的引擎。对于引擎没有明确的概念,只有好坏和适应程度之分,所谓的好坏,就是引擎支持功能和显示特性等是否strong,而适应程度是指一个引擎是否适合开发这个游戏,开发这个游戏是否要自己再编写一些额外的代码。
  我举个例子
  如果我用开发魂斗罗的引擎(假如它有引擎)来开发RPG,和开发RPG游戏的"RPG游戏开发大师"相比,我们还要做很多工作,才能完成玩法功能一样的游戏。
  所以说很难有明确的界限划分这一堆代码是否是游戏引擎,但游戏引擎的任务是不用质疑的,它的任务就是尽量不用负责底层处理,而专心到游戏逻辑上来。 2、从狭义上分,我只分解游戏引擎部分,基本包括(1)游戏图形引擎(2)声音引擎(3)网络引擎(4)脚本引擎(5)GUI(6)人工智能引擎(7)物理引擎。
  (6)(7)两个不是必须的,而前5个是一个好的游戏引擎要基本具备的,其实每个游戏引擎中都具备物理引擎,只不过很多游戏对于物理要求不是很高,所以就集成到了图形引擎中或者游戏逻辑中。
  图形引擎是引擎中最难的,它基本要处理游戏引擎中70-80%的工作量,它的主要任务是负责图形高效显示,包括速度和精度。后面我会集中并详细解释。至于声音和网络引擎大家通过字面就可以知道它干什么。本人对声音处理和网络传输知道甚少,说出来只能误人子弟。
  至于脚本我还略有研究,我想解释下什么是脚本,游戏中为什么用脚本。脚本有时很难给出一个定义,但大家都知道那些是脚本语言,我给出的解释是用软件CPU(虚拟CPU)来运行的编程语言就是脚本语言,软件CPU和所说硬件CPU是对立的,也就是说脚本运行与否先是关联到这个虚拟CPU,在虚拟CPU上运行,然后再又映射到真正CPU,来真正运行。这个过程很抽象,我举2个例子,第一个就是JAVA语言,它有一个虚拟机,这个虚拟机就是软件CPU。再举一个例子,我现在要编写这样一个指令:
  PRINT S  这个指令表示打印S
  S代表一个万能类型。
  为了实现这个指令,你首先要有一个函数来负责处理打印
  比如是这样的函数
  void print(S) {    cout工作时也啃,人家都会说你很有激情的。看电子的如果闲麻烦,就打印下来,打印下来还是花不了几个钢币的,和买一本中文差不多(大家不要哭穷,一本好书100元我认为很值得,里面技术如果你掌握了,你想想,大把大把的票子就进你口袋里,很多人买来不看,天天还抱怨书贵。)
  这几年来,我读过很多游戏编程方面的书,中文的基本都读过了,现在我一直在读英文书,有时到觉得看中文有些不适应,还有好多好书,我还没有读。读英文书时,如果没读懂,自己一定要去网上查查相关资料,然后集中精力把它弄懂,现在很少有看不懂的英文游戏编程书(知道我6级没过的,别用砖扔我),有些还是看不懂,确实自己水平有限,但不是因为英语问题,关于高深而复杂数学问题,即使翻译成中文,我也很难看明白。
  我在后面会把所有好的游戏编程书籍都列出来,告诉大家那些可以买到,那些只有电子的。不好的书,我就不列出来了,只会浪费大家以后的时间。 我这里介绍下要做一个好的,称职的游戏程序员所需要的。学习就和盖楼一样,要想上层建筑牢固,你就要有坚实的基础,我这里介绍的基础是你从事游戏编程最基础,基础的不能再基础的东西。
  (1)数学
  数学是游戏中支柱,没有了它,任何都不要谈,在你编写你游戏的时候,你就会知道,世界抽象成一堆数学是多么的神奇,突然你会觉得以前枯燥无味的数学现在是一顿大餐,但这个是霸王餐。国外人写关于引擎方面书的人,都可以说是数学高手,他们理论和实践都很厉害,让我崇拜的不得了。大学里是你学好数学的最好机会,一定要弄明白它的现实意义,任何理论都不是凭空出来的,它一定有现实基础,这个现实基础,就可以帮助你很好理解这个理论。
  高等数学--微积分理论
  在游戏引擎中,很多游戏特效都是通过微积分方程来解得的,高度仿真是现在游戏的追求,真实感越强就需要越多的计算量。极限,一元微积分,多元微积分,级数,微分方程等等在游戏图形图像和物理上都有明显体现。有时一个硕士或者一个博士为了拟真一个效果要花费几个月或者几年的时间,作为一个游戏程序员,微积分到达什么层次我很难给出定义,但起码如果别人给出了原理我们能看明白,并把它实现,我觉得就很可贵了。
  线性代数和空间解析几何
  在大学课本中,空间解析几何是放在高等数学书里面讲的,但游戏中,它和线性代数放到一起我认为更加合适。线性代数所有知识都要掌握,在游戏中它们比微积分体现的更淋漓尽致,理解上我个人认为相对微积分更容易。
  空间解析几何主要讲向量,平面,线,体,这些东西并通过线性代数矩阵进行空间变换,最后达到游戏想要的目标。
  四元数
  这个在大学里面不学数学的,估计很少有人接触,它也是来用来变换空间,理解起来不是那么容易,但最常用的就是用四元数来表示旋转。
  我这里只是一概而过,上面任何知识在游戏中都有应用,但大学里的数学不是为了游戏而开设的,所以和游戏中用的数学在知识分列和讲解上还是有很大差异,尤其是线性代数和空间解析几何,不用担心,我在后面介绍给大家一些好的游戏书籍,对大家学习游戏编程很有帮助的。
  (2)语言
  编写游戏C和C++是你首选,相对来讲C++是你更应该掌握的。
  其他语言为什么不是当今流行的编写游戏程序语言?
  VB,JAVA,C#,等等其他语言,并不是说它们不能做游戏,它们能做,由于语言本身设计机理的限制,只能做一些对游戏速度要求低的游戏,对于运行速度要求高的游戏,它们被判成死刑。当然这个也取决于硬件的发展,以前8bit FC游戏都用C语言和汇编来写,现在由于硬件速度提高,用VB,JAVA,C#来写这些游戏运行也是可以的,例如现在兴起的WebGame(网页游戏)。但如果你真想做游戏的话,你一定想要了解现在最流行游戏编写,C和C++是你最好的选择,也是你走上真正的游戏编程道路的重要武器。
  C和C++应该选择那一个?
  C和C++,这里面我还要说一说,我个人更看好C++。大家都知道C是面向过程的,而C++是面向对象的,虽然C++的面向对象特性还不是很完善,但出于对大型软件设计上的考虑,因为游戏引擎是大工程,框架设计远远要比编程重要,一般框架设计用面向对象方式更直接,所以C++比C更有优越性,而且如果你合理用好C++,并不见得C++比C速度慢。有时一个软件架构和软件运行上问题,很难取舍,对于大应用程序来说,都是一点点牺牲速度来获得好的架构,是利大于弊的事情,这里确实体现软件工程的重要性质。
  汇编,很重要吗?
  汇编语言也是你要掌握的,你说你语言学的好,但却不会汇编,是一个天大的笑话。现在很少有汇编高手能写出比编译器优化出来的汇编代码运行效率要高的代码,因为语言的不同,思考问题的方式就会有不同,就象最早纸带机上的原语言一样(可计算性与计算复杂性就讲这东西)。如果游戏都用汇编来写,写代码效率很低,所以我们都用高级语言来写,同时还要与底层有密切联系的,C和C++担任大部分工作量。对于游戏速度瓶颈问题,有时我们用C和C++即使优化很多,代码精简很多,算法也改良很多,但由于语言本身设计上问题,和高效汇编来编写还是有不同的,这时就要汇编高手来做速度最快,内存和寄存器使用最少的汇编程序。所以汇编还是很重要的。
  其他CPU硬件指令
  这里只是说 INTER 和 AMD CPU 都支持的指令集,也是最常用指令集。
  MMX和SSE SSE2是游戏编程中最常用的指令集,这个指令集是 SIMD(single instruction multiple data),也就是单指令多数据流指令集,一个指令可以处理多个数据流运算。汇编CPU指令,一个指令只能执行一个数据流运算。
  例如:
  汇编中
  ADD EAX,EBX
  这是一个加法指令,EAX,EBX是寄存器,是32位的。这个指令就是 EAX = EAX + EBX。这个过程只有一个数据流相加。
  而SIMD思想是,如果现在有2个指令
  ADD EAX,EBX 
  ADD ECX,EDX
  能不能让他们一起执行?所以SIMD 指令提供这样的功能,他用很大的寄存器,前一部分装EAX值,后一部分装ECX值,再用一个寄存器,前一部分装EBX,后一部分装EDX.
  SIMD 寄存器分成2部分[1部分][2部分
  ]
  SIMD ADD 指令  寄存器1  ,寄存器2 
  运算过程为:
  寄存器1 [1部分] = 寄存器1  [1部分] + 寄存器2  [1部分] ;
  寄存器1 [2部分] = 寄存器1  [2部分] + 寄存器2  [2部分] ;
  这2个运行是在一个SIMD积寄存器用硬件来执行ADD 同时运行的。
  这里只是说了SIMD思想,现在简单介绍下 MMX,SSE,SSE2。
  MMX寄存器是32位的,所以它可以执行4个8bit数据同时运算,也可以执行2个16bit数据同时运算,具体要看使用哪个指令,在早期没有SSE指令时,就用MMX,但MMX有缺点,它和FPU(浮点运算单元,专门执行浮点数运算)共用同样寄存器,所以当你指令有中断,从浮点运算跳到MMX运算,要告诉CPU,从MMX跳到FPU 也要告诉CPU,这样数据要临时保存,降低了处理速度。早期2D游戏经常用这个。
  现在SSE,SSE2有自己单独的寄存器可以使用,而且它们是128位的,支持4个32位整数或者浮点数同时运算。
  这些指令都没有分支,所以使用时效率要我们掌握,因为执行都是并行的,一个指令完成多个计算,所以即使你编写SIMD代码很差,速度也会提高几倍,游戏中经常用SIMD处理颜色和数学运算问题。在游戏速度瓶颈地方用这样的代码,公德无量。
  ASM SHADER语言和高级SHADER 语言
  开始学游戏编程时,这个知识不一定要具备,因为你不了解3D流水线内部细节学起来还是比较困难,所当你做完"软引擎" ,了解3D流水线,再学这个语言很容易,接下来的语言发挥,就靠你自己了。
  早期的游戏,所有的图形图像处理基本都由CPU来完成,然后把处理完的数据传到显存,用显卡来显示。现在的设计理念尽量解放CPU,把与图形图像有关的运算用GPU来完成。但早期显卡只支持固定流水线,所谓的固定流水线就是所有3D数据处理过程都是事先用硬件实现好的,这个过程是一个大过程,里面封装了很多小过程细节,用户只需要输入数据,显卡负责输出数据,至于用户无法干预这个大过程,小过程更是接触不到。再说的通俗一点,一个空间3D三角形要想显示到计算机屏幕上,基本要经历2个大过程,顶点处理和像素处理,顶点处理封装了很多空间变换的小过程,像素处理包括像素混合小过程。这个过程是不可以访问的,我们只能通过显卡提供的接口来控制,而且改变方式很单一。(刚接触这些可能不明白,现在你知道的不用太详细,就知道大过程是不可以干预的就可以了,或者是只有很少一部分可以干预)为了让图形图像处理更加完善,让人们可以参与到整个3D流水线中,实现更多丰富的效果,显卡开始出现GPU单元(图形处理单元),这时的3D流水线从固定流水变成了可编程流水线,有了早期的GPU 指令,大家都称为 SHADER指令,也就是ASM SHADER,和汇编一样,这些指令都是和GPU指令一一对应的,随着硬件更新,GPU越来越强大,支持指令越来越多,ASM SHADER 从1.0 到 1.4 ,到现在3.0版本。由于ASM SHADER 用起来不方便,就像我们用汇编写程序一样,所以又出现了高级SHADER语言,有Direct3D下支持HLSL(high level shader language)和openGL下支持的GLSL(opengl shader language)这些语言都是面向过程。由于硬件设计限制,这些语言不能象C语言那样随意使用,SHADER语言有自己的使用规范,大家学习时一定要弄明白3D流水线内部实现过程,再使用SHADER就很容易。
  还有一个要说的是,GPU现在还不支持分支预测,但GPU编程语言现在已经提供了丰富的条件判断,条件判断还是会影响到速度的。
  重点你要掌握的是:数学,C和C++,汇编,数据结构;基本掌握的是计算机体系结构,离散数学,编译原理,计算机网络,操作系统,软件工程,数据库,人工智能。可以说这些是计算机最基础的学科,你只有掌握了它们,无论你专研计算机哪个领域,你的基础都是足够的,游戏编程中这些学科都可以用到,我们不用每个学科都精通的要命,我们要精通的是游戏编程,也就是接触到和游戏相关的,我们有这些基础完全可以看懂,然后我们再用自己的时间来专研这些学科在游戏领域的应用。 四、游戏编程,她的大门已经为你打开。
  1、颜色之迷
  计算机怎么显示图形的,这个你必须要弄明白,计算机显示彩色图像是经历了一个什么样的发展过程。
  (1)像素和屏幕显示点
  计算机显示一个图像是由像素组成,我们通常说的分辨率就是屏幕上显示多少个像素。如果一个屏幕最大可以支持1024*768那么它也可以支持800*600,当你屏幕分辨率是800*600时,一个像素占据了屏幕多个屏幕显示点,也就是说,只有当你分辨率调节到最大时,屏幕显示点和像素点才是一一对应的,至于一个像素占据多个屏幕显示点后颜色怎么显示这个是硬件的事,我也不是很了解。像素都是2进制存储,然后由硬件根据显存中当前像素值,根据颜色显示模式的设定,来显示指定颜色。
  (2)颜色组成和模式
  计算机要显示颜色,每个像素都有自己的颜色,通常颜色有3种模式,一个是调色板模式,一个是16bit模式,一个是32bit模式,我这里说的通常,早期也有4bit模式,我要讲出里面的细节,让看的人真正理解,不是死记硬背,你就会发现实质上只有2种模式,一个是调色版模式和bit显示模式。
  我先介绍位显示模式,从4bit开始,早期颜色显示很单调,硬件只支持16个颜色,当然这16个可以是黑白的,也可以是彩色的。总之硬件就支持16个颜色。所以用4bit表示4bit 2进制正好可以代表16个。随着硬件发展支持的颜色越来越多,发展到16bit,16bit开始有了严格限制,颜色是由三种色彩基元组成,也就是红绿蓝,人送江湖称号RGB,16bit分成1555格式和565格式,1555就是1位给ALPHA(表示透明)分给RGB分别5bit,5bit可以表示色彩基元颜色是32种,RGB组合起来就是15bit,就是2的15次方,可以表示很多颜色了。而565格式没有ALPHA位置,直接分给RGB位数为565,也就是绿色多了一位,传说中,专家说人眼对绿色敏感,所以给绿色多分了一位。而32bit分给 ALPHA 和 RGB 分别是 8888,每个都是8bit。其实标准的颜色中每个分量都是8bit,每个色彩基元都是256种,而16bit模式不能显示出真实世界色彩。
  调色板模式一般都是针对每个分量是8bit,也就是颜色组成是32位的。调色板模式有一个映射表数组,这个映射表数组每个元素都存放的是32位的颜色,而显存存放的是一个索引,但硬件读出显存当前像素值时,然后用这个值当作索引去映射表数组里面查对应的颜色,然后显示到屏幕上。
  相比较而言,调色板模式是最早期的,例如早期FC 8bit机每个像素只占8bit,只能表示256种颜色,而我们彩电可以表示很多颜色,为了节省显存,增加处理速度,还显示出多种颜色,FC用调色板模式,而我们想换颜色时,其实只换调色板映射表数组某一个值就可以了,索引都不用变,毕竟索引是写在显存中的,一般改写显存还是速度很慢的。16bit模式也是在处理速度上,节省存储空间上得以应用。毕竟这些显示模式都是为了应付以前硬件速度太慢而设计的,现在一般都用32bit 模式。
  还有一个要说的就是ALPHA,这个分量是表示透明度的,这个分量如果是8bit,那么它可以表示256种透明程度,255表示不透明,0表示完全透明。
  现在大家知道你设置屏幕或者游戏时1024*768*32 什么意思了吧!每个像素占32bit,屏幕显示1024*768个像素。
  (3)颜色的运算
  计算机支持颜色运算都是无符号颜色运算,颜色没有负数,而且颜色运算有CLAMP和MOD
  如果每个颜色占8bit,颜色表示范围为0-255
  这里CLAMP指的是
  if(x255) x=255;
  这里MOD指
  if(x>255) x = x%255;
  Color1(a1,r1,g1,b1) Color2(a2,r2,g2,b2) 
  颜色加减都是向量加减,每个分量做加减
  颜色加法
  Color3(a3,r3,g3,b3) = Color1(a1,r1,g1,b1) + Color2(a2,r2,g2,b2) 
  a3 = a1 + a2; r3 = r1 + r2;        g3 = g1 + g2; b3 = b1 + b2;
  颜色加法一般都用CLAMP
  颜色乘法
  Color3(a3,r3,g3,b3) = Color1(a1,r1,g1,b1) * Color2(a2,r2,g2,b2) 
  a3 = a1 * a2; r3 = r1 * r2; g3 = g1 * g2; b3 = b1 * b2;
  颜色乘法一般都用MOD
  颜色加法和乘法在像素混合效果上经常用,有时为了达到一个效果,加法和减法混合用,至于什么时候用加法,什么时候用乘法,没有严格的规定,还是要看效果,一般对于全局光照模型颜色之间要用加法的,但其他光照模型可能不同,纹理混合或者纹理和颜色混合,加法和乘法都有各自用途。 这里只说他们支持的图形和图像部分,其他部分不说。
  很多人都听过这2个名词,其实他们是一个函数库,这个函数库为我们做了一些最基本的和底层打交道的处理,其次它们还提供了一些常用的3D函数库,算是一个2次开发,其实2次开发一般和底层没有关系,所以在游戏引擎中很多都自己来做,微软做了很多2次开发,可以算是一个引擎。我前面说了,引擎没有明确概念,只有适应程度之分,用它提供的这个来做游戏,还是差很远,做小游戏当然没问题。
  我主要说说和底层打交道那部分,DX和openGL最大功劳在于充分调度和发挥了显卡性能,把显卡的特性用接口的形式提供出来,他们各自都有自己的管理层次、管理方法、管理管线,至于怎么管理,我也不是很清楚,但当你使用和显卡资源相关的API时,你要仔细看这个函数各个参数说明,它会根据你的指定,来管理显卡。但他的管理只是一部分,还有很大一部分要引擎里面自己处理。
  如果你不想自己写驱动的话,那么你还想控制显卡,你就要用这些API,D3D(DX中主要处理3D的)和openGL使用上还是有很大不同,所以学习他们也还要花费一些时间。我当初学习时,由于不了解3D渲染流程,学起来特别困难,很难看懂,我就放弃了他的学习,学习制作"软引擎"(用CPU来实现显卡提供的硬件功能),然后再学D3D,很容易的。有时候放弃是为了选择更好的,并不是真正的放弃。
  至于学习D3D还是openGL,我个人认为无所谓的,但好象openGL越更新越混乱,没有DX那么清晰,我也是听别人说的,毕竟我不是很了解openGL。 游戏编程充着大量常用术语,我不打算把它们都列出来,实在太多,我想对于初学者来说,我希望,你在学习游戏编程时,自己多查下资料究竟这些术语都有什么含义,记住一定在学习游戏编程时去查,也就是说,针对问题去查,而不是在没有遇到任何问题时去查。其实我们的教育有个弊端,任何知识我们学了,不知道怎么用。其实很多知识都是我们遇到问题时再去查资料,去找解决方式,而不是在不知道这个解决方式用来解决什么的情况下瞎学。
  最好大家把这些术语的中文和英文名称都能知道是怎么回事,因为你到以后看英文书时,如果你知道这个术语的含义,看起来会很容易。 五、游戏编程中的2D游戏,你首先要做到的。
  通往神殿的第一个考验就是这个,不知道你是否能走下来,相信自己会成功,你的信念一定要不可动摇,当你走过这段路的时候,想想你现在所得到的,付出的其实不算什么。
  很多人可能会问,我想做3D游戏,2D游戏学它干什么。其实3D游戏处理可以分成2个部分,一个是3D空间数据处理,经过纹理映射把像素写到屏幕缓冲,接下来其他特效处理都是归结到2D问题。
  所以你想真正了解游戏图像处理过程,还是要学2D的。2D原理相对3D来说简单很多,学起来也不是很难。我建议去看《WINDOWS游戏编程大师技巧》里面的代码都读明白,它用C语言实现一个小的游戏引擎,我希望你用C++封装成类的形式,重新按照自己规划来实现,最后做出个游戏。用引擎做出的游戏和直接做游戏还是有很大区别的,代码重用性更强。这本书用的DirectX中DirectDraw接口来实现的,你一定要了解你使用的工具,它能用来干什么,它不能用来干什么,这样你才能很好的游戏编程。如果你不了解C语言,怎么用C语言编程,都是一个道理的。我不想再过多详细介绍DirectDraw为我们提供了什么特性,你自己去看书。
  2D游戏中,最常用的概念就是贴图,把一个图像贴到另一个上。2D游戏中一种处理模式是在各个图片上的处理,还有就是在像素上的处理,其实这些都可以归结到像素上的处理,像素处理,就是处理显存数据。
  颜色模式,《WINDOWS游戏编程大师技巧》这本书讲的很详细。
  2D动画系统,《WINDOWS游戏编程大师技巧》这本书没有详细介绍,但你看它的代码,代码写的很清楚而详细,你就知道的。
  GDI 我不知道大家听说过没有,它是WINDOW自带的图形图像接口,我希望大家也能了解下,当时我是GDI和DirectDraw一起学的,然后分别做了引擎,2个引擎接口也一样,游戏移植非常容易。
  一个最重要的问题就是调试,8BIT模式下的游戏,用编译器带的单步调式是不可能的,我机器死机N回。我现在也没有发现好的办法,最好的办法就是自己做一个LOG日志系统,把所有调试信息都写到文件里,用任务管理器把当前程序关掉,然后看文件写的信息。
  2D游戏制作细节我没有详细介绍,毕竟我不是在讲怎么制作2D游戏,我是讲你应该注意什么,怎么学,我想《WINDOWS游戏编程大师技巧》会给你想要的一切。当然我在学这本书前已经有了一些2D游戏基础,以前用VB做过游戏,用GDI也做过,所以学起来还算容易,如果你以前没有任何游戏编程基础就直接用DirectDraw,那么我希望你多下点工夫,把它制作游戏的流程都搞清楚,记住什么时候用自己的双手做出了自己2D游戏,你才算2D游戏编程过关了。这本书仔细看吧!直到把它所有的精髓都掌握。
  还有一个要说的就是,图像处理常用算法,大家可以多看看图像处理的书,游戏中特效经常用到,其实如果你真想一心搞3D,2D上做一个坦克大战这样的游戏就可以了,很多2D处理详细东西,在学3D游戏时,都可以接触的。 六、游戏编程中的3D游戏,考验你耐力和勇气的时候到了!
  前面你所遇到的一切都是小小测试,证明你有能力接受这个挑战,在3D游戏这个广阔无垠的天地里,它比2D游戏更有让你想象余地的空间,因为3D游戏不仅仅包括2D游戏所有,而且还包括很多其他东西。努力吧!朋友们,无论遇到什么挫折,都不要放弃,因为她最后会给你想要的。
  我不知道其他人学习3D游戏是一个什么样的过程,这里我只介绍我自己的学习过程,因为我是从挫败中走过来的。
  开始学3D,脑袋里一片模糊,只有一点点大学里学的计算机图形学相关的知识,我不得不说学校里讲的计算机图形学和游戏还是大相径庭的。
  (这里允许我抱怨一下,国外很多大学都开设了3D游戏编程的课程,而且很专业,我看过老外的PPT。相对于国内,也有些,但不专业,我说游戏学院骗钱你不要打我,它确实能让你找到工作,但你做的永远是下手,学不到底层的东西。我看过游戏学院开设的课程,没有一个是有技术含量的,用"外包"形容在贴切不过。道理也很简单,中国现在牛人很少,我说搞引擎的高手全国有1000人都是保守的,真正能搞出名堂的,也不多于200人,这200人里面学习游戏编程经验10年就很多了,中国3D游戏起步很晚,相对国外,中国人爱跳槽的习惯,让任何公司都没有技术积累,发展更是困难,所以人才积累的少,而且这些人都很忙,在加上现在学校教育约束,即使他们想去高校教授游戏课程也是不可能,何况人家都不愿意去,这样中国积累的人才更少)
  所以你要系统学习游戏中图形学理论。
  这里我经历了游戏学习编程一次比较大的挫败,当时自己是初学者,问过很多人学3D,应该从什么入手。很多人都说从D3D开始入手,于是我做了。我不得不说的是,如果你不了解3D流水线过程,学D3D简直是看天书,当时我以为自己反复的看书,写程序,最后会理解的,浪费了我大量的时间,最后还是无法灵活掌握D3D,如果你无法掌握D3D,想做游戏可能真的很困难。我终于认识到,我选择的路是错误的,那些所谓的高手难道就学D3D学过来的?那么他们花费的时间是可想而知的。因为有些细节你无法掌握,你使用时就觉得匪夷所思。
  《3D游戏编程大师技巧》这本书是每个学3D的人都应该看的,这本书把显卡硬件实现的功能都用软件来做,真正让你理解一个3D东西到最后的屏幕显示,是一个什么样的过程。作者实现了一个软引擎,软引擎就是所有的3D功能都是用代码自己写的,没有用什么显卡来做处理的引擎。这本书是一个经典巨著,如果你想学3D,即使死也要把这本书弄明白,这样不辜负作者写这本书留下的汗水,写一本书,尤其这么PERFECT,太不容易了,国内人翻译的也很出色,感谢他们。
  《3D游戏编程大师技巧》继承了《WINDOWS游戏编程大师技巧》里面2D函数,然后3D功能以及流水线和引擎都是自己完成,这本书的代码量要有十几万,我当时用C++重新封装了《3D游戏编程大师技巧》代码,自己设计了一个面向对象固定流水线模式,代码量13W左右,这个过程很艰辛,这本书我看了2遍,最后一共零零散散花费了大约9-10个月的时间。你会感觉你立刻升级了,HP,MP,CP都增长了,当然也包括RP,哈哈!(不知道这些术语的,大家多玩玩RPG游戏吧!)
  好东西去追求,不要怕浪费时间,浪费精力,你想想,你得到的最后会大于你的付出,这些都不算什么。很多人问我怎么学3D,我建议他们不能着急,要从学《3D游戏编程大师技巧》开始,大约要8-9个月时间,把每个细节都弄明白,闭上眼睛,怎么实现就很清楚,书上每一页写什么都很明确。他们都觉得浪费时间,那么这样是永远学不好的 虽然你数学学的好,但国内的教科书还是和游戏中用的有些不同,毕竟没有上过专门讲解游戏中数学知识的课程。这需要你系统学习游戏编程中数学,3*3矩阵为什么有的人用,而有的人用4*4矩阵,为什么有的用矩阵转置有的用矩阵的逆。《3D游戏编程大师技巧》这本书介绍的很详细,还有一本书就是《3D数学基础:图形与游戏开发》很不错(有中文的),先系统学习下,然后在学习游戏编程时,不懂的时候,再回头看看这些书,把所有的东西都彻底弄清。你如果数学基础好,学这些都很容易,以后游戏编程中最深奥的地方之一就是数学。
  基本上我总结下,你要知道的是:
  向量  4维和 3维向量有什么不同
  矩阵  4*4 和 3*3 矩阵有什么不同
  四元数
  ELUER角
  以后有机会深入研究碰撞中的各种算法,还会遇到很多关于数学的问题,上面只是渲染有关系。 我无法用言语来表明这个过程的重要性,整个3D流水线是3D游戏的脊柱,你的基础知识牢固与否,主要看这里。3D流水线每一个细节我希望大家都要搞清楚,这个过程对初学者是要花费大量的时间专研与琢磨,D3D的固定流水线都是由硬件完成,如果你的硬件不支持,它会用软件模拟,好,关键就在这里,软件模拟是怎么回事,而《3D游戏编程大师技巧》的流水线是自己用C语言写的,也就是用软件完成,这样你能了解整个流水线的细节,同时你在学D3D时,对照着来学,你会发现,D3D学起来很容易。现在D3D和硬件都支持可编程流水线,而且DX10没有固定流水线,所有变换过程都用SHADER语言控制显卡完成,这个过程是3D流水线的缩影,所以3D流水线的重要性是是可想而知的。
  我说了这么多,3D流水线对你是一个新鲜的名词,我也没有去解释它,我不想去解释,完全留给你自己去,我始终坚持,我只告诉你去的路,路上有什么困难,应该怎么走,你自己去体会这条路上的酸甜苦辣。我希望大家多花些时间在这上面,真真正正的自己写代码实现一下,基础对你真的很重要,记住我说的话,很多人学习时,认为自己理解了,没有去实现,其实还是那句话"纸上得来终觉浅,绝知此事必躬行",相信我,没错的。
  基本上我总结下,你要知道的是:
  3D中的顶点结构,每个分量都用来干什么,三角形是基本渲染单元。
  模型空间--》世界空间--》相机空间--》投影空间--》屏幕空间--》光栅化这个过程和运行原理
  材质究竟是什么?
  常用的宏光照模型原理,光源类型
  光源和材质和法向量关系
  光照在哪个空间去执行(其实不是很严格)
  纹理寻址,纹理映射方式,纹理混合,纹理过滤。
  1D 2D 3D CUBE 纹理
  Z 1/Z缓冲
  2种相机模型
  ALPHA 透明
  关于光栅化三角形要特别注意,他最后混合纹理和光照颜色和ALPHA透明,还要判断深度缓冲,最后是插值填写每个像素。 《3D游戏编程大师技巧》和D3D流水线过程还是有些差别的,比如在投影矩阵上,其实它们都是大同小异,只不过表现形式不同,原理都一样。我希望大家自己可以找出来,深刻理解里面原理。
  还有一个重要的东西,就是哪些是D3D开发游戏必须有的,哪些是D3D自己扩展的。必须有的,就是同硬件打交道的部分,而D3D中自己扩展了很多库函数,例如数学库,这个完全可以没有,我们自己来实现,还有D3D中的EFFECT接口,它自己定义的。X文件所有函数接口。也就是说,你要理解,哪些是游戏开发中必须有的,哪些是游戏开发中自己完全可以不接触底层来实现的。
  游戏编程中有3个缓冲区,颜色缓冲,深度缓冲,模板缓冲,前2个《3D游戏编程大师技巧》中,都详细的介绍,而模板对初学者可能很晦涩,大家先弄明白模板的机制,然后多看些例子,我想你会深刻理解它的含义的。
  D3D的学习,可以看D3D SDK的例子,也可以找一些书籍,很多的。
  基本上我总结下,你要知道的是:
  D3D提供基本常用底层接口,哪些是D3D为了编程必须提供的,哪些是不用提供的,比如数学库我们完全可以自己写。
  D3D顶点索引BUFFER
  颜色缓冲,模版缓冲,深度缓冲以及对这些缓冲的操作
  目标渲染对象、D3D 中的3D流水线
  单通道渲染,多通道渲染。
  熟练操作上面的所有,这些都足够了,其他的都是D3D中多余的,如果你要自己做引擎,很多都要自己实现,当然初学者可以就用它扩展的函数库,也很方便的。 下面知识都属于很强的游戏技术范畴,他们只属于单单游戏中技术支持,引擎就是用合理的方式,把所有3D相关包括流水线和下面这些都整和到一起,但这种整和是有效的管理。
  场景管理算法:BSP OCTREE QUADTREE PORTAL PVS
  动画系统:骨骼动画,蒙皮骨骼动画,渐变动画,和这些动画的混合
  阴影:阴影体投影阴影阴影影射
  剔除算法:包围球 OBB AABB BHV算法
  LOD系统:视点无关LOD 视点相关LOD
  广告牌:跟踪相机方向和只围绕y轴旋转
  粒子系统
  这些是比较常用的,常常碰到的,根据基本的颜色运算,空间运算还能衍生出很多游戏特效,等待你自己去看书,去解决。 就象我前面说的,引擎没有严格定义划分,但对于当代的引擎,似乎大家都趋向于越好的东西,越健壮的支持,才称上引擎。现在游戏玩家对画面拟真程度要求很高,这就要求引擎能更好的处理3D世界中大量数据,一个好的引擎,起码要做到以下几点:
  l         如何把3D世界中大量数据,让它实时快速处理。
  l         引擎中的渲染器(用来管理数据,进行渲染处理的)接口应该怎么定义。
  l         如何让使用引擎的人,能很容易的使用引擎。
  l         当引擎中添加新特性时,如何让引擎改动最小。
  我感觉这4句话,概括的很精辟,如果让我来概括,好象我现在还没这个能力。这是一个当代引擎的新的定义,虽然不是全面,但它一语道破天机,如果你的引擎能达到上面4点,我想它已经足够的优秀,同时说明你也很优秀了。下面我就分别解剖这4句话,让大家对引擎有一个深刻的了解。我只是分析,这4句话要求高手才可以达到,我现在还不具备这个能力,所以只能帮大家分析。 1、如何把3D世界中大量数据,让它实时快速处理。
  3D世界中充满了大量数据,有效的处理只可以看见的,能感受到的就可以了。
  3D引擎中,很多时候都在处理剪裁和剔除的问题,把不可见的或者和碰撞无关的数据用最快的方法弄掉,不让它进入显卡,一切还是停留在3D空间中。剪裁,剔除还有碰撞处理,永远是3D引擎中最常见的话题,现在有很多成型的方法,大家自己通过学习就可以了解的。 2、引擎中的渲染器(用来管理数据,进行渲染处理的)接口应该怎么定义。
  3、如何让使用引擎的人,能很容易的使用引擎。
  这是一个经验问题,一个软件设计给用户使用,怎么让用户很容易上手。但无论什么样的用户,你必须对3D有了解才可以使用,否则神仙也没法完成这个引擎。 4、当引擎中添加新特性时,如何让引擎改动最小。
  经常说的一句话就是"计划没有变化快",怎么能让引擎跟上时代的步伐,当硬件有革新,我们引擎就有革新,出现新的处理方法,引擎也要改进,用户需求改变,引擎接口也要改变,我们要求引擎的所有改动最小,这样才是一个完美的引擎。
  引擎是软件设计+算法+编程的结合体,难点在软件设计上,一个好的引擎,代码几百万很正常,没有一个好的设计来规范它们,混乱是不可避免的。
  对于一个引擎,从设计到编程都很重要,一个人完成一个好的引擎是不可能的,多人协作来完成引擎,在大家相互配合的同时,每个人对自己的要完成的任务必须精通,还要有人协调这些工作。
  好的引擎,要有一个抽象层次,然后是渲染API层次,还要支持多操作系统平台,我在这里没有过多介绍各种技术细节,因为很多细节在书中都可以找到,加上你的聪明,很多技术算法可以自己创造的。
  对于游戏中大量算法,引擎中到处都是,碰撞,场景管理,光照,纹理混合,动画系统,粒子系统,内存管理,资源管理等等大家要多实践,多思考,多看书,多看资料,把握每一个细节,把握每一个整体。看书时要带着问题去看,同时也要带出问题,因为没有一个方法是完美的,必定会有或多或少的缺陷。
  现在开源的引擎确实不少,其实程序员都有一个共性,看别人代码有时不如自己写,确实这样,有时只看代码去体会别人的思想真的很难,但有时为了去学习也要硬着头皮去看的,跟踪代码。开始时,如果你不了解引擎究竟是什么,这时最好集中看一个开源引擎,一定要把它的工作原理都弄明白,这样你会得到很大的提升,你就会明白引擎是什么,为什么不用D3D直接编写游戏,还有一点就是,有机会一定要去实现,这样你的体会会更深。 这2个都不是中国游戏中的优势,它们和图形一样,要求一定能力积累才可以胜任。如果我没有预测的话,未来中国游戏中大量的需求将来自物理和人工智能,传统的网络RPG会慢慢不能满足大家需要,而被时代所抛弃的。
  这2方面的编程我只是略知一二,还算一个小白,在此简单谈谈。 游戏中大部分物理模拟都集中在力学和运动学上,本来它们就是一个整体。因为最后效果是大家看到的,而看到的都是物体在屏幕上的移动,所以所有的计算最终都归结到物体移动上。
  因为游戏毕竟是游戏,人也毕竟是人,没有必要模拟的那么精确,同时人也是感觉不出来的。
  所以要想做好物理上的编程,必须对力学和运动学有系统的了解,高中学的力学部分还不是很足够,对于旋转部分,也就是处理力矩和转动惯量上,高中物理书都没有讲(我那时是没有讲,而且很多直线线性运动方程推导其实是用微积分推导的,高中书上都没有明确推导)
  物理上的模拟也没有逃脱物理计算基本规则,先是受力分析,然后计算合力,计算加速度,计算速度,最后计算位置,也可能涉及到动能和动量等知识,还有些流体力学等等吧。
  物理其实处理的问题基本就是检测物体碰撞,碰撞后的反映,物体运动情况。
  至于理论,大家弄本大学物理,力学部分就足够,如果数学好的话加上高中的物理知识,应该学起来不难的。
  《游戏开发物理学》这本书很好,可惜绝版了,但有电子版的,也有中文版。 相对物理的编程书籍来说,AI的书很多。
  AI是研究生必须学的课程,包括传统的AI和计算智能。游戏中常用的传统AI包括自动机理论,A* 算法,回溯,图搜索,剪枝等等吧。计算智能包括的是:遗传算法,模糊计算,人工神经网络。
  我答UBI笔试的时候,里面很多题都是A*算法,可见FPS游戏中大量存在的都是AI的路径搜索问题,让电脑更加智能。
  AI的游戏编程书很多,我就看过几本。《WINDOWS游戏编程》中有一部分讲的AI,《游戏开发中人工智能》《游戏编程中的人工智能技术》这3本都有中文的,而且都有大量的实例,对于那些大量理论的书籍来说,看看它们还是很通俗的。还有很多好书,都是英文的。
分享到:
评论

相关推荐

    如何学好3D游戏引擎编程

    很实际的一个关于游戏引擎编程的感想,一个一路学引擎的人心血啊~

    2021-2022收藏资料关于如何学好游戏3D引擎编程的一些经验.doc

    2021年09月16日

    3D游戏引擎编程-3D.Game.Engine.Programming.pdf【第二部分】

    3D游戏引擎编程-3D.Game.Engine.Programming.pdf,作者:Stefan Zerbst & Oliver Duvel,本书是英文版,大小 271 MB,被压缩成两部分分别上传。这是第二部分,第一部分下载地址:...

    3D游戏引擎编程-3D.Game.Engine.Programming.pdf【第一部分】

    3D游戏引擎编程-3D.Game.Engine.Programming.pdf,作者:Stefan Zerbst & Oliver Duvel,本书是英文版,大小 271 MB,被压缩成两部分分别上传。这是第一部分,第二部分下载地址:...

    DirectX 游戏编程 3D游戏引擎

    极好的学习DirectX和3D游戏编程的入门书籍 以Direct3D为主,介绍3D变换,渲染流程,灯光,纹理,混合,网格模型,地形渲染基础,粒子系统,和着色器语言入门 最后附上一个完整的FPS游戏Donuts代码,基于DirectX编写...

    TrueVision3D 6. 5 商业3D游戏引擎 特别版 3/6

    6.5版包含:3D引擎,多媒体引擎,网络引擎。SDK内包含许多工具用以加速开发: 阴影编辑器,模型查看器,多种模型格式输出插件以及特殊效果编辑器。世界编辑器和地图编辑器由于考虑到用户不同而不在计划中。 [编辑]...

    Unity3D游戏引擎 脚本入门

    Unity 3D游戏引擎脚本入门,可以看教程结合图解一步一步来建构自己的游戏,能够让新手尽快入门,即使没有编程基础也可以轻松开发游戏,值得好好学习一下。

    TrueVision3D 6. 5 商业3D游戏引擎 特别版 4/6

    6.5版包含:3D引擎,多媒体引擎,网络引擎。SDK内包含许多工具用以加速开发: 阴影编辑器,模型查看器,多种模型格式输出插件以及特殊效果编辑器。世界编辑器和地图编辑器由于考虑到用户不同而不在计划中。 [编辑]...

    3D游戏引擎编程_《3D Game Engine Programming》.part01

    这本经典的书很难下到的。解压后有200多兆。 大师精品。学习3D游戏开发必看。

    游戏引擎开发引导

    如何学好3D游戏引擎编程 此篇文章献给那些为了游戏编程不怕困难的热血青年,它的神秘要我永远不间断的去挑 战自我,超越自我,这样才能攀登到游戏技术的最高峰 这篇文章是我一年半前,找工作时候写的,那时是发到...

    游戏编程--大师技巧

     伪3D等角引擎  T3DLIB1库函数  BOB(变换对象)引擎  总结  第九章 用DirectInput和力反馈进行输入  输入循环回顾  DirectInput序曲  力反馈详述  编写通用的输入系统:T3DLIB2CPP  总结  第十章 用...

    一个用C++写的3D游戏引擎demo

    适用于所有人 学习3D游戏开发。  注释摘要:GetDeviceCaps(hDC, LOGPIXELSY) 用于取得每英寸有多少像素  MulDiv函数(被乘数, 分子, 分母) = nPointSize * GetDeviceCaps(hDC, LOGPIXELSY) / 72,如果不支持硬件...

    游戏引擎教程案例光盘

    结合大量的实例介绍了3D游戏引擎的发展和windows、Directx等编程在游戏引擎中的应用,让读者对3D图像引擎技术有详细的了解。书中包含有经过编译的完整案例,可以帮助读者系统地掌握游戏引擎的开发过程,这也是本书的...

    TrueVision3D 6. 5 商业3D游戏引擎 特别版 1/6

    6.5版包含:3D引擎,多媒体引擎,网络引擎。SDK内包含许多工具用以加速开发: 阴影编辑器,模型查看器,多种模型格式输出插件以及特殊效果编辑器。世界编辑器和地图编辑器由于考虑到用户不同而不在计划中。 [编辑]...

    TrueVision3D 6. 5 商业3D游戏引擎 特别版 6/6

    6.5版包含:3D引擎,多媒体引擎,网络引擎。SDK内包含许多工具用以加速开发: 阴影编辑器,模型查看器,多种模型格式输出插件以及特殊效果编辑器。世界编辑器和地图编辑器由于考虑到用户不同而不在计划中。 [编辑]...

    一个基于VC的3D游戏引擎演示代码

    摘要:VC/C++源码,游戏编程,3D游戏引擎  一个基于VC的3D游戏引擎演示源代码,并不是一个完整的游戏,主要是供学习和参考的,对VC新手友好。

    TrueVision3D 6. 5 商业3D游戏引擎 特别版 2/6

    6.5版包含:3D引擎,多媒体引擎,网络引擎。SDK内包含许多工具用以加速开发: 阴影编辑器,模型查看器,多种模型格式输出插件以及特殊效果编辑器。世界编辑器和地图编辑器由于考虑到用户不同而不在计划中。 [编辑]...

    TrueVision3D 6. 5 商业3D游戏引擎 特别版 5/6

    6.5版包含:3D引擎,多媒体引擎,网络引擎。SDK内包含许多工具用以加速开发: 阴影编辑器,模型查看器,多种模型格式输出插件以及特殊效果编辑器。世界编辑器和地图编辑器由于考虑到用户不同而不在计划中。 [编辑]...

Global site tag (gtag.js) - Google Analytics