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. swfupload文件上传配置文件大小

    在配置文件中加入: <system.web>         <httpRuntime executionTimeout="36000" maxRequestLe ...

  2. nopi设置excel只读

  3. node.js定时任务 node-schedule

    先安装 node-schedule npm install node-schedule //1:确定时间 //例如:2014年2月14日,15:40执行 var schedule = require( ...

  4. 开源项目几点心得,Java架构必会几大技术点

    关于学习架构,必须会的几点技术 1. java反射技术     2. xml文件处理     3. properties属性文件处理     4. 线程安全机制     5. annocation注解 ...

  5. day22-类的多态

    一.多态 多态的概念是应用于Java和C#这一类强类型语言中,而Python崇尚“鸭子类型”.所谓多态:调用的方法是同一个,但是执行的代码或者说现象不一样,此时就称为多态 #我们编写了名为Animal ...

  6. mongo aggregate 用法记录

    mongo 聚合查询查询还是很方便的,做下记录     依赖的jar是org.springframework.data.mongodb 1.9.6  低版本可能不支持. 数据结构  大概是  这是一份 ...

  7. Delphi Locate 详解1 转

    TDataSet控件以及它的继承控件,例如TSimpleDataSet/TClientDataSet等都可以使用Locate方法在结果数据集中查寻数据.程序首先必须使用SQL命令从后端数据库中取得数据 ...

  8. HashMap 实现总结

    Entry类中需包含键值的hash值,防止resize时的重复计算: Map容量为2的整幂,可使用位操作取代取余操作提高效率: resize时需要将原table的桶内数据置null,利于垃圾回收: h ...

  9. 免費查看SQL PLAN的工具 - SQL Sentry Plan Explorer

    今天 Terry大 介紹給小弟這個 SQL Sentry Plan Explorer 工具,可以用來看SQL Plan. 什麼? 用SSMS看不就很清楚了嗎? 這個Tool有把SQL Plan幫我們整 ...

  10. [Shell]Bash基本功能:输入输出重定向

    /*----------------------------------------------------------------------------------------------- @黑 ...