| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287 |
- 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.drawObjects.Enemy;
- import model.drawObjects.Player;
- import model.objects.InfoPanel;
- import model.objects.Path;
- import model.objects.PlayArea;
- import model.objects.highscore.Highscore;
- import audio.ButtonInstance;
- import audio.ObjectInstance;
- import control.GameStateManager;
- import control.SongHandler;
- import control.GameStateManager.State;
- import control.button.Button;
- import control.button.ButtonEvent;
- import control.button.ButtonHandler;
- import control.joystick.JoystickEvent;
- import data.io.SQLConnector;
- 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;
- private Stroke borderStroke;
- public static int sizeOfEnemy = 40;
- public static int currentScore = 0;
- public static int comboScore = 0;
- public static double lifePoints = 100;
-
- private int enemies_hit = 0;
- private int enemies_missed = 0;
- private int buttons_pressed = 0;
- private int joystick_moved = 0;
-
- private boolean init = false;
- private static boolean won = false;
- private long oldProgress = 0;
- public PlayState(GameStateManager gsm, SongHandler sh, SQLConnector sql) {
- super(gsm, sh, sql);
- infoPanel = new InfoPanel(sh);
- area = new PlayArea(256, 1024, 1024, 125);
- player = new Player(1280 - 1024 + 1024 / 2, 1024 / 2);
- stroke = new BasicStroke(sizeOfEnemy, BasicStroke.CAP_ROUND, BasicStroke.JOIN_ROUND);
- borderStroke = new BasicStroke(sizeOfEnemy+2, BasicStroke.CAP_ROUND, BasicStroke.JOIN_ROUND);
- }
- @Override
- public void init() {
- init = true;
- won = false;
- lifePoints = 100;
- currentScore = 0;
- comboScore = 0;
- oldProgress = 0;
-
- enemies_hit = 0;
- enemies_missed = 0;
- buttons_pressed = 0;
- joystick_moved = 0;
- Highscore h = sql.getHighscore(sh.getCurrentSong(), sh.getCurrentSongInstance());
- if(h != null)
- infoPanel.init(h.getScore());
-
- for(Path p : area.paths)
- {
- p.getEnemysInPath().clear();
- }
-
- ButtonHandler.getButton(1).setColor(sh.getCurrentSongInstance().getButtons().get(0).getColor());
-
- sh.play();
- init = false;
- }
- @Override
- public void update(float factor) {
- if(init)
- return;
-
- long progress = (long) ((sh.getProgress() / 1000) + (Enemy.secondsToEnd * 1000));
- for (ButtonInstance bu : sh.getCurrentSongInstance().getButtonsBetween(oldProgress, progress)) {
- Button b = ButtonHandler.getButton(bu.getButtonID());
- b.setColor(bu.getColor());
- }
- for (ObjectInstance ob : sh.getCurrentSongInstance().getObjectsBetween(oldProgress, progress)) {
- Path p = area.paths.get(ob.getDirection());
- p.addEnemy(ob.getColor(), ob.getDirection(), (int) ob.getLength());
- }
-
- if(progress > sh.getCurrentSongInstance().getEndTime() + Enemy.secondsToEnd*2500){
- won = true;
- endGame();
- }
-
- oldProgress = progress;
- Enemy closedEnemy = null;
- player.update(factor);
- for (Path path : area.paths) {
- Iterator<Enemy> enemyIterator = path.getEnemysInPath().iterator();
- while (enemyIterator.hasNext()) {
- Enemy e = enemyIterator.next();
- if (e.getDistanceFromStart() > Enemy.distanceToOctagon + (sizeOfEnemy * 1.5)) {
- enemyIterator.remove();
- lifePoints -= 6;
- comboScore /= 2;
- enemies_missed++;
- }
- if(closedEnemy == null){
- closedEnemy = e;
- }
- if((Enemy.distanceToOctagon-closedEnemy.getDistanceFromStart()) > (Enemy.distanceToOctagon-e.getDistanceFromStart())){
- closedEnemy = e;
- }
- e.update(factor);
- }
- }
- lifePoints -= 0.003 * factor;
-
- infoPanel.updateIPanel();
-
- if(lifePoints <= 0)
- {
- endGame();
- }
- if(comboScore >= 100)
- {
- comboScore = 0;
- currentScore += 500;
- }
-
- area.count();
- if(closedEnemy == null){
- area.pathPainted(-1, null);
- }else{
- area.pathPainted(closedEnemy.getIndex(), closedEnemy.getColor());
- }
- }
- private void endGame() {
- if(sh.getProgress()/1000 > 5000)
- {
- sql.addPlaydata(sh.getCurrentSong(), sh.getCurrentSongInstance(), sh.getProgress()/1000, enemies_missed, enemies_hit, buttons_pressed, joystick_moved);
- sh.getCurrentSongInstance().played();
- }
-
- if(currentScore == 0)
- gsm.setState(State.MENU_STATE);
- else
- gsm.setState(State.END_STATE);
- }
- @Override
- public void draw(Graphics2D g2) {
- try {
- infoPanel.draw(g2);
- g2.setClip(borderRect);
- area.draw(g2);
- for (Path p : area.paths) {
- if (p.getEnemysInPath() != null) {
- for (Enemy enemy : p.getEnemysInPath()) {
- g2.setStroke(borderStroke);
- enemy.draw(g2, true);
- g2.setStroke(stroke);
- enemy.draw(g2);
- }
- }
- }
- if (player != null)
- player.draw(g2);
- } catch (Exception e) {
- }
- }
- @Override
- public void buttonPressed(ButtonEvent e) {
- boolean notHit = true;
- Iterator<Enemy> enemysInPath = area.paths.get(player.getIndex()).getEnemysInPath().iterator();
- while (enemysInPath.hasNext()) {
- Enemy enemy = enemysInPath.next();
- if (enemy.getDistanceFromStart() > Enemy.distanceToOctagon || enemy.getDistanceFromStart() > Enemy.distanceToOctagon + sizeOfEnemy) {
- if (e.getButton().getColor().equals(enemy.getColor())) {
- currentScore += enemy.getDistanceFromStart() - Enemy.distanceToOctagon;
- comboScore += 5;
- lifePoints = Math.min(lifePoints+8, 100);
- area.setHitAreaColor(enemy.getColor());
- area.hit();
- enemies_hit++;
- enemysInPath.remove();
- notHit = false;
- break;
- }
- }
- }
-
- player.setBeat();
- if(notHit)
- {
- if(area.paths.get(player.getIndex()).getEnemysInPath().size() > 0)
- {
- lifePoints -= 1.5;
- }
- }
-
- if(e.getButton().getButtonID() == 0)
- {
- endGame();
- }
- else
- buttons_pressed++;
- }
- @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;
- }
- joystick_moved++;
- }
- public void addEnemy(int pathID, Color color) {
- Path path = area.paths.get(pathID);
- Enemy e = new Enemy(pathID, 1, color, path);
- path.getEnemysInPath().addLast(e);
- }
-
- public static boolean won(){
- return won;
- }
- }
|