贪吃蛇snake Java实现(二)
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实现(二)的更多相关文章
- 贪吃蛇Controller Java实现(二)
package cn.tcc.snake.Controller; import java.awt.Point;import java.awt.event.KeyAdapter;import java. ...
- 贪吃蛇GamePanel Java实现(二)
package cn.tcc.snake.tcc.View; import java.awt.Color;import java.awt.Graphics; import javax.swing.JP ...
- 贪吃蛇Food Java实现(二)
1.antition包Food类 package cn.tcc.snake.antition; import java.awt.Graphics;import java.awt.Point;publi ...
- 贪吃蛇Ground Java实现(二)
package cn.tcc.snake.antition; import java.awt.Color;import java.awt.Graphics; import java.awt.Point ...
- 贪吃蛇Global Java实现(二)
package cn.tcc.snake.util; public class Global {public static final int CELL_SIZE=20;public static f ...
- 贪吃蛇Listener Java实现(二)
package cn.tcc.snake.listener; import cn.tcc.snake.antition.Sanke;//接口//处理用户按键事件public interface Sna ...
- 贪吃蛇的java代码分析(二)
代码剖析 贪吃蛇是一款十分经典的小游戏,对初入coding的朋友来说,拿贪吃蛇这样一个案例来练手十分合适,并不高的难度和成功后的成就感都是学习所必须的.下面我将依照我当时的思路,来逐步分析实现的整个过 ...
- 贪吃蛇的java代码分析(三)
代码剖析 在上一篇文章中,我们完成了贪吃蛇部分代码的构造.回头审视我们写的代码与思路,会发现我们遗漏了一个重要的地方,那就是:贪吃蛇的自身移动.想必大家都知道,贪吃蛇自身是会自己移动的,并且会跟随你的 ...
- 贪吃蛇的java代码分析(一)
自我审视 最近自己学习java已经有了一个多月的时间,从一开始对变量常量的概念一无所知,到现在能勉强写几个小程序玩玩,已经有了长足的进步.今天没有去学习,学校里要进行毕业答辩和拍毕业照了,于是请了几天 ...
随机推荐
- swfupload文件上传配置文件大小
在配置文件中加入: <system.web> <httpRuntime executionTimeout="36000" maxRequestLe ...
- nopi设置excel只读
- node.js定时任务 node-schedule
先安装 node-schedule npm install node-schedule //1:确定时间 //例如:2014年2月14日,15:40执行 var schedule = require( ...
- 开源项目几点心得,Java架构必会几大技术点
关于学习架构,必须会的几点技术 1. java反射技术 2. xml文件处理 3. properties属性文件处理 4. 线程安全机制 5. annocation注解 ...
- day22-类的多态
一.多态 多态的概念是应用于Java和C#这一类强类型语言中,而Python崇尚“鸭子类型”.所谓多态:调用的方法是同一个,但是执行的代码或者说现象不一样,此时就称为多态 #我们编写了名为Animal ...
- mongo aggregate 用法记录
mongo 聚合查询查询还是很方便的,做下记录 依赖的jar是org.springframework.data.mongodb 1.9.6 低版本可能不支持. 数据结构 大概是 这是一份 ...
- Delphi Locate 详解1 转
TDataSet控件以及它的继承控件,例如TSimpleDataSet/TClientDataSet等都可以使用Locate方法在结果数据集中查寻数据.程序首先必须使用SQL命令从后端数据库中取得数据 ...
- HashMap 实现总结
Entry类中需包含键值的hash值,防止resize时的重复计算: Map容量为2的整幂,可使用位操作取代取余操作提高效率: resize时需要将原table的桶内数据置null,利于垃圾回收: h ...
- 免費查看SQL PLAN的工具 - SQL Sentry Plan Explorer
今天 Terry大 介紹給小弟這個 SQL Sentry Plan Explorer 工具,可以用來看SQL Plan. 什麼? 用SSMS看不就很清楚了嗎? 這個Tool有把SQL Plan幫我們整 ...
- [Shell]Bash基本功能:输入输出重定向
/*----------------------------------------------------------------------------------------------- @黑 ...