java课程设计---俄罗斯方块游戏.doc

  1. 1、本文档共18页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
石家庄职业技术学院 ~ PAGE 1 ~ 石家庄职业技术学院 Java课程设计报告 俄罗斯方块游戏 学生姓名: 学 号: 系 别:信息工程系 专 业:软件技术 班 级: 指导教师: 论文提交时间:2013年x月x日 目录 TOC \o 1-3 \h \z \u 摘要 2 一 游戏设计说明 3 1.1 游戏的设计及实现 3 1.2 游戏流程图设计 4 二 详细设计 4 2.1参数及界面 4 2.2初始化构造方法 5 2.3 初始化地图 6 2.4生成新方块的方法 6 2.5 旋转方法 6 2.6 判断是否合法方法 7 2.7 消行方法 7 2.8 判断挂方法 8 三 测试分析 8 四 设计体会 8 五 游戏代码 10 参考文献: 18 摘要 俄罗斯方块游戏运用java实现具有一定功能的游戏软件,主要功能如下: 控制对象左右下运动; 控制对象旋转; 判断对象是否越界; 判断对象底下是否到底下或固定对象; 判断某一行是否全有对象,然后消一行,加分; 判断游戏进行是否挂了,然后自动重新开始,分数清零。 关键词:java、俄罗斯方块游戏、对象 一 游戏设计说明 1.1 游戏的设计及实现 本游戏主要有以下5个主要方法: 1.MyPanel() 初始化构造方法; 2.newmap() 初始化地图; 3.newboxs() 生成新方块方法; 4.blow() 是否合法方法; 5.gobox() 消行方法; 1.2 游戏流程图设计 开始 开始 初始化构造方法 初始化地图 生成新方块 画围墙 旋转方法 左移方法 右移方法 下落方法 是否合法方法 把当前添加map 画方块方法 消行方法 判断挂方法 二 详细设计 2.1参数及界面 int boxs 方块类型 int scoer 分数 int boxscore 方块状态 int[][] map = new int[13][23] 定义已经放下的方块x=0-11,y=0-21 2.1游戏界面 2.2初始化构造方法 开始,初始化方块、分数、地图等。 public MyPanel() { newboxs(); newmap(); Timer timer = new Timer(1000, new TimerListener()); timer.start(); drawbox(); } 2.3 初始化地图 开始游戏时,初始化参数。 public void newmap() { for (i = 0; i 12; i++) { for (j = 0; j 22; j++) { map[i][j] = 0; } } } 2.4生成新方块的方法 public void newboxs() { boxs = (int) (Math.random() * 1000) % 7; boxscode = (int) (Math.random() * 1000) % 4; x = 4; y = 0; if (gameover(x, y) == 1) { newmap(); drawbox(); score = 0; JOptionPane.showMessageDialog(null, GAME OVER); } } 2.5 旋转方法 通过按↑来控制对象旋转,如果对象没有越界或附近没有固定对象可以旋转,否侧失效。 public void turn() { int tempturnState = boxscode; boxscode = (boxscode + 1) % 4; if (blow(x, y, boxs, boxscode) == 1) { } if (blow(x, y, boxs, boxscode) == 0) { boxscode = tempturnState; } repaint(); } 2.6 判断是否合法方法 用来判断对象是否越界、是否继续下去等。 public int blow(int x, int y, int boxs, int boxscode) { for (int a = 0; a 4; a++) { for (int b = 0; b 4; b++) { if (((shapes[boxs][boxscode][a * 4 + b] == 1) (map[x+ b + 1]

文档评论(0)

ligennv1314 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档