J2ME版贪吃蛇游戏

J2ME贪吃蛇项目说明与分析:
 
游戏说明:
* 运行环境:手机移动平台,通过实验多种型号手机均可以运行。固然前提下是手机要支JAVA功能才行。
* 本游戏支持RMS持久化数据库存,能够保存游戏计分,关数,速度。
* 用户能够自行设置游戏速度,游戏关数。
* 想在手机上运行,能够经过多种方式,将文件传送到手机中,固然最普通的方式就是经过USB链接将数据传送到手机上。因为我把项目的全部源代码都发布了,传送时只须要将项目文件当中.jar.jad传进去。有的手机,可能不须要那个.jad的文件,这两个文件在项目当中的dist目录下。不须要将其余的文件发送到手机上去。
 
游戏分析:
  首先分析此游戏,贪吃游戏通常都有一些食物对象,那么首先咱们先来看一下抽象食物对象的类。
Guttler.java:
/*
 * 此类是游戏场景上须要的
 * 对象
 */
package GuttlerGame;
 
import javax.microedition.lcdui.Graphics;
 
public class Guttler
{
    public int x,y; //肯定对象的坐标位置的属性
    private static int w=5,h=5; //肯定对象的大小属性
 
    /*
     * 此构造方法构造一个具备
     * 坐标位置的对象
     */
    public Guttler(int x,int y)
    {
        this.x=x;
        this.y=y;
    }
 
    /*
     * 在游戏场景上画此对象的方法
     */
    public void paint(Graphics g)
    {
        g.setColor(255, 255, 255);
        g.fillRect(x, y, w, h);
        g.setColor(10,10,30);
        g.drawRect(x, y, w, h);
    }
 
    /*
     * 获取此对象的一个Rectangle对象
     */
    public Rectangle getRect()
    {
        return new Rectangle(x,y,w,h);
    }
 
}
上面是抽象了一个在屏幕上的食物对象,在这个对象中要利用此对象的的x,y坐标和w,h宽高大小得到一个方框对象,因为J2ME sdk没有提供Rectangle矩形这个对象类,因此我就本身抽象了一个Rectangle矩形对象,此对象主要是为了碰撞检测时候用的,下面咱们来看一下这个类的内容:
Rectangle.java:
/*
 * 此类是一个Rectangle类对象
 * 是为实现物体之间的相交,碰撞检测
 * 的类
 */
package GuttlerGame;
 
public class Rectangle
{
    public int x,y,w,h; //此对象的坐标位置和高宽属性
 
    /*
     * 构造方法构造一个具坐标位置和高宽属性的对象
     */
    public Rectangle(int x,int y,int w,int h)
    {
        this.x=x;
        this.y=y;
        this.w=w;
        this.h=h;
    }
 
    /*
     * RectangleRectangle对象重合的方法
     */
    public boolean superposition(Rectangle rec)
    {
        if(this.x==rec.x&&this.y==rec.y)
        {
            return true;
        }
        return false;
    }
 
    /*
     * RectangleRectangle对象相交的方法
     */
    public boolean intersect(Rectangle rec)
    {
        if(this.x>=rec.x&&this.y>=rec.y&&this.x<=rec.x+rec.w&&this.y<=rec.y+rec.h)
        {
            return true;
        }
        return false;
    }
 
}
固然有了这些东西固然不行,由于一个手机程序的入口点对象必须继承MIDLet这个类,因此咱们必须建立一个主类,继承MIDLet这个类,而后重写MIDLet类当中的方法,就至关于系统上的程序的main方法同样,每一个程序都必须有一个main方法,而手机应用程序则不是main方法,可是手机应用程序也必须有一个入口方法,这与main方法是同样的。在这里个人主类代码就没必要所有列出,只是列出一个MIDLet的特性地方,所有代码能够下载源代码。
下面是一个手机应用程序继承MIDLet必须重写的方法
/*
* 开始运行此类的方法
*/
public void startApp()
{
}
/*
* 暂停,停止的方法
*/
public void pauseApp()
{
}
/*
* 撤销此类的方法
*/
public void destroyApp(boolean unconditional)
{
}
关于界面的问题在这里就不进行列述,在这里还有一点手机数据存储的技术代码以下:
因为游戏当中有一个数据须要持久性的保存起来,供下一次程序运行加载,因为J2ME对文件不是很好,只能读取文件数据,不能写入数据,这时J2ME就提供了RMS技术相似于数据库的一个技术,实现代码以下:
  首先得建立一张数据表,只有手机没有这张表的时候才会执行这段代码,也因此只有第一次运行的时候才会建立该表和初始化该表字段。
  try {
                rs = RecordStore.openRecordStore("GameDatabase", true);
                if(rs.getNumRecords()==0){
                String s1=Integer.toString(num);
                rs.addRecord(s1.getBytes(), 0, s1.length());
                s1=Integer.toString(fraction);
                rs.addRecord(s1.getBytes(), 0, s1.length());
                s1=Integer.toString(speed);
                rs.addRecord(s1.getBytes(), 0, s1.length());
                }
} catch (Exception ex) {
    ex.printStackTrace();
 }
 建立以后,这时每一次运行时就只读取数据表当中的内容
 try {
     num = Integer.parseInt(new String(rs.getRecord(1)));
     fraction = Integer.parseInt(new String(rs.getRecord(2)));
     speed = Integer.parseInt(new String(rs.getRecord(3)));
 } catch (RecordStoreException ex) {
     ex.printStackTrace();
 }
 而当程序关闭的时候,必须将程序如今的数据更新到数据库当中,这样下次运行才看见数据改变过了,而实现了数据的存取结果,实现以下:
 /*
     * 执行按钮操做的方法
     */
    public void commandAction(Command c, Displayable s)
    {
        if(c==exitCommand)
        {
            String s2=Integer.toString(num);
            byte[] b1=s2.getBytes();
            try {
                rs.setRecord(1, b1, 0, s2.length());  //更新数据内容
                s2=Integer.toString(fraction);
                b1=s2.getBytes();
                rs.setRecord(2, b1, 0, s2.length());
                s2=Integer.toString(speed);
                b1=s2.getBytes();
                rs.setRecord(3, b1, 0, s2.length());
                rs.closeRecordStore();
            } catch (RecordStoreException ex) {
                ex.printStackTrace();
            }
            this.notifyDestroyed();
        }
这样就实现了数据持久化的目的。
由于写了两个版本一个是有障碍物对象的版本,一个是没有障碍物对象的版本,下面我来看一下关于抽象障碍物对象类的内容以下:
Bar.java:
package GuttlerGame;
 
import java.io.IOException;
import javax.microedition.lcdui.Graphics;
import javax.microedition.lcdui.Image;
 
/*
 * 此类是一个表现游戏
 * 障碍物的类
 */
public class Bar
{
    private Image img_bar=null;  //一个障碍物的图像对象
    private int img_x,img_y;  //障碍物的图像对象的x,y坐标
    private String url;  //障碍物图像的路径
 
    /*
     * 在游戏中构造一个障碍物对象
     */
    public Bar(int x,int y,String s)
    {
        this.img_x=x;
        this.img_y=y;
        this.url=s;
        try {
                img_bar = Image.createImage(url);
        } catch (IOException ex) {
            ex.printStackTrace();
        }
    }
 
    /*
     * 在游戏画布上画出此障碍物对象
     */
    public void paint(Graphics g)
    {
        g.drawImage(img_bar, img_x, img_y, Graphics.LEFT|Graphics.TOP);
    }
 
    /*
     * 获取此障碍物的一个Rectangle对象为
     * 碰撞检测时所用的一个对象
     */
    public Rectangle getRect()
    {
        return new Rectangle(img_x+5,img_y+5,img_bar.getWidth()-5,img_bar.getHeight()-5);
    }
   
}
这个类主要是实如今屏幕上加一些障碍物对象,若是碰到障碍物就Game Over.
下面看一下运行状况:
这个是程序一开始的运行状态图片:
下面再来看一下Menu按钮打操做界面:
下面是游戏说明的界面:
下面定义游戏关数的界面:
下面定义游戏速度的界面:
下面没有障碍物版本的游戏运行界面
下面是有障碍版本的游戏运行界面
 
贪吃蛇游戏说明和分析就到这了,但愿你们看完后,可以给我一些见意!这样也能促进我进步,同时也让本身进步了,何乐而不为呢!但愿咱们你们共同进步!若是有见意能够用QQ方式跟我交流一下!QQ:565345652。若是想下载源码可到个人博客上下载。
博客地址: http://smqnetwork.blog.51cto.com http://smq-java.javaeye.com 这个两个站点都有源码提供。
相关文章
相关标签/搜索