网站地图| 免费获取|
毕业论文网
  • 网站首页|
  • 论文范文|
  • 论文降重|
  • 职称论文发表|
  • 合作期刊|
  • 论文下载|
  • 计算机论文|
  • 外文翻译|
  • 免费论文|
  • 论文资料|
  • 论文开题报告
搜索

当前位置:毕业论文网 -> 免费论文 -> 计算机论文 -> 免费手机吞吃蛇游戏的设计与开发(五)
计算机论文资料| ASP设计| Delphi| VB设计| JSP设计| ASP.NET设计| VB.NET| java设计| VC| pb| VS| dreamweaver| c#.net| vf| VC++| 计算机论文范文| 论文下载| 自动化论文

免费手机吞吃蛇游戏的设计与开发(五)

最新活动:微信集50个赞就可获取任意一篇钻石会员文档。详情见微信集赞换文档
免费手机吞吃蛇游戏的设计与开发(五)  SnakeScore:用来纪录分数的类。
 SnakeLink:抽象了蛇身上的一段,保存了这段的坐标、方向和所有状态。
 SnakeException:处理异常类。
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 图3:类对应图
4系统实现及核心代码
4.1系统实现
 首先我将介绍下主要用到的七个类:
 一条完整的贪吃蛇是由一段一段组成的。链表中保存的第一个元素是蛇的尾巴段,最后一个元素是蛇的头部段。当蛇运动的时候,它头部段增加一节而尾段减少一节。如果它吃到了食物,尾部段就不减少一节。也就是说,蛇是从头部段开始长的。
  吞吃蛇是由一节一节组成的。因为它经常有一些节连成一条直线形成段,所以这是一种相对有效的方法来保存整个蛇。[X,Y]表示段头部的坐标,然后段的头部开始按照方向向后画若干节。(段的头尾和蛇的头尾不是一个概念)
 吞吃蛇将会在画面中移动寻找食物。如果它吃到食物它将会长一格。如果它碰到边界或者吃到自己将Game Over。
 下面介绍下Snake类中的几个方法:
 public void update(Graphics g)
 这个函数是更新贪吃蛇状态。每次更新都把头部增加一节,尾部减少一节。如果它吃到食物尾部段就不减少一节。看起来就像整只蛇长了一节。
 // 把吞吃蛇头部增加一格
 head = (SnakeLink)worm.lastElement();
 head.increaseLength();
 // 如果没有吃到食物则尾部减少一格
 if (!hasEaten) {
 SnakeLink tail;
 tail = (SnakeLink)worm.firstElement();
 int tailX = tail.getX();
 int tailY = tail.getY();
 // 如果尾部块长度为0就删除
 tail.decreaseLength();
 if (tail.getLength() == 0) {
 worm.removeElement(tail); }
 // 尾部减少一格
 g.setColor(SnakePit.ERASE_COLOUR);
 drawLink(g, tailX, tailY, tailX, tailY, 1);
 } else {
 // 如果吃到食物就不删除尾部
 hasEaten = false; }
 needUpdate = false;
 // 确认是否在边界中
 if (!SnakePit.isInBounds(head.getEndX(), head.getEndY())) {
 // 如果不在,就死了
 throw new SnakeException("over the edge"); }
 headX = (byte)head.getEndX();
 headY = (byte)head.getEndY();
 //贪吃蛇的头部增加一格
 g.setColor(SnakePit.DRAW_COLOUR);
 drawLink(g, headX, headY, headX, headY, 1);
 // 判断是否吃到自己
 for (int i = 0; i < worm.size()-1; i++) {
 sl = (SnakeLink)worm.elementAt(i);
 if (sl.contains(headX, headY)) {
 throw new SnakeException("you ate yourself"); } }
 void drawLink(Graphics g, int x1, int y1, int x2, int y2, int len)
 这个函数用来画蛇的一段,一只完整的蛇是一段一段组成的。
 // 把长度转换成像素长度
 len *= SnakePit.CELL_SIZE;
 // (x1 == x2)说明这一段是垂直的
 if (x1 == x2) {
 // 把x1转成像素长度
 x1 *= SnakePit.CELL_SIZE;
 // (y2 < y1)说明是向上运动
 if (y2 < y1) {
 // 就把头、尾左边交换并转成像素
 y1 = y2 * SnakePit.CELL_SIZE;
 } else {
 // 把y1转成像素
 y1 *= SnakePit.CELL_SIZE; }
 g.fillRect(x1, y1, SnakePit.CELL_SIZE, len);
 } else {
 // 这是水平的一段
 y1 *= SnakePit.CELL_SIZE;
 if (x2 < x1) {
 // 就把头、尾左边交换并转成像素
 x1 = x2 * SnakePit.CELL_SIZE;
 } else {
 x1 *= SnakePit.CELL_SIZE; }
 g.fillRect(x1, y1, len, SnakePit.CELL_SIZE); }
 public void paint(Graphics g)
 画出一只完整的吞吃蛇
 SnakeLink sl;
 int x1, x2, y1, y2;
 int len;
 for (int i = 0; i < worm.size(); i++) {
 // 取出每一段,然后画出这一段,连起来就是一只完整的蛇
 sl = (SnakeLink)worm.elementAt(i);
 x1 = sl.getX(); x2 = sl.getEndX();
 y1 = sl.getY(); y2 = sl.getEndY();
 len = sl.getLength();
 drawLink(g, x1, y1, x2, y2, len); }
4.2 核心代码
 SnakeMain是最主要的类,继承自MIDlet类并实现了CommandListener接口。
 protected void startApp()
 实现MIDlet父类的方法,当开始程序时首先执行这个函数
 

首页 上一页 2 3 4 5 6 7 下一页 尾页 5/7/7

免费手机吞吃蛇游戏的设计与开发(五)由毕业论文网(www.huoyuandh.com)会员上传。
原创论文资料流程 相关论文
上一篇:免费基于细胞自动机的生命活力模.. 下一篇:免费数据包截获技术的研究与实现
推荐论文 本专业最新论文
Tags:手机 游戏 设计 开发 2010-04-01 10:54:19【返回顶部】
精彩推荐
发表论文

联系方式 | 论文说明 | 网站地图 | 免费获取 | 钻石会员 | 硕士论文资料


毕业论文网提供论文范文,论文代发,原创论文资料

本站部分文章来自网友投稿上传,如发现侵犯了您的版权,请联系指出,本站及时确认并删除  E-mail: 17304545@qq.com

Copyright@ 2009-2020 毕业论文网 版权所有