| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154 |
- package model.gameState;
- import java.awt.BasicStroke;
- import java.awt.Color;
- import java.awt.Graphics2D;
- import java.awt.Stroke;
- import java.awt.geom.Rectangle2D;
- import java.util.Iterator;
- import model.GameModel;
- import model.SongHandler;
- import model.drawObjects.Player;
- import model.drawObjects.enemy.Enemy;
- import model.objects.InfoPanel;
- import model.objects.Path;
- import model.objects.PlayArea;
- import control.GameStateManager;
- import control.button.ButtonEvent;
- import control.joystick.JoystickEvent;
- public class PlayState extends GameState{
- public static final Rectangle2D borderRect = new Rectangle2D.Double(256, 0, 1024, 1024);
- private PlayArea area;
- private InfoPanel infoPanel;
- private Player player;
- private Stroke stroke;
-
- public static int sizeOfEnemy = 40;
- public static int currentScore = 0;
- public static int lifePoints = 100;
-
- public PlayState(GameStateManager gsm, SongHandler sh) {
- super(gsm,sh);
- infoPanel = new InfoPanel(0, 0);
- area = new PlayArea(256, 1024, 1024, 100);
- for(int index = 0; index < 8; index++){
- addEnemy(index, GameModel.colors[index % 6]);
- }
-
- player = new Player(1280-1024+1024/2, 1024/2);
- stroke = new BasicStroke(sizeOfEnemy,BasicStroke.CAP_ROUND,BasicStroke.JOIN_ROUND);
- }
- @Override
- public void init() {
-
-
- }
- @Override
- public void update() {
- player.update();
- for(Path path : area.paths){
- enemyIterator = enemys.iterator();
- while(enemyIterator.hasNext()){
- Enemy e = enemyIterator.next();
- Rectangle2D hitArea = area.hitAreas[e.getIndex()];
- if(e.finised()){
- enemyIterator.remove();
- }
- if(hitArea.intersectsLine(e.enemy) && !e.isClickable()){
- e.clickable();
- }
- e.update();
- }
- }
- infoPanel.updateIPanel();
- }
-
- @Override
- public void draw(Graphics2D g2) {
- try{
- infoPanel.draw(g2);
- g2.setClip(borderRect);
- area.draw(g2);
-
- g2.setStroke(stroke);
- for(Path p : area.paths){
- if(p.getEnemysInPath() != null){
- for(Enemy enemy : p.getEnemysInPath()){
- enemy.draw(g2);
- }
- }
- }
- if(player != null)
- player.draw(g2);
- }catch(Exception e){};
-
- }
-
-
- @Override
- public void buttonPressed(ButtonEvent e) {
- // int index = player.getIndex();
- Path currentPath = area.paths.get(player.getIndex());
- Enemy ce = currentPath.getEnemysInPath().getFirst();
- if(ce.isClickable()){
- if(ce.getColor().equals(e.getButton().getColor())){
- currentScore += ce.getTimeLeftToClick();
- currentPath.getEnemysInPath().remove(ce);
- }
- }
- }
- @Override
- public void buttonReleased(ButtonEvent e) {
- }
- @Override
- public void onJoystickMoved(JoystickEvent e) {
- switch(e.getJoystick().getPos()){
- case CENTER:
- break;
- case DOWN:
- player.setIndex(4);
- break;
- case DOWN_LEFT:
- player.setIndex(5);
- break;
- case DOWN_RIGHT:
- player.setIndex(3);
- break;
- case LEFT:
- player.setIndex(6);
- break;
- case RIGHT:
- player.setIndex(2);
- break;
- case UP:
- player.setIndex(0);
- break;
- case UP_LEFT:
- player.setIndex(7);
- break;
- case UP_RIGHT:
- player.setIndex(1);
- break;
- default:
- break;
- }
- }
- public void addEnemy(int pathID,Color color){
- Path path = area.paths.get(pathID);
- Enemy e = new Enemy(pathID,1,color,100,path.getP1(),path.getP2());
- path.getEnemysInPath().addLast(e);
- }
- }
|