现代软件工程系列 结对编程 两周写好3D 陆战棋

from: http://cid-ba6a52af193f301f.spaces.live.com/blog/cns!BA6A52AF193F301F!122.entry

 

Oh,my pair project

From new Pair(HuangShuo,WangGuan)

签入代码,发送邮件,关上Flex Builder。纠结了差不多两周的Pair Project终于能够有个了结了,此刻跑来码码字,感到甚为解脱。

我们Pair,Wang Guan和我,刚面对这个作业时,基本上是傻眼的,因为除了写点C和Java基本什么也不会了。当我发现了Silverlight网上教程的缺乏又听到有同学说到Flex后,我们选择了Flash+Papervision3D类库来实现我们的3D陆战棋,当然依旧是什么都不会。

我们开始疯狂的Baidu,搜索各种诸如Flash3D,pv3d教程的关键字,然后拿到源码,在机器上试。我们最开始的Pair Programming就是以一起想办法用源代码跑出网上的效果开始的,但是基本上是悲剧的,不断的尝试,却依旧弄不懂怎么在MXML里面显示出那个旋转的立方体。

所有的知识对我们两个都是新的,对它们完全没有概念。我觉得这种情况下的Pair Programming是没法进行了,必须先弄点基础。于是我们开始了分工,WG开始研究陆战棋的规则的3D扩展,我则开始攻关flash 3d图形方面。

庆幸flash的普及度的确很高,教程很多,各种牛人个人主页也多,我开始疯狂看教程,调代码,然后给每一个我能找到的教程作者的email发邮件提问。这样度过了黑暗的好几天,终于慢慢见到光明了,Cube转动起来了,视角拉动起来了,终于有个牛人回我邮件了,最后我们来回了13次邮件。

我掌握了怎么设点,画线以后,我就告诉WG,让他开始设计棋盘,几番争论,大概确定了棋盘的样子。我向WG讲了代码的写法,然后他开始实现棋盘线条的代码。当最后WG改出了一个正确的棋盘时,拖动着那个精致的空间网格,感受着我们自己弄出来的3D效果,真的觉得这是天赐的艺术品啊。

通过不断的看Papervison3d的api,不断的试代码,我终于觉得能开始做自己的项目了。于是我们进行了项目中最关键的一次Pair Programming,我们利用编译课上机时间,在机房里Pair完成了整个项目的类的设计与程序结构的设计。我们一起分析出类,然后找属性,写方法头,开始是WG用键盘,后来我用。一个明显的好处是,写完一条自己不确定的语句,马上可以跟Pair一起缕一缕思路。一下午下来,感觉甚为清爽,因为终于清楚这个项目的做法了。

接下来的工作,又开始分工。我来做图形外观方面的东西,这个容易测试,也不必要两人做。WG则写了很多内部逻辑处理的代码。这时我们开始了项目中用到最多的一种Pair Programming了,也就是WG用他的代码开始跑,我没有写代码带来的主观偏见,很适合出测试样例,代码出了问题,马上我们从比较抽象一点的层面来讨论这个事件的逻辑,最后WG哦的一声,弄明白了,回到代码层次迅速改好代码,继续上面的过程。这时很常见的就是WG坐在电脑前,我站在他身后,走来走去,然后俯身去用鼠标出测试样例;WG则是转身来跟我讨论,完了再转回去改代码。

 

军棋本来棋子就麻烦,加上我们每个棋子都会有三种贴图,在不同的时候显示,来增强用户的体验效果,因此关于换贴图,关于相互吃子的逻辑,我们反复这样Pair了好多次,改了无数bug,也不幸引进了无数bug,最后也只能弄到自己找不到bug,其实可能还是有。由于军棋中很多类似的逻辑代码,我们又用了很多直接暴力枚举的代码,不在一起写代码而在一起debug,避免了在那些逻辑简单打字量大的代码上浪费Pair的时间,我觉得这个方法还是成功的。

现在基本做完了这个作业,回过头来想想,其实还是有很多经验教训的。

一条经验是,学好基本的东西,真的很有用。Java的基础帮助我们基本上没有在ActionScript的语法与用法上花费什么时间。另外一个再次被印证了的经验,搜索引擎是个好东西,有了互联网,似乎真的不能说什么“流行的”技术是不能掌握的——当然还是要花时间的,说不定还要痛苦个几天。

教训更多的体现在总体的设计上。Actionscript是面向对象的,一开始关于flash3d什么都不明白,我们并没有太在意面向对象的分析设计方法的运用,很多地方有些随意,如果最开始能老老实实的画类图,分析用例,也许不会后来突然发现重要的属性取不到,要改很多代码了。再就是一些逻辑,一开始我们并没有很完全的去分析清楚,没有用很优雅的处理方法写程序,后来改代码,只能疯狂的用if,写到最后,有些代码真的改得很难看了。

整个过程,也让我们对一些问题有了亲身的体会。最明显的就是“回归测试”这个东西,我之前一直不太相信它的必要性,这次改行棋逻辑的代码,算是让人体会到了回归测试多么重要,很多次都是改对了一个贴图显示,新毛病又出来了。。。

也不过是两周不到以前,无助的看着Papervision3D 的api,都有些想放弃这作业了,若干天后的现在居然能做出个东西来,还能现在来码码字,真有种熬过黎明前的黑暗的感觉。这项目,我会记住很久了。

最后说点题外话,因为调试的时候程序崩溃,强行关IE,我这vista悲剧的蓝屏了两次,死机了一次;另外,Flash3D现在还不支持硬件加速,全是CPU算出来的,这些天我的CPU也是长时间接近100%,也许哪天Flash3D能发挥点显卡的能力了,我真应该把这个Pair Project再拿出来试试,让CPU看着显卡出力,它自己清闲爽一爽。

posted @   SoftwareTeacher  阅读(2256)  评论(2编辑  收藏  举报
编辑推荐:
· .NET Core GC计划阶段(plan_phase)底层原理浅谈
· .NET开发智能桌面机器人:用.NET IoT库编写驱动控制两个屏幕
· 用纯.NET开发并制作一个智能桌面机器人:从.NET IoT入门开始
· 一个超经典 WinForm,WPF 卡死问题的终极反思
· ASP.NET Core - 日志记录系统(二)
阅读排行:
· 支付宝事故这事儿,凭什么又是程序员背锅?有没有可能是这样的...
· 在线客服系统 QPS 突破 240/秒,连接数突破 4000,日请求数接近1000万次,.NET 多
· C# 开发工具Visual Studio 介绍
· 在 Windows 10 上实现免密码 SSH 登录
· C#中如何使用异步编程
点击右上角即可分享
微信分享提示