IT第十一天、第十二天、第十三天 - 数组的应用、飞行棋游戏的编写和总结
NIIT第十一天 |
||
上午 |
多维数组 |
1.数组是引用数据类型 |
排序 |
1.冒泡排序法 2.类冒泡排序法 |
|
下午 |
飞行棋游戏 |
1.项目策划 2.项目规则确认 3.项目模块确认 |
晚上 |
1.飞行棋游戏,项目框架的编写 |
|
笔记 |
1.数组也是引用数据类型 2.冒泡排序法:嵌套for循环,外层循环控制冒泡的轮数,内层循环负责将本轮循环的最小值调换到末尾 3.在equals()方法使用上,应该将不会发生空值写在前面,因为在a.equals(b)时,如果a是空值,将不可能调用equals()方法,导致空指针报错,而b为空则不会 |
|
NIIT第十一天、第十二天、第十三天 |
||
飞行棋游戏 |
《游戏设置》 (1)游戏素材 普通格子:【∷】幸运轮盘:【◎】地雷:【※】暂停:【▉】时空隧道:【〓】 玩家角色:【野、辅、力、魔、控】说明:用于在地图上显示玩家的位置图标 (2)游戏规则 1.玩家初始位置在第一个位置处,如:玩家第一次投掷骰子点数为1,则玩家进入到第二个格子(在地图中的索引是1) 2.如果玩家投掷骰子,在最终行进到某位置后,与其他玩家重叠,则其他玩家被踩回到初始位置,即第一位置处(最终位置:是指玩家在经历:点数、幸运轮盘、地雷等后,最后所在的位置) 3.玩家赢的标准:玩家移动后最终落在终点,则玩家赢,游戏结束;如果玩家落在了地图外,则倒退超出终点的格数 4.地图图标说明,以下均为玩家最后停留的位置为判定依据: 【◎】:幸运轮盘,玩法:会额外得到一次投掷骰子的机会,如果点数是1、2、3,则该玩家与此刻最前面的玩家互换位置,如果点数是4、5、6,则玩家再投掷一次骰子,根据点数前进一定位置 【※】:地雷,玩法:玩家会被炸晕,倒退6格,但是玩家不能被炸出地图外 【▉】:坐牢,玩法:玩家会被暂停投掷筛子一轮 【〓】:时空隧道,玩法:玩家会被传送到下一个时空隧道的位置,如果玩家所在时空隧道是最后一个,则玩家什么都不做,停留在该时空隧道 5.其他待定的规则 (3)游戏模块设置 1.游戏会分为两个循环模块:游戏菜单循环模块+轮回投掷点数模块 2.在游戏菜单循环模块中,主要会包含:菜单的显示方法、有些基本的菜单项显示(游戏说明、关于游戏)、游戏退出方法、开始游戏的入口,在本模块中还会确定玩家的数量,即是几人局,因为在存储玩家时,使用的是数组,而数组的长度是不可变的,因此,这个只需要确认一次,玩家之后再来一局的话,就不需要再重新选择了(强制不可再选择) 3.在开始游戏模块中个,主要负责游戏的所有逻辑处理,这里分为主方法、地图打印方法、游戏逻辑判断方法、其他辅助的方法;主方法负责每一轮的控制,地图打印负责实时的显示玩家在地图上的位置,游戏逻辑判断是本游戏的关键,负责玩家所行进格数的判断,及玩家在落点处会经历幸运轮盘、坐牢等玩法,其他辅助方法是为了避免可能在多处存在相同的代码,如:玩家在地图的位置,可以独立写成方法,用于实时的计算 (4)游戏目前的BUG 到目前游戏代码的编写结束和简单的测试,发现以下的缺陷或程序设计的错误: 1.地图的打印或玩家的位置的实时确定:在本程序中,在玩家掷完点数后,不是立即加到玩家的位置信息上,而是尽力虚拟的位置信息,待其他(坐牢、时空隧道等)信息都确认后,再将最后的真是位置加到玩家的位置信息上;经检测,这样会导致玩家“自己踩自己”的情况发生,如:玩家行进6格,结果踩到地雷被炸回6格,因为是采用虚拟的位置,这时系统会判断6格前有玩家的存在,因此发生自己踩自己的情况 解决办法:不采用虚拟的位置,每次掷点结束后即加到玩家的位置信息上,然后进行该位置的判断,继续进行玩家位置信息的加减 2.在玩家获得幸运转盘,并且和最前面的玩家交换时,发生了传递参数的出错,即最前面的玩家被拉到当前玩家的位置,但是由于参数传递错误,当前的玩家行进的格数并不是两者之间的差距,因此导致当前的玩家并没有行进到最前玩家的位置,待修复 3.游戏开始,玩家在选择角色的时候,应该动态的减去被选择的角色,即游戏不允许存在相同的角色 4.特定索引被玩家占用后的恢复问题,这个问题需要修复打印地图的一个缺陷,即不应该在地图信息中存入玩家的信息,而应该在打印地图时,动态的替代 5.比赛结束后,对于比赛的评价功能暂未编写 6.其他暂未发现的BUG (5)游戏源码 http://www.kuaipan.cn/file/id_68788844752798025.htm (6)评价 做项目,学的不是写代码,而是这个项目该如何实现,和在项目中能或学到了什么! |