范文一:java编写俄罗斯方块(三)
/**
* File: ErsBlocksGame.java
* User: Administrator
* Date: Jan 15, 2003
* Describe: 俄罗斯方块的 Java 实现
*/
import javax.swing.*;
import java.awt.*;
import java.awt.event.*;
/**
* 游戏主类,继承自 JFrame 类,负责游戏的全局控制。
* 内含
* 1, 一个 GameCanvas 画布类的实例引用,
* 2, 一个保存当前活动块 (ErsBlock)实例的引用,
* 3, 一个保存当前控制面板(ControlPanel )实例的引用 ;
*/
public class ErsBlocksGame extends JFrame {
/**
* 每填满一行计多少分
*/
public final static int PER_LINE_SCORE = 100;
/**
* 积多少分以后能升级
*/
public final static int PER_LEVEL_SCORE = PER_LINE_SCORE * 20; /**
* 最大级数是 10级
*/
public final static int MAX_LEVEL = 10;
/**
* 默认级数是 5
*/
public final static int DEFAULT_LEVEL = 5;
private GameCanvas canvas;
private ErsBlock block;
private boolean playing = false;
private ControlPanel ctrlPanel;
private JMenuBar bar = new JMenuBar();
private JMenu
mGame = new JMenu(
mControl = new JMenu(
mWindowStyle = new JMenu(
mInfo = new JMenu(
private JMenuItem
miNewGame = new JMenuItem(
miSetBlockColor = new JMenuItem(
miSetBackColor = new JMenuItem(
miTurnHarder = new JMenuItem(
miTurnEasier = new JMenuItem(
miExit = new JMenuItem(
miPlay = new JMenuItem(
miPause = new JMenuItem(
miResume = new JMenuItem(
miStop = new JMenuItem(
miAuthor = new JMenuItem(
miSourceInfo = new JMenuItem(
private JCheckBoxMenuItem
miAsWindows = new JCheckBoxMenuItem(
miAsMotif = new JCheckBoxMenuItem(
miAsMetal = new JCheckBoxMenuItem(
/**
* 主游戏类的构造函数
* @param title String,窗口标题
*/
public ErsBlocksGame(String title) {
super(title);
setSize(315, 392);
Dimension scrSize = Toolkit.getDefaultToolkit().getScreenSize();
setLocation((scrSize.width - getSize().width) / 2,
(scrSize.height - getSize().height) / 2);
createMenu();
Container container = getContentPane();
container.setLayout(new BorderLayout(6, 0));
canvas = new GameCanvas(20, 12);
container.add(canvas, BorderLayout.CENTER);
container.add(ctrlPanel, BorderLayout.EAST);
addWindowListener(new WindowAdapter() {
public void windowClosing(WindowEvent we) { stopGame();
System.exit(0);
}
});
addComponentListener(new ComponentAdapter() {
public void componentResized(ComponentEvent ce) { canvas.fanning();
}
});
show();
canvas.fanning();
}
/**
* 让游戏“复位”
*/
public void reset() {
ctrlPanel.reset();
canvas.reset();
}
/**
* 判断游戏是否还在进行
* @return boolean, true-还在运行, false-已经停止
*/
public boolean isPlaying() {
return playing;
}
/**
* 得到当前活动的块
* @return ErsBlock, 当前活动块的引用
*/
public ErsBlock getCurBlock() {
return block;
/**
* 得到当前画布
* @return GameCanvas, 当前画布的引用 */
public GameCanvas getCanvas() {
return canvas;
}
/**
* 开始游戏
*/
public void playGame() {
play();
ctrlPanel.setPlayButtonEnable(false); miPlay.setEnabled(false);
ctrlPanel.requestFocus();
}
/**
* 游戏暂停
*/
public void pauseGame() {
if (block != null) block.pauseMove();
ctrlPanel.setPauseButtonLabel(false); miPause.setEnabled(false);
miResume.setEnabled(true);
}
/**
* 让暂停中的游戏继续
*/
public void resumeGame() {
if (block != null) block.resumeMove(); ctrlPanel.setPauseButtonLabel(true); miPause.setEnabled(true);
miResume.setEnabled(false);
ctrlPanel.requestFocus();
}
/**
* 用户停止游戏
public void stopGame() {
playing = false;
if (block != null) block.stopMove();
miPlay.setEnabled(true);
miPause.setEnabled(true);
miResume.setEnabled(false);
ctrlPanel.setPlayButtonEnable(true);
ctrlPanel.setPauseButtonLabel(true);
}
/**
* 得到当前游戏者设置的游戏难度
* @return int, 游戏难度 1-MAX_LEVEL
*/
public int getLevel() {
return ctrlPanel.getLevel();
}
/**
* 让用户设置游戏难度
* @param level int, 游戏难度 1-MAX_LEVEL
*/
public void setLevel(int level) {
if (level < 11="" &&="" level=""> 0) ctrlPanel.setLevel(level); }
/**
* 得到游戏积分
* @return int, 积分。
*/
public int getScore() {
if (canvas != null) return canvas.getScore();
return 0;
}
/**
* 得到自上次升级以来的游戏积分,升级以后,此积分清零
* @return int, 积分。
*/
public int getScoreForLevelUpdate() {
if (canvas != null) return canvas.getScoreForLevelUpdate(); return 0;
}
/**
* 当分数累计到一定的数量时,升一次级
* @return boolean, ture-update successufl, false-update fail */
public boolean levelUpdate() {
int curLevel = getLevel();
if (curLevel < max_level)="">
setLevel(curLevel + 1);
canvas.resetScoreForLevelUpdate();
return true;
}
return false;
}
/**
* 游戏开始
*/
private void play() {
reset();
playing = true;
Thread thread = new Thread(new Game());
thread.start();
}
/**
* 报告游戏结束了
*/
private void reportGameOver() {
JOptionPane.showMessageDialog(this,
}
/**
* 建立并设置窗口菜单
*/
private void createMenu() {
bar.add(mGame);
bar.add(mControl);
bar.add(mWindowStyle);
bar.add(mInfo);
mGame.add(miNewGame);
mGame.addSeparator();
mGame.add(miSetBlockColor);
mGame.addSeparator();
mGame.add(miTurnHarder);
mGame.add(miTurnEasier);
mGame.addSeparator();
mGame.add(miExit);
mControl.add(miPlay);
mControl.add(miPause);
mControl.add(miResume);
mControl.add(miStop);
mWindowStyle.add(miAsWindows);
mWindowStyle.add(miAsMotif);
mWindowStyle.add(miAsMetal);
mInfo.add(miAuthor);
mInfo.add(miSourceInfo);
setJMenuBar(bar);
miPause.setAccelerator(
KeyStroke.getKeyStroke(KeyEvent.VK_P, KeyEvent.CTRL_MASK)); miResume.setAccelerator(KeyStroke.getKeyStroke(KeyEvent.VK_ENTER, 0));
miNewGame.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent ae) {
stopGame();
reset();
setLevel(DEFAULT_LEVEL);
}
});
miSetBlockColor.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent ae) {
Color newFrontColor =
JColorChooser.showDialog(ErsBlocksGame.this,
canvas.setBlockColor(newFrontColor);
}
});
miSetBackColor.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent ae) {
Color newBackColor =
JColorChooser.showDialog(ErsBlocksGame.this,
if (newBackColor != null)
canvas.setBackgroundColor(newBackColor);
}
});
miTurnHarder.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent ae) {
int curLevel = getLevel();
if (curLevel < max_level)="" setlevel(curlevel="" +="">
}
});
miTurnEasier.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent ae) {
int curLevel = getLevel();
if (curLevel > 1) setLevel(curLevel - 1);
}
});
miExit.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent ae) {
System.exit(0);
}
});
miPlay.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent ae) {
playGame();
}
});
miPause.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent ae) {
pauseGame();
}
});
miResume.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent ae) {
resumeGame();
}
});
miStop.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent ae) {
stopGame();
}
});
miAsWindows.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent ae) {
String plaf =
setWindowStyle(plaf);
canvas.fanning();
ctrlPanel.fanning();
miAsWindows.setState(true);
miAsMetal.setState(false);
miAsMotif.setState(false);
}
});
miAsMotif.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent ae) {
String plaf =
canvas.fanning();
ctrlPanel.fanning();
miAsWindows.setState(false);
miAsMetal.setState(false);
miAsMotif.setState(true);
}
});
miAsMetal.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent ae) {
String plaf =
setWindowStyle(plaf);
canvas.fanning();
ctrlPanel.fanning();
miAsWindows.setState(false);
miAsMetal.setState(true);
miAsMotif.setState(false);
}
});
}
/**
* 根据字串设置窗口外观
* @param plaf String, 窗口外观的描述
*/
private void setWindowStyle(String plaf) {
try {
UIManager.setLookAndFeel(plaf);
SwingUtilities.updateComponentTreeUI(this);
} catch (Exception e) {
}
}
/**
* 一轮游戏过程,实现了 Runnable 接口
* 一轮游戏是一个大循环,在这个循环中,每隔 100毫秒,
* 检查游戏中的当前块是否已经到底了,如果没有,
* 就继续等待。如果到底了,就看有没有全填满的行,
* 如果有就删除它,并为游戏者加分,同时随机产生一个
* 新的当前块,让它自动下落。
* 当新产生一个块时,先检查画布最顶上的一行是否已经
* 被占了,如果是,可以判断 Game Over了。
*/
private class Game implements Runnable {
public void run() {
int col = (int) (Math.random() * (canvas.getCols() - 3)),
style = ErsBlock.STYLES[(int) (Math.random() * 7)][(int) (Math.random() * 4)];
while (playing) {
if (block != null) { //第一次循环时, block 为空
if (block.isAlive()) {
try {
Thread.currentThread().sleep(100);
} catch (InterruptedException ie) {
ie.printStackTrace();
}
continue;
}
}
checkFullLine(); //检查是否有全填满的行
if (isGameOver()) { //检查游戏是否应该结束了
miPlay.setEnabled(true);
miPause.setEnabled(true);
miResume.setEnabled(false);
ctrlPanel.setPlayButtonEnable(true);
ctrlPanel.setPauseButtonLabel(true);
reportGameOver();
return;
}
block = new ErsBlock(style, -1, col, getLevel(), canvas);
block.start();
col = (int) (Math.random() * (canvas.getCols() - 3));
style = ErsBlock.STYLES[(int) (Math.random() * 7)][(int) (Math.random() * 4)];
ctrlPanel.setTipStyle(style);
}
}
/**
* 检查画布中是否有全填满的行,如果有就删除之
*/
public void checkFullLine() {
for (int i = 0; i < canvas.getrows();="" i++)="">
int row = -1;
boolean fullLineColorBox = true;
for (int j = 0; j < canvas.getcols();="" j++)="">
if (!canvas.getBox(i, j).isColorBox()) {
fullLineColorBox = false;
break;
}
}
if (fullLineColorBox) {
row = i--;
canvas.removeLine(row);
}
}
}
/**
* 根据最顶行是否被占,判断游戏是否已经结束了。
* @return boolean, true-游戏结束了, false-游戏未结束
*/
private boolean isGameOver() {
for (int i = 0; i < canvas.getcols();="" i++)="">
ErsBox box = canvas.getBox(0, i);
if (box.isColorBox()) return true;
}
return false;
}
}
/**
* 程序入口函数
* @param args String[], 附带的命令行参数
*/
public static void main(String[] args) {
new ErsBlocksGame(
}
范文二:java俄罗斯方块
Java 课程设计
Java 俄罗斯方块
学生姓名
学 号 所 在 系 专业名称 班 级 指导教师
XXX 学校
二0一二年十二月
目录
摘 要、关键字........................................................................................................................... 3
Abstract and Keywords . ................................................................................................................ 4
第一章 绪论 .................................................................................................................................. 5
1.1游戏的历史 . ....................................................................................................................... 5
1.2游戏的意义与内涵 . ........................................................................................................... 5
第二章 可行性研究 . .................................................................................................................... 7
2.1 设计目的 . .......................................................................................................................... 7
2.2 可行性研究前提 . .............................................................................................................. 7
2.3 可行性分析 . ...................................................................................................................... 7
2.4 结论意见 . .......................................................................................................................... 7
第三章 ................................................................................................................................ 需求分析
.......................................................................................................................................................... 8
3.1 引言 . .................................................................................................................................. 8
3.2 游戏需求 . .......................................................................................................................... 8
3.3 软硬件需求 . ...................................................................................................................... 8
3.4 接口控制 . .......................................................................................................................... 8
3.5 方案论证 . .......................................................................................................................... 9
第四章 概要设计........................................................................................................................... 11
4.1 游戏设计分析 . ................................................................................................................ 11
4.2 注意事项 . ........................................................................................................................ 11
4.3 游戏流程图 . .................................................................................................................... 12
第五章 详细设计........................................................................................................................... 13
5.1 总体设计 . ........................................................................................................................ 13
5.2 屏幕信息初始化(paint()) . ...................................................................................... 14
5.3 方块的装载(begin()) . .................................................................................................. 15
5.4 处理键盘事件 . ................................................................................................................ 16
5.5 方块变化(change()) . ................................................................................................ 17
5.6 控制游戏速度与自动下降(run ()) . ........................................................................ 18
5.7 处理到达事件 . ................................................................................................................ 19
5.8 判断满行及消行 . ............................................................................................................ 21
5.9 显示控制 . ........................................................................................................................ 22
5.10 保存方块坐标(save()) . .......................................................................................... 23
5.11 处理游戏结束 . .............................................................................................................. 23
第六章 体会 ................................................................................................................................ 24
参考文献 ........................................................................................................................................ 25
摘 要
在现今电子信息高速发展的时代,电子游戏已经深入人们的日常生活,成为老少皆宜的娱乐方式。但是游戏设计结合了日新月异的技术,在一个产品中整合了复杂的设计、艺术、声音和软件,所以并不是人人皆知。直到今天,在中国从事游戏设计的人仍然很少,但是游戏行业的发展之快,远超如家电、汽车等传统行业,也正因为如此,游戏人才的教育、培养远落后于产业的发展。
俄罗斯方块是个老幼皆宜的小游戏,它实现由四块正方形的色块组成,然后存储在一个数组的四个元素中,计算机随机产生不同七种类型的方块,根据计算机时钟控制它在一定的时间不停的产生,用户根据键盘的四个方向键控制翻转、向左、向右和向下操作,(控制键的实现是由键盘的方向键的事件处理实现)。然后程序根据这七种方块堆叠成各种不同的模型。
论文描述了游戏的历史,开发此游戏的环境,游戏开发的意义。遵循软件工程的知识,从软件问题定义开始,接着进行可行性研究、需求分析、概要设计、详细设计,最后对软件进行了测试,整个开发过程贯穿软件工程的知识体系。
此次设计在Microsoft Windows XP 系统下,以Java 为开发语言,在eclipse 开发平台上进行游戏的设计与实践。
关键词:Java 游戏设计;算法;数组;事件
Abstract
In the current era of rapid development of electronic information,computer games has been deeply People's Daily life, becomethe entertainment for young and old. But game design combined with tomorrow's technology, in a product integrate the complicated design, art, sound and software, so it is not known. Until today, in China engaged in game design are very few, but the game industry development fast, far above such ashome appliances, automobile and other traditional industries, also because of this, the game talent education, training far behind the development of the industry.Tetris is a young and old all appropriate little game, it achieved by four square of color piece, and then stored in an array of the four elements, computer random generation different seven types of party .
Keywords: Java Game design; algorithm; array; events.
第一章 绪论
1.1游戏的历史
游戏开发至今已经有30多年, 在这个短暂的时期里, 随着硬件水平的提高, 游戏开发新技术层出不穷, 经典游戏比比皆是。
1.1.1 从头谈起
真正的电子游戏机产生于20世纪70年代。1971年,麻省理工学院的学生Nolan Bushnell 设计了世界上的第一个业务用游戏机(俗名街机),叫做《电脑空间》。这台游戏机用一台黑白电视机作为显示屏,用一个控制柄作为操纵器,不过由于市场因素这款游戏以失败告终。但是最后他在电子游戏的发展上取得了非凡的成就。
上面介绍的是专用机游戏的历史,而最早的电脑游戏可以追溯到1972年,一个叫Crowther 的工程师用当时最流行的主机――DEC 公司的PDP -10编写一段简单的FORTRAN 程序。在这个程序里,Crowther 设计了一张地图,地图上不规则的分布着陷阱,游戏者必须寻找路径避开陷阱。这个程序被公认为是最早的电脑游戏程序。
1989年,BroderBund 公司的设计师乔丹. 麦克纳根据阿拉伯民族的古老传说《一千零一夜》在Apple 平台上制作了一部动作冒险相结合的电脑游戏――波斯王子。这个游戏获得了第一作,它代表了当时电脑技术的最高水平。
1986年,任天堂公司发售了一款真正的游戏巨作――超级马里奥。 20世纪80年代IBM PC兼容机的出现打破了Apple 公司的垄断地位。 到了20世纪90年代,游戏业才真正成熟起来,成为了一种产业。
由于PC 机价格非常低而且硬件速度越来越快,游戏逐渐成为人们生活中不可缺少的一部分。游戏产业也逐渐发展成熟。
1.1.2 图形硬件的革命
图形硬件的飞速发展是近些年来的事情,部分原因是来自工业方面的压力,例如在军事和医疗方面对于实时图形的需求很强烈,而交互娱乐产业也极大的推动了图形硬件的发展。技术上的因素同样也推动着图形硬件的发展,许多图形算法可以很容易地表达为并行方式,这样硬件执行的效率变得很高。摩乐定律也起了作用,越来越多的晶体管可以集成到一块单独的芯片上。
在所谓的GPU (图形处理器)概念出现以前,特殊的图形硬件只出现在诸如SGI 和E&S系统里面,这些硬件价格太昂贵,不过这些公司提供了第一代基于硬件的顶点变换和纹理映射的解决方案。
1.2游戏的意义与内涵
游戏这个名称一直就存在于每个人的日常生活中, 如猜拳游戏、猜谜游戏、大地游戏、球类游戏等, 林林总总, 不胜枚举, 甚至于有些流行歌曲把人生也比喻为游戏, 好比“一场游戏一场梦” 。因此, 游戏对于现代人的成长历程, 绝对是一个不可或缺的重要角色。
1.2.1 游戏的组成要素
“游戏”, 最简单的定义, 就是一种供人们娱乐休闲的快乐元素。从更专业的角度形容, “游戏”是具有特定行为模式、规则条件、身心娱乐及输赢的一种行为表现。这种行为表现具备以下4个要素。
行为模式: “游戏”最简单的要素就是游戏有特定的流程模式, 这种流程模式贯穿于整个游戏的行为, 用户必须依照它的模式流程来执行。倘若一种游戏没有了特定的行为模式, 那么就没有执行的行为;在没有执行的行为之后, 这个游戏也玩不下去了。举个例子来说, 如果猜拳游戏没有了剪刀、石头、布等行为模式, 那么这还能叫做“猜拳游戏” 吗? 所以不管游戏的流程有多么复杂还是多么简单, 一定要有特定的行为模式。
条件规则:当游戏有了一定的行为模式后, 接着就必须制定出一系列的条件规则。简单来说, 这些游戏的条件规则就是大家必须去遵守的游戏行为守则, 只要是大家一致以为的游戏行为, 在游戏中, 玩家就必须遵守它, 如果不遵守这种游戏行为, 那么就失去了公平性。如同一种简单的球赛, 打球的英文解释可以用PLAY GAME 来加以说明, 按照英文字面上的解释, 它就是执行游戏的行为, 而球赛必须有一定的条件规则, 并且参与者都要必须去遵守它, 不能遵守它就叫作“犯规”。所以不管是什么游戏, 它都会具备一组规则条件, 在游戏进行的时候才会有足够的公平性。
娱乐身心:一种游戏所带来的娱乐性, 关键就在于为玩家所带来的刺激感, 这也是游戏的精华所在。简单来说, 不管是很多人玩的游戏, 还是一个人玩的单机游戏, 游戏本身就会存在它的娱乐和刺激性, 使得玩家们想要去玩它。
输赢:其实针对游戏而言, 输赢是所有游戏的最终目的。一个没有输赢的游戏,也就没有了它存在的意义,如同我们常常接触到的猜拳游戏,说穿了最终目的就是为了分出胜负而己。
一般而言,游戏又可以分为动态和静态两种形态。动态的游戏必须配合肢体动作,如猜拳游戏;而静态游戏则是较偏向思考的行为,如同纸上游戏。然而不管是动态或是静态游戏,只要具备上述4项组成要素,都可以将它称为“游戏”。
第二章 可行性研究
2.1 设计目的
综合运用在校期间所学理论知识和技能,设计开发俄罗斯方块,使自己熟悉应用系统的开发过程,培养独立思考能力,检验学习效果和动手能力,提高工程实践能力,为将来实际工作打下坚实的基础。
2.2 可行性研究前提
基本需求:系统开发的总体任务是实现游戏的可操作性、美观性、及时性。 开发过程遵循软件工程规范,可采用结构化或面向对象分析设计方法。主要实现windows 的GUI 程序开发,对游戏中的图形图像进行键盘控制。游戏者可以通过上下左右键来对游戏进行操作。
主要开发目标:采用结构化设计方法,开发出一个可操作性、美观性、及时性的游戏,实现windows 的GUI 程序开发, 并通过此次软件开发过程全面提高自身的综合素质。
条件假定和限制:由于本软件目前是我的初次版本,可能还存在一些问题。如果该软件提高版本,本软件需要根据游戏者的要求进行进一步的修改。
可行性研究所采用的方法和步骤:通过研究分析俄罗斯方块所具备的能力及实现的方法、确定主体结构。利用现阶段我所能达到的能力,以最简洁、最容易的办法,边开发边测试边修改,实现一个初级游戏软件。
评价尺度:由于本软件是一个初级产品,对其要求不是太苛刻,所以能够达到俄罗斯游戏的一般功能即可。
2.3 可行性分析
管理可行性: 该游戏软件为首次开发,目的只为提高工作自身素质和检查自学Java 的效果,用 Java3.0软件编写后在Applet 管理器中运行简单明了,所有功能均根据基本需求所做。便于管理,所以在这方面是可以实现的。
经济可行性:由于本游戏的主要背景是毕业课程设计,不注重直接的经济效益和其后的发展方向,只在注重自身水平和能力的提高,对自身的经济要求也不高,只要有一台能运行JAVA3.0软件的电脑便可,所以不用考虑到经济问题。
技术可行性:可用与本游戏的编程语言有VB ,Java ,Delphi 等,考虑到用于编写程序的困难度,和对语言的了解程度,选择JAVA 作为编程语言。需要对变量定义、变量初始化、界面初始化、游戏初始化、然后进入游戏、处理游戏过程中的各种操作。
社会可行性:本游戏的开发作为毕业课程设计以巩固先前所学的知识,以个人为单位,仅供个人平常娱乐所用,无须考虑有可能造成的社会影响,不用考虑到法律、版权等的社会因素,所以在这方面是完全可行的。
2.4 结论意见
综上所述,本游戏软件的技术成熟、完备。各方面均无重大问题,因此本游戏软件可开始着手编写。
第三章 需求分析
3.1 引言
对软件需求完全理解对于软件开发工作的成功是至关重要的,需求说明的任务是发现、规范的过程,有益于提高软件开发过程中的能见度,便于对软件开发过程中的控制与管理,便于采用工程方法开发软件,提高软件的质量,便于开发人员、维护人员、管理人员之间的交流、协作,并作为工作成果的原始依据,并且在向潜在用户传递软件功能、性能需求,使其能够判断该软件是否与自己的需求相关。
3.2 游戏需求
随机给出不同的形状(长条形、Z 字形、反Z 形、田字形、7字形、反7形、T 字型)下落填充给定的区域,若填满一条便消掉,记分,当达到一定的分数时,过关,设置三关,每关方块下落的速度不同,若在游戏中各形状填满了给定区域,为输者。游戏功能要求如下:
游戏界面需求:良好的用户界面,有关数显示和分数显示。让方块在一定的区域内运动和变形, 该区域用一种颜色表明, 既用一种颜色作为背景, 最好设为黑色。还需用另一种颜色把黑色围起来, 宽度适中,要实现美感。
游戏形状(方块) 需求:良好的方块形状设计,绘制七种常见的基本图形(长条形、Z 字形、反Z 形、田字形、7字形、反7形、T 字型),各个方块要能实现它的变形,可设为顺时针或逆时针变形,一般为逆时针。
键盘处理事件:方块下落时,可通过键盘方向键(上、下、左、右键)对该方块进行向上(变形), 向下(加速)、向左、向右移动。
显示需求:当不同的方块填满一行时可以消行,剩余方块向下移动并统计分数。当达到一定的分数时过关。设置三关,每关方块下落的速度不同。
3.4 接口控制
本软件需求通过键盘进行操作,在Windows 的操作系统下,利用键盘的上、下、左、右键对方块进行移动变形,要使用键盘的接口事件。
3.5 方案论证
学校现已开设的课程有C 语言、VB 、C++,自己本身自学了Java ,就目前了解,可用Jave ,VB 和C++编写俄罗斯方块程序。
3.5.1 VB的优点
VB 是完全中文化的环境使用,语句生成器和快速提示帮助使用户不必记忆成千上万的属性和方法,在较短的时间内就能开发出功能强大的应用程序。Internet 应用程序的开发功能更加强大和容易,支持动态HTML 技术的应用程序。种类繁多,功能强大的多媒体控件,能帮助用户在较短的时间内用较少的语句编写出图文声像并茂的多媒体程序。能对多种数据库进行读写操作。它所提供的可视化数据管理器能帮助用户构造多种类型的数据库。用户自定义类型可以作为参数或作为公共属性和方法的返回值,函数可以返回数组变量,动态数组可以赋值,文件系统对象,按名调用,增强创建对象函数和StrConv 函数。应用程序安装向导能帮助用户自动生成具有一定功能的应用程序,加快了程序的开发速度。
3.5.2 C++的优点
C++是对C 语言的扩充,扩充的绝大部分来自著名语言中的最佳特性:从SIMULA 67中吸取了类,从ALGOL 68中吸取了运算符一名多用、引用和在分程序中任何地方说明变量,综合了Ada 的类属和Clu 的模块特点,从BCPL 中吸取异常处理,从BCPL 中吸取了用//表示注释。
C++保持了C 的紧凑、灵活、高效和易移植强的优点,它对数据抽象的支持主要在于类概念和机制,对面向对象风范的支持主要通过虚拟函数。C++既有数据抽象和面向对象能力,语言运行性能高多,加上C 语言的普及,而从C 至C++的过渡较为平滑,以及C++与C 的兼容程度可使数据巨大的C 程序能方便地在C++环境中重用。
尽管C++当初的设计本意是帮助管理大型程序,但其用途并不仅限于此。C++的面向对象的特性可有效地用于实际的程序设计工作。C++常常用于设计编辑器、数据库、个人文件系统以及通讯程序等。而且,由于C++共享C 的效率,所以用C++可以构成很多高性能的系统软件。
3.5.3 Java的优点
Java 是定义位于网络计算的计算机语言,它几乎所有的特点也是围绕着这一中心展开的并为之服务的,这些特点使得Java 语言特别适全于用来开发网络上的应用程序;另外,作为一种面世较晚的语言,Java 也集中体现和充分利用了若于当代软件技术新成果,如面向对象、多线程等,这些也都在它的特点中有所反映。
3.5.3.1 开台无关性
如前所述,Java 语言独特的运行机制使得它具有良好的二进制级的可移植性,利用Java ,开发人员可以编写出与具体平台无关、普遍适用的应用程序,大大降低了开发、维护和管理的开销。
3.5.3.2 面向对象
Java 是面向对象的编程语言。面向对象技术较好地适应了当今软件开发过程 中新出现的种种传统面向过程语言所不能处理的问题,包括软件开发的规模扩
大、升级加快、维护量增大经及开发分工日趋细化、专业化和标准化等,是一种迅速成熟、推广的软件开发方法。面向对象技术的核心是以更接近人类思维的方式建立计算机逻辑模型,它利用类和对象的机制将数据与其上的操作封装在一起,并通过统一的接口与外界交互,使反映现实世界实体的各个类在程序中能够独立、自治、继承;这种方法非常有利于提高程序的可维护性和可重用性,大大提高了开发效率和程序的可管理性,使得面向过程语言难于操纵的大规模软件可以很方便的创建、使用和维护。
3.5.3.3 安全稳定
对网络上应用程序的另一个需求是较高的安全可靠性。用户通过网络获取并 在本地运行的应用程序必须是可依赖的,不会充当病毒或其他恶意操作的传播者而攻击用户本地的资源;同时它还应该是稳定的,轻易不会产生死机等错误,使得用户乐于使用。
3.5.3.4 支持多线程
多线程是当今软件技术的又一重要成果,已成功应用在操作系统、应用开发 等多个领域。多程序技术允许同一个程序有两个执行线索,即同时做两件事情,满足了一些复杂软件的需求。Java 不但内置多线程功能,而且提供语言级的多线程支持,即定义了一些用于建立、管理多线程的类和方法,使得开发具有多线程功能的程序变得简单、容易和有效。
3.5.3.5 简单易学
如前所述,衍生自C++的Java 语言,出于安全稳定性的考虑,去除了C++中 不容不得易理解和掌握的部分,如最典型的指针操作等,降低了学习的难度;同时 Java还有一个特点就是它的基本语法部分与C 语言几乎一模一样。这样,无论是学过Java 再学C ,还是已经掌握了C 语言再业学Java ,都会感到易于入门。
3.5.4方案选择
面向对象是一种认识世界的方法,是一种程序设计方法。面向对象的观点认为,客观世界是由各种各样的实体,即对象组成的。每种对象都有自己的内部状态和运动规律,不同对象间的相互联系和相互作用就构成了各种不同的系统,并进而构成整个客观世界。按照这样的思想设计程序,就是面向对象的程序设计。
面向对象的程序设计吸取了结构化程序设计的先进思想,并把它们同几个支持用户用新方法进行程序设计的有力概念结合在一起。
所有面向对象的程序设计语言一般都包含三个概念:封装、多态性和继承性。 这种方法要求语言必须具备抽象、封装、继承和多态性这几个关键要素。 面向对象的程序设计,是通过数据和代码建立分块的内存区域,以便提供对程序进行模块化的一种程序设计方法,这些模块可以被用作样板,在需要时再建立其副本。
C++和Java 在面向对象这方面比VB 要强,所以我排除了用VB 做的可能性。但是C++为了与C 语言兼容,其是包含了些面向过程的成分;Java 除了C++中非面向过程的部分,其程序编写过程就是设计、实现类,定义其属性、行为的过程。还有Java 特有的“沙箱”机制是其安全性的保障,同时它去除了C++中易造成的错误指针,增加了自动内存管理等措施,保证了Java 程序运行的可靠性。
所以经过再三比较了三种语言后,决定采用Java 语言编写俄罗斯方块。
第四章 概要设计
4.1 游戏设计分析
Java 为纯面向对象(Object-Oriented ,OO )的程序语言,它的诸多优点在此就不作论述了。从面向对象的观念出发,本程序可分为以下几个对象:
● 方块类型数据 ● 程序运算逻辑 ● 绘图
● 显示平台
分析对象的技巧在于它的重复利用及维护效率。试想,若要把设计出来的程序在不同的显示平台上执行,就要作大幅度的更动甚至重写,这样就失去了面向对象属性,所以在本程序分析时将不变与易变的因素分别做成对象,如方块类型数据及程序运算逻辑就是不变的项目,而绘图及显示平台会因为环境而有所不同属于易变的项目。
1. 方块类型数据
方块类型虽然运送不同,但状态与行为都是相同的,如下表所示。
2. 程序运逻辑
程序中逻辑运算通常只作数值的运算及分析,如方块移动时阻碍判断、方块满行判断、删除满行、方块移动、定时器、事件响应等。
3. 绘图
绘图会因为显示平的不同而有所不同,例如在单机与手机上的显示环境就不相同,或显示效果会有所不同,例如方块的样式作修正时,即可以产生出不同的显示效果。
4. 显示平台
“可移植性高”是Java 的属性之一,Java 的应用涉及许多领域,如手机、单机程序及浏览器等,不同的平台对于它的设定不尽相同,若将显示平**立为一个类,将有助于主程序的完整性及移植程序的快速性。
4.2 注意事项
游戏在设计时除了将程序切割成多个对象外,在游戏的逻辑运算上应尽可能做到弹性化。所谓弹性就是方块地图的长与宽应该可以用参数来改变。
4.3 游戏流程图
顶层图
图1
图 2
第五章 详细设计
5.1 总体设计
程序流程图
5.2 屏幕信息初始化(paint())
游戏开关控制图(在panint()内实现)
paint()方法是绘制游戏地图的方法,先指明是什么颜色,再定义颜色范围,本游戏是先用红色画了一个大的实心矩形框,再在红色中画一个比红色小一点的黑色实心矩形框,这样黑色的框便会把原来红色的部分遮掉,让人看起来就是黑色的框周围围了一圈红色。黑色矩形框为后面的游戏方块活动的范围。该方法中还设置了一把锁,是游戏是否开始的锁,如果还没开始则会在黑色框中提示游戏开始的方法。如果游戏锁解开,会调用gameinit()方法。Paint()方法还可在前面加re ,即repaint(),该方法可以将整个屏幕清屏,再重新画一个游戏界面。 也由于如此,如果在方块向下运动中,每运动一行都要掉用一次repaint()方法的话,屏幕便会闪烁的很快,这样就游戏的可观性来说很不好。所以我另外定义了一个制作图形变量(Graphics gg) ,这个变量只要被激活(gg = getGraphics()),就可以拥有绘图的所有功能。同时也定义了另外一个绘图的方法(xian()),这样就减少重新绘图而造成的屏幕闪烁问题。有关xian()方法的使用,将在后面的显示控制中提到。
gameinit()方法是游戏初始化,用双重循环把定义游戏地图的二维数组screen[][]赋为false ,即清空游戏地图中的所有方块。也把每行方块数初始化,分数初始化,打开游戏地图清屏开关,再调用装载游戏方块begin()方法。
5.3 方块的装载(begin())
方块装载(begin()方法)
定义一个随机变量, 然后调用随机函数(rand=(int)(Math.random()*7)+1), 所取得的随机数在1到7之间,用这7个数字表示7中常见的方块,并从7种方块中随机抽取图形。每一种方块都是由两个一维数组(x,y) 表示的,其中一个用来保存方块所在行,另一个数组用来保存方块所在列,这样有利于方块在屏幕上准确而有活动的定位。所有7种图形都是在三行三列的地图中研究后给出的坐标,给出的坐标也是方块在游戏地图中靠最顶行的坐标。这就好象方块存在于一个三行三列大小的图形中而够成的一张图片。图片的运动也就是方块的运动,这样,要实现方块的变形,就要在三行三列的图形中定义一个最左上角的基点,方块运动,基点也跟着运动。基点坐标在加载方块是加载,基点的存储空间在加载每个方块数组的最后定义。这样使得方块在游戏地图中的每一个地方都可以变形。也不会因为变形而方块在游戏地图中的变动很厉害,出现瞬移的现象。图形坐标装载完后,先判断在方块的下一行是否已有方块,如果有则说明方块以到达游戏地图的顶端,游戏将结束。没有则先把方块坐标保存,这是为了在方块向下移动的时候在它的后面不会有虚假的方块,因为方块向下运动,记录的是新一行的方块坐标,但旧一行的没有消掉,所以要先旧方块的坐标保存起来,搽掉旧方块再显示方块。这样也会减少屏幕的闪烁问题。
5.4 处理键盘事件
键盘事件功能图(KeyDown())
keyDown()是处理按键的事件,刚开始运行程序时,游戏还没有开始,这时除S 键(解键盘锁的键)是有用外,其他的键都给锁住,这样可以避免键盘过早的控制游戏。在判断是否在S 键的语句中还加了对游戏锁取反并判断是否为真的语句,两个语句同时成立时,才会解开游戏锁,程序开始时,游戏还没有开始,游戏锁是关的,但是取反后它就是真的,所以只要按下S 键后,两个语句都成立。这样做是为了在游戏开始时再按下S 键,游戏不会重新开始,即游戏开始后,S
键就没有用了。按下S 键后,游戏锁才被解开,键盘也被解开。每当有按键,也就是方块要产生变化时,先保存方块的坐标,便于清理旧方块,显示新方块。当方块要进行上(变形)、下、左、右变化时,先对方块将要移动到的位置进行判断,判断是否有障碍,有则保持原来的位置不变,没有则根据所按的键执行相关的操作。再把方块的位置显示在屏幕上。方块的移动其实也只是对行或列坐标的增减而己。
例 向左键的障碍物判断及处理: for(i=0;i<>
if (x[i]<1 ||="">1>
//判断是否到达屏幕最左边或要到的左边有没有方块
break;
if(i==4) // 当无障碍时 for(i=0;i<>
x[i]-=1; //方块向左移动 break;
5.5 方块变化(change())
当按下向上键时,将会执行方块变化事件(change())。常见的方块有7种(长条形、Z 字形、反Z 形、田字形、7字形、反7形、T 字型) ,所有图形都是用两个一维数组来统计它的横坐标和纵坐标,每个方块有4种不同的变化形状,所以我对7种图形都做要详细的研究和分析,得到了一个方块逆时针旋转结论:
x1=y; y1=2-x;
其中x,y 代表方块变化前的坐标,x1,y1代表方块变化后的坐标,这样使方块成功的变化。这里的变量和游戏中的无关,只用于此处说明。但田字形的方块用上面的变化规则时,方块晃动的厉害,所以上面的规则只能作用与其他6种图形。因为田字形本身的变化也是原来的图形,有变化和没变化一样,可以对它不作改变,即按下向上键时,不对田字型的做改变。这样就可以解决田字形变化的问题。还有两个Z 字形和一字形变化不是很规范,但没有太大的问题,所以为了避免麻烦我就没有处理这些问题。当图形要改变时,它将先判断变化后的位置是否没有任何小方块,或是否已到达游戏地图的边缘,如果有小方块或到达边缘,则不执行方块变化,这也是一种障碍物的判断;如果没有的才处理方块变化。至于处理障碍物的方式与处理方块向左运动的方式差不多,所以在这不做详细的解说。
5.6 控制游戏速度与自动下降(run ())
为了使每一关中每个方块的下降速度的一致性,Thread.sleep(1200-pass*300)是一个固定的数字,每次循环时都会根据关数(pass )的级别决定所增加的数字大小。可以说控制游戏的关数,也就是控制速度,也可以说是对休眠时间长短的控制,休眠时间越短则游戏关数越高,游戏速度就越快。因为这个数字就是控制方块在每行的休眠时间, 不会受游戏者按键的影响。
Thread.sleep ()是游戏休眠,括号中的数字将决定休眠的时间,也是方 块在此行停留的时间。Run()是当游戏没有任何操作,就会返回它进行循环运行。如果游戏还没开始那么在这里下降功能将被锁定,因为游戏都没有开始,在这里处理自动下降有点说不过去。如果游戏开始这个功能马上会被开启,正因为有自动向下运行的功能,那么也少不了障碍物的判断和是否到达底行的判断,只要符全其中之一,就可以调用到达事件(reach())来处理。否则就为了清除旧图而保存方块当前坐标,然后方块再向下移动一行。方块向下运动时,先保存旧方块的坐标,记录新的方块坐标,然后用黑色把旧方块覆盖,再画出新方块的图形,由于电脑处理速度快,在视觉效果上就像方块向下运动了一行一样。
5.7 处理到达事件
处理方块到达图
reach()事件是在方块自动下降或是按键下降时, 当方块新坐标遇到障碍或是到达底部时调用此事件。到达事件是将方块所在位置上的点,用一个屏幕数组记录下来,成为以后的障碍物。
在这里还有一点要做详细的解说,屏幕是如何实现,为什么方块能够堆积之类的问题:
屏幕采用的是一个二维的逻辑数组,主要描述第几行第几列上是否存在方块,如果存在则这个逻辑变量的值将会为真,否则为假。这个数组也能描述哪行哪列上存在着小方块,能描述方块在屏幕上的准确位置。但在屏幕上显示方块, 是通过这个数组和显示里面的控制得到屏幕上的显示信息。
到达事件一触动就证明了方块到达目的地,那么就将方块进行堆积。 方块的堆积实现如下: for(j=0;j<4;j++)>4;j++)>
screen[x[j]][y[j]]=true;//将到达的活动方块赋给屏幕控制数组 row[x[j]]++;//对活动方块所在行的数量加1 }
循环是因为每个方块都是有四个小方块组合而成的,之前有过说明。 screen[x[j]][y[j]]=true只是将每个小方块所在位置记录下来,使方块能够堆
积在一起。row[y[j]]++统计小方块所在行的数目,给下一节的判断满行提供条件。可能会问到方块下降时会不会把这些己经堆积在屏幕上的图形清除,关于这方面我在方块发生任何运动之前都会做一次障碍物判断,也就是判断它即将要到达的那一点是否有小方块的存在(那一点的坐标是否为真),存在则不移动,不存在才会移动。所以它不会清除己存在于屏幕上的任何图形。
统计分数:在消行处理里面有一个专门用来统计消行数的变量,然后根据变 量的值决定分数的多少,程序统计分数是:消一行得10分,同时消4行得40分,没有定义因为同时消多行而得多分数的情况。如果总分数达到过关条件就过关,改变游戏速度,游戏初始化,开启新的一关,然后再加载方块。没有达到过关分数或者没有满行,则加载下一个方块继续游戏。
5.8 判断满行及消行
判断满行及消行图
满行判断及消行是到达事件中的一部分, 是方块堆积, 并对每个小方块所在行个数统计后, 利用循环语句从屏幕最底行依次向上对有方块的每一行进行判断, 判断是不是空行,如果那一行是空行则证明它以上的所有行都将不会有方块,也就不必要向上查找了。不是则判断当前行是否满行的,如果满行则看有个连续几个满行的在一起。然后再判断是否有行满的情况,否的话就继续检查上一行。不然就进行消行处理及方块下移。最后再向上查找满行情况直到本行为空时为止。
消行及方块下移:当有行满时,则说明需要消行,有消行那么所有方块则要下移。当本行满时,则以间隔为1向上查找,当遇到所查找的行也是满行,那么它的间隔自增1,然后继续向上查找,直到那一行不是满行的情况,则将此行所有数据信息移到本行,以后本行以上的每行都会以这个间隔去判断它将获得的那行数据,可以则继承,不然和上述一样操作。如果将获得的那行数据为空行,则只须对本行的数据清空即可,那么方块下移也就完成。
例 处理消行及方块下移 j=18;
while (row[j]!=0) {
while (row[j-k]==12) k++;//向上查找不是满行的数据,k 是统计间隔数 if (k>0)//有消行,使屏幕方块向下移动 {
for(i=0;i<>
screen[i][j]=screen[i][j-k]; row[j]=row[j-k]; }
j--;//向上推动一行 }
5.9 显示控制
方块组成:小方块是由三个不同颜色的正方形方框组成, 其中正方形有实心 的也有空心的, 这样使得方块变得好看点能看出堆积的视觉效果. 每个图形是由四个小方块拼凑而成的。显示控制时先看之前是否发生过消行事件,如果发生了
清除屏幕所有方块、成绩和关数,全部重新绘置,使得消行视觉化。然后再清除旧图形,绘制新图形。其实消除屏幕只是将屏幕重新画一次而己,清除成绩和关数,也只是在有显示成绩和关数的地方画一个白色的框而己。重新绘置新点,就是从下向上判断看哪些地方有方块的就得新画一个小方块,没有的不画。
5.10 保存方块坐标(save())
save()方法将活动方块的之前坐标保存,在方块移动后,它就起到清除 旧图形的重要作用,就是如些使显示界面不用不断的刷新,然后再去绘制新图,这样可以使得屏幕不会变得太闪烁。
5.11 处理游戏结束
destroy()来处理游戏结束, ● 关闭游戏开关 ● 关数初始化 ● 返回到开始界面
● 调用repaint()使屏幕初始化
第六章 体会
在做JAVA 设计中,我对Java 游戏开发只是停留在理论知识的水平上,是“纸上谈兵”,缺乏实际的软件开发经验。这次通过做这次设计,我完成了俄罗斯游戏的软件开发任务。在整个开发过程中遇到了很多问题,如方块的装载和变形、屏幕太闪烁的问题、满行判断及消行的处理。但最终都被我一一解决,对其中比较主要的几点体会总结如下。
第一,为了熟悉俄罗斯方块的相关运作,我经常在玩街机和游戏机上的俄罗斯方块,慢慢去发现它所有的功能,然后再思考和查阅资料进行分析,经过逐步的设计与反复的修改论证,才完成了整个游戏的开发。
第二,完成了从“小而全”,到“全而精”的转变。设计过程中, 经常会遇到困难, 我学会通过反复思考和测试,然后找出自己的错误并加以改正,再进行下一个步骤。这个程序就是在这样反复过程序中一点一点的完成的。完成之后再来优化整个程序。
第三,作是一个不断学习新鲜事物的过程,从设计初的不懂到最后能够顺利完成,我体会到在实践中学习的重要性,这对于将来我走上工作岗位具有重要意义。
第四,通过这次设计使我对Java 这门课程有了一定的了解,也对我今后的就业之路打下了一定的基础。
经过不断努力, 这次设计内容已经基本上完成了。回顾这个设计过程, 我学到了许多书本上没有学到的知识。通过这次自己制作的软件, 丰富了自己的实践技能, 扩展了本专业的知识面, 使我受益非浅, 同时也体验到了搞软件开发的困难度。在这次设计的同时, 我又从中学到了许多东西。但由于我对这样的软件开发还只是一个开始,了解的不多,这其中或许还有很多的不足,有些模块做得不是很好,有些功能还不能够完全的实现,如不能把要装载的方块提前显示出来。因此做得不是很好,界面的设计及整体的布局还比较简单,没有突出特色出来,这也可能是我这个系统的不足之处。
总的来说,我自认为还是比较成功的,这也是我在大学以来完成的一个比较全面的实际例子。在这次努力中,我查阅了大量的资料,对Java 有了一点初步的认识,对于软件工程这些辅助性的教材也巩固了不少,为我这次的设计提供了很大的帮助,锻炼了我的能力。
参考文献
[1].齐治昌、谭庆平、宁洪编著,《软件工程》 北京:高等教育出版社 1997年7月
[2].印旻编著,《java 语言与面向对象程序设计》 北京:清华大学出版社 2000年9月
[3].荣钦科技编著,《Java 2 游戏设计》 北京:清华大学出版社 2004年11月
[4].朱福喜编著,《Java 程序设计技巧与开发实例》 北京:人民邮电出版社 2004年2月
范文三:java编写俄罗斯方块(二)
/**
* File: ErsBlock.java
* User: Administrator
* Date: Jan 15, 2003
* Describe: ?í?T?????éμ? Java êμ??
*/
/**
* ?éàà???ì?D×????ìàà??Thread??
* óé 4 * 4 ????????ErsBox?????éò????é??
* ?????éμ?ò?????????????D?μè
*/
class ErsBlock extends Thread {
/**
* ò????é??μ?DDêyê?4DD
*/
public final static int BOXES_ROWS = 4;
/**
* ò????é??μ?áDêyê?4áD
*/
public final static int BOXES_COLS = 4;
/**
* è?éy??????????μ?òò×ó???ü?a×?oó????????μ??ù?è?à???üò???
*/
public final static int LEVEL_FLATNESS_GENE = 3;
/**
* ?à?üμ?á??????????é??????ò?DDμ?ê??????e?a?àéù(oá??)
*/
public final static int BETWEEN_LEVELS_DEGRESS_TIME = 50;
/**
* ???éμ??ùê?êy???a7
*/
private final static int BLOCK_KIND_NUMBER = 7;
/**
* ??ò????ùê?μ????éμ???×a×?ì???àà?a4
*/
private final static int BLOCK_STATUS_NUMBER = 4;
/**
* ???e??ó???7????Díμ?28??×?ì?
*/
public final static int[][] STYLES = {// ??28??×?ì?
{0x0f00, 0x4444, 0x0f00, 0x4444}, // ??ì?Díμ?????×?ì?
{0x04e0, 0x0464, 0x00e4, 0x04c4}, // 'T'Díμ?????×?ì?
{0x4620, 0x6c00, 0x4620, 0x6c00}, // ??'Z'Díμ?????×?ì?
{0x2640, 0xc600, 0x2640, 0xc600}, // 'Z'Díμ?????×?ì?
{0x6220, 0x1700, 0x2230, 0x0740}, // '7'Díμ?????×?ì?
{0x6440, 0x0e20, 0x44c0, 0x8e00}, // ??'7'Díμ?????×?ì?
{0x0660, 0x0660, 0x0660, 0x0660}, // ???éμ?????×?ì?
};
private GameCanvas canvas;
private ErsBox[][] boxes = new ErsBox[BOXES_ROWS][BOXES_COLS];
private int style, y, x, level;
private boolean pausing = false, moving = true;
/**
* ???ìo?êy???úéúò???ì???μ??é
* @param style ?éμ??ùê?????ó?STYLESμ?28???μ?Dμ?ò???
* @param y ?eê???????×óé????úcanvas?Dμ?×??êDD
* @param x ?eê???????×óé????úcanvas?Dμ?×??êáD
* @param level ó???μè?????????éμ??????ù?è
* @param canvas ?,??
*/
public ErsBlock(int style, int y, int x, int level, GameCanvas canvas)
{
this.style = style;
this.y = y;
this.x = x;
this.level = level;
this.canvas = canvas;
int key = 0x8000;
for (int i = 0; i < boxes.length;="" i++)="" {="">
for (int j = 0; j < boxes[i].length;="" j++)="" {="">
boolean isColor = ((style & key) != 0);
boxes[i][j] = new ErsBox(isColor);
key >>= 1;
}
}
display();
}
/**
* ???ìààμ?run()o?êy???????????é????μ??é???ü?ù????
*/
public void run() {
while (moving) {
try {
sleep(BETWEEN_LEVELS_DEGRESS_TIME
* (ErsBlocksGame.MAX_LEVEL - level +
LEVEL_FLATNESS_GENE));
} catch (InterruptedException ie) {
ie.printStackTrace();
}
//oó??μ?movingê??íê??úμè?yμ?100oá??????moving????????
if (!pausing) moving = (moveTo(y + 1, x) && moving);
}
}
/**
* ?é?ò×óò???ò???
*/
public void moveLeft() {
moveTo(y, x - 1);
}
/**
* ?é?òóòò???ò???
*/
public void moveRight() {
moveTo(y, x + 1);
}
/**
* ?é?ò????ò???
*/
public void moveDown() {
moveTo(y + 1, x);
}
/**
* ?é??Dí
*/
public void turnNext() {
for (int i = 0; i < block_kind_number;="" i++)="" {="">
for (int j = 0; j < block_status_number;="" j++)="" {="">
if (STYLES[i][j] == style) {
int newStyle = STYLES[i][(j + 1) % BLOCK_STATUS_NUMBER];
turnTo(newStyle);
return;
}
}
}
}
/**
* ?Yí??éμ?????????ó?ó????Yí?
*/
public void pauseMove() {
pausing = true;
}
/**
* ?ìD??éμ?????????ó?ó????ìD?
*/
public void resumeMove() {
pausing = false;
}
/**
* í????éμ?????????ó?ó???í???
*/
public void stopMove() {
moving = false;
}
/**
*
??μ????é?ó?,??μ???ó?????ò??y??òaμèμ????????,?,??ê????ü??ó???à?
*/
private void earse() {
for (int i = 0; i < boxes.length;="" i++)="" {="">
for (int j = 0; j < boxes[i].length;="" j++)="" {="">
if (boxes[i][j].isColorBox()) {
ErsBox box = canvas.getBox(i + y, j + x);
if (box == null) continue;
box.setColor(false);
}
}
}
}
/**
* è?μ????é?????ú?,??μ???ó?????é???òaμèμ????????,?,??ê????ü????
*/
private void display() {
for (int i = 0; i < boxes.length;="" i++)="" {="">
for (int j = 0; j < boxes[i].length;="" j++)="" {="">
if (boxes[i][j].isColorBox()) {
ErsBox box = canvas.getBox(y + i, x + j);
if (box == null) continue;
box.setColor(true);
}
}
}
}
/**
* μ????é?ü??ò???μ?newRow/newCol?ù????μ?????
* @param newRow int, ??μ?μ??ù?úDD
* @param newCol int, ??μ?μ??ù?úáD
* @return boolean, true-?üò?????false-???ü
*/
private boolean isMoveAble(int newRow, int newCol) {
earse();
for (int i = 0; i < boxes.length;="" i++)="" {="">
for (int j = 0; j < boxes[i].length;="" j++)="" {="">
if (boxes[i][j].isColorBox()) {
ErsBox box = canvas.getBox(newRow + i, newCol + j);
if (box == null || (box.isColorBox())) {
display();
return false;
}
}
}
}
display();
return true;
}
/**
* ??μ????,ò???μ?newRow/newCol?ù????μ?????
* @param newRow int, ??μ?μ??ù?úDD
* @param newCol int, ??μ?μ??ù?úáD
* @return boolean, true-ò????é????false-ò???ê??ü
*/
private synchronized boolean moveTo(int newRow, int newCol) {
if (!isMoveAble(newRow, newCol) || !moving) return false;
earse();
y = newRow;
x = newCol;
display();
canvas.repaint();
return true;
}
/**
* μ????é?ü?????énewStyle?ù????μ??é?ùê?????òaê?òa????
* ????ò????????ü?éμ?×??????üò???μ??é??
* @param newStyle
int,??í?????μ??é?ùê?????ó?STYLESμ?28???μ?Dμ?ò???
* @return boolean,true-?ü??????false-???ü????
*/
private boolean isTurnAble(int newStyle) {
int key = 0x8000;
earse();
for (int i = 0; i < boxes.length;="" i++)="" {="">
for (int j = 0; j < boxes[i].length;="" j++)="" {="">
if ((newStyle & key) != 0) {
ErsBox box = canvas.getBox(y + i, x + j);
if (box == null || box.isColorBox()) {
display();
return false;
}
}
key >>= 1;
}
}
display();
return true;
}
/**
* ??μ????é???énewStyle?ù????μ??é?ùê?
* @param newStyle
int,??òa?????éμ??é?ùê?????ó?STYLESμ?28???μ?Dμ?ò???
* @return boolean,true-?????é????false-????ê??ü
*/
private boolean turnTo(int newStyle) {
if (!isTurnAble(newStyle) || !moving) return false;
earse();
int key = 0x8000;
for (int i = 0; i < boxes.length;="" i++)="" {="">
for (int j = 0; j < boxes[i].length;="" j++)="" {="">
boolean isColor = ((newStyle & key) != 0);
boxes[i][j].setColor(isColor);
key >>= 1;
}
}
style = newStyle;
display();
canvas.repaint();
return true;
}
}
范文四:java编写俄罗斯方块实验报告
前言
实习时间,
实习学时,36学时
实习地点,北京科技大学信息楼
Java是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由Sun 公司于1995年5月推出的Java程序设计语言和Java平台的总称。Java 技术具有卓越的通用性、高效性、平台移植性和安全性,广泛应用于个人PC、数据中心、游戏控制台、科学超级计算机、移动电话和互联网,同时拥有全球最大的开发者专业社群。在全球云计算和移动互联网的产业环境下,Java更具备了显著优势和广阔前景。
Java 编程语言的风格十分接近C、C++语言。Java是一个纯的面向对象的程序设计语言,它继承了 C++语言面向对象技术的核心。Java舍弃了C ++语言中容易引起错误的指针、运算符重载、多重继承等特性,增加了垃圾回收器功能用于回收不再被引用的对象所占据的内存空间,使得程序员不用再为内存管理而担忧。在 Java 1.5 版本中,Java 又引入了泛型编程、类型安全的枚举、不定长参数和自动装/拆箱等语言特性。
Java 不同于一般的编译执行计算机语言和解释执行计算机语
言。它首先将源代码编译成二进制字节码,然后依赖各种不同平台上的虚拟机来解释执行字节码。从而实现了“一次编译、到处执行”的跨平台特性。不过,每次的执行编译后的字节码需要消耗一定的时间,这同时也在一定程度上降低了 Java 程序的运行效率。 实习目的和要求
认识实习是教学计划的主要部分之一, 它是培养学生实践能力和解决实际问题的第三课堂,它是专业知识培养的摇篮,也是对专业的实际应用和工作需求直接的认识与认知。实习中应该深入实际,认真观察,大胆实践,获取直接经验,巩固所学基本理论,保质保量完成指导老师所布置的任务。要习惯本专业工作的性质,要学会耐得住寂寞,在看似枯燥的编程中寻找兴趣点,大胆想象,培养我们的实践能力和创新能力, 开拓视野, 培养实际中研究、 观察、 分析、解决问题的能力。
认识实习是我们工科学生的一门必修课,通过认识实习,我们要对通信工程专业建立感性认识, 并进一步了解专业的学习实践环节, 培养自己专业的思想。 通过接触实际实习过程,一方面,达到对所学专业的性质、内容及其在工程技术领域中的地位有一定的认识, 为了解和巩固专业思想创造条件,在实践中了解专业、熟悉专业、热爱专业。另一方面,巩固、加深理解在课堂所学的理论知识,让自己的
理论知识更加扎实,专业技能更加过硬,更加善于理论联系实际。再有,通过分析利用编程解决生活中的小问题为进一步学习技术基础和专业知识奠定基础。
认知实习的过程中学生是以假想技术人员的身份完成老师布置的任务,在实习中应深入实际,认真实习,获取直接知识,巩固所学理论,培养和锻炼独立分析问题和 解决问题的能力。丰富和扩大学生的专业知识领域,也培养了学生的团结合作精神,牢固树立学生的群体意识,即个人智慧只 有在融入集体之中才能最大限度地发挥作用,让我们对于以后所担任的角色及工作内容有了更深的了解和体会,对于我们以后的实习和工作都是有很大帮助的。
实习要求
学生必须在教师指导下,按照实习大纲和实习计划进行实习,努力完成实习任务。
严格遵守学校的规章制度。实习期间要严格考勤,病假由指导教师批准,两天以上必须有医院诊断证明,超过一周时要及时向学院汇报。学生一般不得请事假,特殊情况需请事假时,三天以内由负责教师批准,三天以上报学院审批。无故不参加实习两天者由负责教师负责报学院给予通报批评,无故不参加实习三天,含,以上者,其成绩按不及格处理。
实习缺课三分之一以上天数者不予评定成绩。不交实习报告者,不得参加考核,其成绩按“0” 计。
严格遵守实验室的有关规章制度,对违反纪律的学生要进行批评教育,对情节严重者要及时向学院汇报处理,可取消其本次实习资格,其成绩按“0”分处理。
1、 实习期间应该注意自己的着装,不能穿背心、短裤和拖鞋
2、 实习期间一定要听从老师的指挥,认真遵守该有的课堂纪律,按时到教室,不擅自离开
3、 实习期间仔细观察,认真听老师和专家的讲解,遇到不懂得地方可以提出来,随时做笔记
实习所用工具介绍
Windows XP系统电脑一台,eclipse编程软件
实习内容
1.需求分析
俄罗斯方块是一个经典的小游戏,由于它简单有趣,因而得到了广泛的流行,男女老幼都适合。而俄罗斯方块游戏的设计工作复杂且富有挑战性,它包含的内容多,涉及的知识广泛,与图形界面联系较大,包括界面的显示与更新、 数据收集等,在设计的过程中,必将运用到各方面的知识,这对于我的认识实习及专业认知是有很大帮助
的。
2.系统功能设计
1. 本系统主要设计以下几种功能
1、游戏难度选择功能
如果玩家不选难度直接按“开始游戏”, 则使用默认的难度5,难度最高等级为10。
2、方块下落、变形功能
键盘上的左、右、下、上的箭头分别代表方块的向左、向右、向下、变形的功能。
3.升级功能
在游戏过程中能自主更改难度系数,如果觉得速度过慢,则可按“提高级数”,若过快,则可按“降低级数”
4.暂停功能
在游戏中方便暂时离开设置了“游戏暂停”功能。
5.帮助功能
界面中的帮助,能够使游戏者更好的使用该小游戏界面 6.界面设定
界面左侧为游戏区,上面有“游戏”“控制”“帮助”三个选项,右上方为下一个方块的提示,下方为等级和得分。
技术难点
因为是第一次使用java编程,所以对于基础应用还是不太会,如果只是看所谓的基础介绍,感觉短短两周是无法完成任务的。因为想到要做俄罗斯方块,众多类的建立会是个问题,而且俄罗斯方块看似简单,可是界面的布置,具体细节的功能实现
3.系统功能设计分析 1. 俄罗斯方块游戏根据功能的不同,设置了如下8个 类ErsBlocksGame,GameCanvas、ErsBlock、boolean、ControlPanel、JMenuBar、JMenu、JMenuItem。
每个类的描述如下:
2.1、ErsBlocsGAME
这个类中定义了生成方块的方法,用二维数组 int[][] pattern,存放 7 种方块的四种状态。在构造方法中以随机的形式生成方块,同 时提供了以下几种方法: 分别实现方块的重画、翻转、左移、右移、下落、同步显示等功能。
2.2、Command,处理控制类。这是一个实现 ActionListener 接口的类,主要处 理点击按钮事件。类中定义了三个 int 型变量:button_play,button_quit, button_pause,和一个 boolean 型的变量:pause_resume,并赋值。在 GameArea 类中通过事件响应,在按钮执行方法中调用其值,使用 switch 语句,根据不同 按钮不同的值,来响应不同的事件。 2.3、GameArea,游戏界面类。GameArea 继承了 JFrame,是俄罗斯方块的主要游 戏界面。这个类定义了 GameSetting 类的 gameScr 对象和 ImagePanel 类的 imagepanel 对象作为游戏区域面板和控制区域面板。在游戏区域,主要是根据 相应格子的设置标志来显示相应的图形图片,这
样就实现了俄罗斯方块的实时显 示。 2.4、GameSetting, 游戏画布类。这个类生成的对象将作为游戏界面的方块下落 区域,画布的设置为 15 行 10 列,当中的方格边长为 30,类中还定义了一个二 维数组 int [][] scrArr 作为屏幕数组,表示每一个方格。游戏区域中每一个方 格是否存在游戏方块是由该方格的值来决定的,如果该方格的值为 1,则表示该 方格中存在游戏方块;如果该方格中的值为 0,则表示该方格中不存在游戏方 块,因此二维数组用于记录游戏区域中每个小方格的值。此外,类中还定义了画 方块的方法,根据不同的难度画出不同颜色的方块。单击 Play 按钮时,系统调 用 initScr( )方法,初始化屏幕,将屏幕数组清零。当满足满行删除的条件时, 系统调用 deleteFullLine( )方法,进行删行加分,而且每删除十行,难度自动 增加一级,方块颜色改变,并在难度显示框中相应显示。 2.5、GameOver,游戏结束弹出提示框类。当游戏结束时,系统弹出提示,包括 玩家分数以及询问玩家要继续游戏还是退出。 2.6、Help,帮助类。在游戏界面,按 F1 键,弹出提示窗口,获取帮助。 2.7、ImagePanel,背景图片类。这个类继承了 JPanel 类,用来作为游戏界面中 控制区域的容器,并添加图片。 2.8、JieMian,主界面类。这个类继承了 JPanel 类,作为游戏的第一个界面, 也是难度选择界面。定义了 9 个单选按钮,当玩家未选任何难度就按 Enter 时, 系统会弹出一个提示框,提示玩家先选难度再进入。 2.9、MyPanel,重写 MyPanel 类,使 Panel 的四周留空间。 2.10、MyTimer,定时线程类。类中定义了一个 run()方法,用 sleep()函数 实现方块下落的快慢,即调节难度。 2.11、PlayMidi,添加音乐类。在游戏过程中添加背景音乐。 2.12、WinListener,关闭窗口类。
范文五:java编写俄罗斯方块源代码一.doc
import javax.swing.*;
import javax.swing.border.Border;
import javax.swing.border.EtchedBorder;import java.awt.*;
import java.awt.event.*;
/**
* ,,,,,,,,,,,,,,JPanel.
* ,,?,,,,,,,,,,,,,,,,?,,,,,?,?
* ,,,,4,,,,,,,,,,,?
*/
class ControlPanel extends JPanel {
private JTextField
tfLevel = new JTextField("" + ErsBlocksGame.DEFAULT_LEVEL),
tfScore = new JTextField("0");
private JButton
btPlay = new JButton("Play"),
btPause = new JButton("Pause"),
btStop = new JButton("Stop"),
btTurnLevelUp = new JButton("Turn hard"),
btTurnLevelDown = new JButton("Turn easy");
private JPanel plTip = new JPanel(new BorderLayout());
private TipPanel plTipBlock = new TipPanel();
private JPanel plInfo = new JPanel(new GridLayout(4, 1));
private JPanel plButton = new JPanel(new GridLayout(5, 1));
private Timer timer;
private ErsBlocksGame game;
private Border border = new EtchedBorder(
EtchedBorder.RAISED, Color.white, new Color(148, 145, 140));
/**
* ,,,,,,,,,?,,,,?
* @param game ErsBlocksGame, ErsBoxesGame,,,?,,,,,,,,?,
* ,,,,?,,,,,ErsBoxesGame,,,,,?,,
*/
public ControlPanel(final ErsBlocksGame game) {
setLayout(new GridLayout(3, 1, 0, 4));
this.game = game;
plTip.add(new JLabel("Next block"), BorderLayout.NORTH);
plTip.add(plTipBlock);
plTip.setBorder(border);
plInfo.add(new JLabel("Level"));
plInfo.add(tfLevel);
plInfo.add(new JLabel("Score"));
plInfo.add(tfScore);
plInfo.setBorder(border);
tfLevel.setEditable(false);
tfScore.setEditable(false);
plButton.add(btPlay);
plButton.add(btPause);
plButton.add(btStop);
plButton.add(btTurnLevelUp);
plButton.add(btTurnLevelDown);
plButton.setBorder(border);
add(plTip);
add(plInfo);
add(plButton);
addKeyListener(new ControlKeyListener());btPlay.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent ae) {
game.playGame();
}
});
btPause.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent ae) {
if (btPause.getText().equals(new String("Pause"))) {
game.pauseGame();
} else {
game.resumeGame();
}
}
});
btStop.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent ae) {
game.stopGame();
}
});
btTurnLevelUp.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent ae) {
try {
int level = Integer.parseInt(tfLevel.getText());
if (level <>
tfLevel.setText("" + (level + 1));
} catch (NumberFormatException e) {
}
requestFocus();
}
});
btTurnLevelDown.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent ae) {
try {
int level = Integer.parseInt(tfLevel.getText());
if (level > 1)
tfLevel.setText("" + (level - 1));
} catch (NumberFormatException e) {
}
requestFocus();
}
});
addComponentListener(new ComponentAdapter() {
public void componentResized(ComponentEvent ce) {
plTipBlock.fanning();
}
});
timer = new Timer(500, new ActionListener() {
public void actionPerformed(ActionEvent ae) {
tfScore.setText("" + game.getScore());
int scoreForLevelUpdate =
game.getScoreForLevelUpdate();
if (scoreForLevelUpdate >= ErsBlocksGame.PER_LEVEL_SCORE
&& scoreForLevelUpdate > 0)
game.levelUpdate();
}
});
timer.start();
}
/**
* ,,,,,,,,,,,,,,,,
* @param style int,,,ErsBlock,,,STYLES,е,28,?,?
*/
public void setTipStyle(int style) {
plTipBlock.setStyle(style);}
/**
* ,,,,?,,,,?,,,,,,,,,
* @return int, ,,,,,,1,,,,,,ErsBlocksGame.MAX_LEVEL?
*/
public int getLevel() {
int level = 0;
try {
level = Integer.parseInt(tfLevel.getText());
} catch (NumberFormatException e) {
}
return level;
}
/**
* ,,,?,,,,,,,,,,,,,?
* @param level ,,?,,,,,,,,,?
*/
public void setLevel(int level) {
if (level > 0 && level < 11)="" tflevel.settext(""="" +="">
}
/**
* ,,,,",,,",,?,,?,,,
*/
public void setPlayButtonEnable(boolean enable) {
btPlay.setEnabled(enable);
}
public void setPauseButtonLabel(boolean pause) {
btPause.setText(pause ? "Pause" : "Continue");
}
/**
* ,,,?,,,,,,
*/
public void reset() {
tfScore.setText("0");
plTipBlock.setStyle(0);
}
/**
* ,,,?,,,TipPanel,,,boxes[][],,,С,,?,С
*/
public void fanning() {
plTipBlock.fanning();
}
/**
* ,,,,,,,,,,,,,,,
*/
private class TipPanel extends JPanel {
private Color backColor = Color.darkGray, frontColor =
Color.lightGray;
private ErsBox[][] boxes =
new ErsBox[ErsBlock.BOXES_ROWS][ErsBlock.BOXES_COLS];
private int style, boxWidth, boxHeight;private boolean isTiled = false;
/**
* ,,,,,,,,,,,?
*/
public TipPanel() {
for (int i = 0; i < boxes.length;="" i++)="">
for (int j = 0; j < boxes[i].length;="">
boxes[i][j] = new ErsBox(false);
}
}
/**
* ,,,,,,,,,,,?
* @param backColor Color, ,,,,?,,,?
* @param frontColor Color, ,,,,,,,,?
*/
public TipPanel(Color backColor, Color frontColor) {
this();
this.backColor = backColor;
this.frontColor = frontColor;
}
/**
* ,,,,,,,,,,?,,,,,,
* @param style int,,,ErsBlock,,,STYLES,е,28,?,?
*/
public void setStyle(int style) {
this.style = style;
repaint();
}
/**
* ,,,,JComponent,,?,,,,,,,
* @param g ,,,,,,,,豸
*/
public void paintComponent(Graphics g) {
super.paintComponent(g);
if (!isTiled) fanning();
int key = 0x8000;
for (int i = 0; i < boxes.length;="" i++)="">
for (int j = 0; j < boxes[i].length;="" j++)="">
Color color = (((key & style) != 0) ? frontColor :
backColor);
g.setColor(color);
g.fill3DRect(j * boxWidth, i * boxHeight,
boxWidth, boxHeight, true);
key >>= 1;
}
}
}
/**
* ,,,,,,?,С,,,,,,,,,,?,,
*/
public void fanning() {
boxWidth = getSize().width / ErsBlock.BOXES_COLS;
boxHeight = getSize().height / ErsBlock.BOXES_ROWS;
isTiled = true;
}
}
private class ControlKeyListener extends KeyAdapter {
public void keyPressed(KeyEvent ke) {
if (!game.isPlaying()) return;
ErsBlock block = game.getCurBlock();
switch (ke.getKeyCode()) {
case KeyEvent.VK_DOWN:
block.moveDown();
break;
case KeyEvent.VK_LEFT:
block.moveLeft();
break;
case KeyEvent.VK_RIGHT:
block.moveRight();
break;
case KeyEvent.VK_UP:
block.turnNext();
break;
default:
break;
}
}
}
}
转载请注明出处范文大全网 » java编写俄罗斯方块(三)