庞大资源库的计算机教程网站!
设为首页
加入收藏
总编信箱
投稿或申请专栏请先 [登 陆]
首页 操作系统 程序设计 图形图像 媒体动画 机械电子 WEB开发 数 据 库 办公系列 路由技术 网络原理 网络应用
认证考试 安全技术
首页>安全技术>软件破解>算法研究>正文
资料搜索
Google搜索
Google
返回上级列表

推荐文章

快速保存网页中所有图片的方法
Windows中让光驱巧妙“隐身”技
防范非法用户入侵Win 2000/XP系
两款比较典型的ASP木马防范方法
有关表格边框的css语法整理
Windows XP中可以被禁用的服务
SQL Server导出导入数据方法
Javascript所有对象的属性的获
网页(HTML)中的特殊字符
与篮球共舞,尽显模式本色
QQ病毒的手工清除方法
Photoshop为极品美女打造性感睫
天衣无缝:IIS与PHP水火也相容
SQL Server存储过程编写和优化

贪吃蛇的算法分析(4)

 作者:本站收集   日期:2005-5-28
字号选择〖 〗/ 双击滚屏 单击停止   
WormPit类

WormPit类中包括了Worm和WormFood。贪吃蛇将会在画面中移动寻找食物。如果它吃到食物它将会长一格。如果它碰到边界或者吃到自己将Game Over。

下面介绍几个重要的函数

l         private void paintPitContents(Graphics g)

重绘屏幕上的所有元素

// 更新贪吃蛇的状态

        myWorm.update(g);  

        // 头部的位置和食物的位置重合就吃到食物

        if (myFood.isAt(myWorm.getX(), myWorm.getY())) {

        myWorm.eat();

        score += level;

        foodEaten++;

        if (foodEaten > (level << 1)) {

            /* 增加游戏难度 */

            forceRedraw = true;

            foodEaten = 0;

            level++;

            if (tonePlayer != null) {

            try {

                tonePlayer.setMediaTime(0);

                tonePlayer.start();

            } catch (MediaException me) { }         }

        } else {

            if (audioPlayer != null) {

            try {

                Manager.playTone(69, 50, 100);   // Play audio

            } catch (MediaException me) { }         }        }

        g.setColor(WormPit.ERASE_COLOUR);

        // 填充长方形(三个字的宽度)

        g.fillRect((width - (SCORE_CHAR_WIDTH * 3))-START_POS,

               height-START_POS,

               (SCORE_CHAR_WIDTH * 3),

               SCORE_CHAR_HEIGHT);

        g.setColor(WormPit.DRAW_COLOUR);

        // 显示新的分数

        g.drawString("" + score,

                 width - (SCORE_CHAR_WIDTH * 3) - START_POS,

                 height - START_POS, Graphics.TOP|Graphics.LEFT);

        // 重新生成食物

        myFood.regenerate();

        int x = myFood.getX();

        int y = myFood.getY();

        while (myWorm.contains(x, y)) {

        // 如果食物和贪吃蛇的身体重复就重新生成

            myFood.regenerate();

            x = myFood.getX();  y = myFood.getY();       }       }

        // 画出食物

        myFood.paint(g);

    } catch (WormException se) {    gameOver = true; }

 l         public void run()

主循环体:

while (!gameDestroyed) { // 游戏不终止就一直循环执行

        try {

        synchronized (myWorm) { // 多线程中要进行同步

            // 如果游戏结束

            if (gameOver) {

            if (WormScore.getHighScore(level) < score) {

                // 把最高分保存

                WormScore.setHighScore(level, score, "me");          }

            if ((audioPlayer != null) &&

                (audioPlayer.getState() == Player.STARTED)) {

                try {

                audioPlayer.stop();

                Manager.playTone(60, 400, 100);

                } catch (Exception ex) { }           }

            // 重绘

            repaint();

            // 游戏结束时等待用户重新开始

            myWorm.wait();  

            } else if (gamePaused) {

            //重绘

            repaint();

            // 游戏暂停时等待用户重新开始

            myWorm.wait();

            } else {

            // 游戏继续

            myWorm.moveOnUpdate();

            repaint();

            // 这里的等待时间决定了游戏难度!!!

            myWorm.wait(DEFAULT_WAIT-(level*40));

            }

        }

        } catch (java.lang.InterruptedException ie) {

        }

    }

上一篇:贪吃蛇的算法分析(3)    下一篇:贪吃蛇的算法分析(5)  
[发送给好友]  [关闭窗口]  [返回顶部]   转载请注明来源:www.it00.com   
特别声明: 本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作者。文章版权归文章原始作者所有。对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转载的文章有版权问题请联系编辑人员,我们尽快予以更正。
责任编辑: 原点 投稿作者: 本站收集
信息来源: 网络 录入时间: 2005-5-28
关于我们 - 广告服务 - 版权申明 - 网站地图 - 联系方式 - 总编信箱 - 会员投稿