package cn.tcc.snake.antition;

import java.awt.Color;
import java.awt.Graphics;
import java.awt.Point;
import java.util.HashSet;
import java.util.LinkedList;
import java.util.Set;

import cn.tcc.snake.listener.SnakeListener;
import cn.tcc.snake.util.Global;

public class Sanke {
    public static final int UP = -1;
    public static final int DOWN =1;
    public static final int LEFT=2;
    public static final int RIGHT=-2;
    private int oldDirection,newDirection;
    private LinkedList<Point> body = new LinkedList<Point>();
    private Set<SnakeListener> Listeners = new HashSet<SnakeListener>(); // 监听器
    private Point oldTail;
    private boolean life;
    public void die(){
        life = false;
    }
    public Sanke(){
        init();
        
    }
    public void init(){
    int x = Global.WIDTH / 2;
    int y = Global.HEIGHT /2;
    for(int i=0;i<10;i++){
        body.addLast(new Point(x--,y));
        
    }
    newDirection=oldDirection = RIGHT;
    life = true;
    }
public void Move(){
    System.out.println("Snake Move");
    if(!(oldDirection+newDirection==0)){
        oldDirection = newDirection;
    }
    //去尾
    oldTail=body.removeLast();
    int x = body.getFirst().x;
    int y = body.getFirst().y;
    switch (oldDirection) {
    case UP:
        y--;
        if(y < 0){
            y=Global.HEIGHT-1;
        }
        break;
    case DOWN:
        y++;
        if(y >= Global.HEIGHT){
            y=0;
        }
        break;
    case LEFT:
        x--;
        if(x<0){
            x=Global.WIDTH-1;
        }
        break;
    case RIGHT:
        x++;
        if(x>=Global.WIDTH){
            x=0;
        }
        break;
    }
    Point newHead = new Point(x,y);
    //加头
    body.addFirst(newHead);
}

public void changDirection(int direction){
    System.out.println("Snake changDirection");
    
    newDirection = direction;
    
}

public void eatFood(){
    body.addLast(oldTail);
    System.out.println("Snake eatFood");
}
public boolean isEatBody(){
    System.out.println("Snake EatBody");
    for(int i=1;i<body.size();i++){
        if(body.get(i).equals(this.getHead())){
            return true;
        }
    }
    return false;
}
public void drawMe(Graphics g){
    g.setColor(Color.BLUE);
    for(Point p: body){
    g.fill3DRect(p.x*Global.CELL_SIZE, p.y*Global.CELL_SIZE,Global.CELL_SIZE,Global.CELL_SIZE, true);
    }
    
    System.out.println("snake drawme");
}
public Point getHead(){
    return body.getFirst();
}
public class SnakeDriver implements Runnable{

@Override
    public void run() {
        
        while(life){
            Move();
            for(SnakeListener l: Listeners){
            l.SnakeMoved(Sanke.this);
            
            }
            try {
                Thread.sleep(300);
            } catch (Exception e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
        }
    }
    
}
public void start(){
    new Thread(new SnakeDriver()).start();
}
//添加监听器
public void addSnakeListener(SnakeListener l){
    if(l != null){
        this.Listeners.add(l);
    }
}
}

贪吃蛇snake Java实现(二)的更多相关文章

  1. 贪吃蛇Controller Java实现(二)

    package cn.tcc.snake.Controller; import java.awt.Point;import java.awt.event.KeyAdapter;import java. ...

  2. 贪吃蛇GamePanel Java实现(二)

    package cn.tcc.snake.tcc.View; import java.awt.Color;import java.awt.Graphics; import javax.swing.JP ...

  3. 贪吃蛇Food Java实现(二)

    1.antition包Food类 package cn.tcc.snake.antition; import java.awt.Graphics;import java.awt.Point;publi ...

  4. 贪吃蛇Ground Java实现(二)

    package cn.tcc.snake.antition; import java.awt.Color;import java.awt.Graphics; import java.awt.Point ...

  5. 贪吃蛇Global Java实现(二)

    package cn.tcc.snake.util; public class Global {public static final int CELL_SIZE=20;public static f ...

  6. 贪吃蛇Listener Java实现(二)

    package cn.tcc.snake.listener; import cn.tcc.snake.antition.Sanke;//接口//处理用户按键事件public interface Sna ...

  7. 贪吃蛇的java代码分析(二)

    代码剖析 贪吃蛇是一款十分经典的小游戏,对初入coding的朋友来说,拿贪吃蛇这样一个案例来练手十分合适,并不高的难度和成功后的成就感都是学习所必须的.下面我将依照我当时的思路,来逐步分析实现的整个过 ...

  8. 贪吃蛇的java代码分析(三)

    代码剖析 在上一篇文章中,我们完成了贪吃蛇部分代码的构造.回头审视我们写的代码与思路,会发现我们遗漏了一个重要的地方,那就是:贪吃蛇的自身移动.想必大家都知道,贪吃蛇自身是会自己移动的,并且会跟随你的 ...

  9. 贪吃蛇的java代码分析(一)

    自我审视 最近自己学习java已经有了一个多月的时间,从一开始对变量常量的概念一无所知,到现在能勉强写几个小程序玩玩,已经有了长足的进步.今天没有去学习,学校里要进行毕业答辩和拍毕业照了,于是请了几天 ...

随机推荐

  1. 白鹭引擎 - 碰撞检测 ( hitTestPoint )

    1, 矩形碰撞检测 class Main extends egret.DisplayObjectContainer { /** * Main 类构造器, 初始化的时候自动执行, ( 子类的构造函数必须 ...

  2. JS 相等判断 / 类型判断

    相等判断 JavaScript提供三种不同的值比较操作: 严格相等 ("triple equals" 或 "identity"),使用 === , 宽松相等 ( ...

  3. delphi query阻塞执行 长时间执行sql的解决办法

    delphi query 执行sql一直是阻塞执行,执行长时间的sql语句,程序没响应了,这时候只能用线程技术解决. 如今FDQuery有了CmdExecMode属性,可以设置amCancelDial ...

  4. 获取数据库表中自增长最新的id

    mybatis <insert id="InsertCourse"> insert into training_course(type_id,course_title, ...

  5. jq动画分析

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  6. table布局与div布局

      DIV与TABLE本身并不存在什么优缺点,所谓web标准只是推荐的是正确的使用标签,好比说:DIV用于布局,而TABLE则本来就是转二维数据的.让TABLE做该做的事,并不是说页面里不出现TABL ...

  7. virtual 初探

    两种代码方式: class person { public: void f() { cout << "person.f()" << endl; } }; c ...

  8. iOS app bundle id

    每个app的bundle id是唯一的,不同开发者账号不能申请相同的bundle id,例如开发者账号B想用开发者A的bundle id,只能是开发者A将这个bundle id先删除,B才可以注册,否 ...

  9. java 使用jsoup处理html字符

    依赖的jar <dependency> <groupId>org.jsoup</groupId> <artifactId>jsoup</artif ...

  10. E_FAIL (0x80004005) MachineWrap

    下载VirtualBox-4.3.12-93733-Win.exe,下载地址:http://download.virtualbox.org/virtualbox/4.3.12/