>重点算法解疑系列文档·再快一点

 由于本章对读者的可接受能力的考虑,对DX的引入作了二点处理,1:从MFC中引入DX,2:使用DX的窗口模式,学习中应该着重注意的是原GDI贴图函数向DX下的贴图函数的改写,这些很容易理解,勿须再谈..
        作者为什么特别提到从MFC中引入DX呢?这个问题是不是来得有点莫明其妙?下面解释一下,因为MFC对窗口对象以及对窗口对象操作(如创建它,从内存中销毁它..),消息机制,绘图机制的API封装是MFC特有的,而其它的OPP,如Delphi对窗口的封装是用VCL来进行的,因此它们创建的窗口对象是有本质区别的,DX无论全屏模式还是窗口模式都有一个实际的窗口存在,假如这个窗口是一个对话框(游戏程序多用对话框窗口模型),用MFC来创建这个对话框窗口对象和用Delphi来创建这个对话框窗口对象以供DX所用,都是不一样的,根本原因上面说了,因为MFC和Delphi对窗口对象(对话框窗口对象当然也属于窗口对象的一种)的封装是不一样的,那么要达到使用VC++和Delphi来创建同一效果的对话框窗口对象就没有办法了吗?我们可以使用VC++的SDK方式来创建这个对话框,也可以使用Delphi的"准SDK"方式(即不使用VCL提供的窗口对象)来创建它,我想这就是作者为什么要特别提到从MFC中引入DX的原因了..
        还有一个问题是函数Surface(),似乎168的Game::InitDDraw()已经完成了所有的建立DDraw环境的工作,为什么还要加一个Surface()呢?它到底有什么作用呢?我们来具体分析一下Surface()中的代码以寻求答案,可以看到Surface()中,首先清除188页创建主显页面中创建的页面描述DDSD,可以页面描述想象成创建页面的模块,创建页面前要定义一个该页面使用的页面描述,当然这个页面描述还可用于创建其它的页面,只要DDSD不被重新定义,这个模板就不会变动,我们看到用DDSD创建主显页面之后,从创建各个缓存页面开始,由于功能上的需要(要创建固定大小的缓存页面)而对DDSD作了重新的定义(DDSD是一个结构,重新定义它就是给它的各个成员分量重新赋值),新的DDSD比起定义前的DDSD加入了对页面宽高度的定义,还有定义系统内存而不是显示内存为缓存区,而分量Flags只是重写,因为没有必要对它作功能上的变更,因此现在的DDSD是一个新的DDSD,除主显页面外的所有都是用新的DDSD定义的,具体表现就是从Game::InitDDraw()体内的创建第一个缓存页面时先调用了Surface(),再调用CreatSurface()创建实际的页面,Surface()并不创建实际的页面,上面说了它的作用只是重新定义DDSD,最后一个问题,由于Game::InitDDraw()引入DX定义的是DX的窗口模式,DDraw最大卖点之一的页面翻转将不能使用,于是程序中使用了自定义的BackToPro()..
[原网页] [置顶] 程序员面试、算法研究、编程艺术、红黑树、数据挖掘5大系列集锦 [原网页] 程序员编程艺术第三十~三十一章:字符串转换成整数,通配符字符串匹配 [原网页] 程序员编程艺术第二十八~二十九章:最大连续乘积子串、字符串编辑距离 [原网页] 数据挖掘中所需的概率论与数理统计知识、上 [原网页] 从K近邻算法、距离度量谈到KD树、SIFT+BBF算法 [原网页] 九月十月百度人搜,阿里巴巴,腾讯华为笔试面试八十题(第331-410题) [原网页] 支持向量机通俗导论(理解SVM的三层境界) [原网页] 从决策树学习谈到贝叶斯分类算法、EM、HMM [原网页] 从LSM-Tree、COLA-Tree谈到StackOverflow、OSQA [原网页] 程序员编程艺术第一~二十七章集锦与总结(教你如何编程),及PDF免分下载 [原网页] 教你如何迅速秒杀掉:99%的海量数据处理面试题 [原网页] 程序员编程艺术第二十七章:不改变正负数相对顺序重新排列数组(无解?) [原网页] 三五杆枪,可干革命,三五个人,可以创业 [原网页] Machine Learning读书会集锦(2013年4月14日第5期PPT教程已公布) [原网页] 结构之法算法之道blog博文集锦第6、第7期CHM文件0积分下载「07.30」 [原网页] 推荐引擎算法学习导论 [原网页] 程序员编程艺术第二十六章:基于给定的文档生成倒排索引(含源码下载) [原网页] 程序员编程艺术第二十五章:Jon Bentley:90%无法正确实现二分查找 [原网页] 编程艺术第二十三~四章十一续:杨氏矩阵查找,倒排索引关键词Hash编码 [原网页] 六之再续:KMP算法之总结篇(12.09修订,必懂KMP) [原网页] Nginx源码剖析之内存池,与内存管理 [原网页] 程序员编程艺术第一~二十二章集锦与总结(教你如何编程) [原网页] 从Trie树(字典树)谈到后缀树(10.28修订)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值