Browse Source

Merge branch 'menu'

remotes/origin/visualizer
fdai2751 11 months ago
parent
commit
fad5780a76
  1. 28
      src/main/java/pacmanGame/GameManager.java
  2. 53
      src/main/java/pacmanGame/VisualizerPlainText.java

28
src/main/java/pacmanGame/GameManager.java

@ -9,9 +9,13 @@ public class GameManager {
public int score = 0;
public boolean ghostIsEdible = false;
public boolean isPaused;
public int livesRemaining;
public int failedAttempts;
public GameManager() {
setupGame();
livesRemaining = 3;
failedAttempts = 0;
setupGame();
}
public void setupGame(){
@ -23,14 +27,26 @@ public class GameManager {
for(int i = 0; i < ghosts.length; i++) {
ghosts[i] = new Ghost(this);
}
isPaused = false;
isPaused = false;
}
public void handleGhostCollision() {
livesRemaining--; // Reduziere verbleibende leben um 1
failedAttempts++; // Erhöhe die Anzahl der Fehlversuche
if(livesRemaining <= 0) {
gameOver(); //wenn Keine Leben mehr übrig sind.
}
}
public void gameOver() {
System.out.println("Das Spiel ist vorbei! Pech!!");
}
public void Update() {
visualizer.Update();
if(time%5 == 0) {
player.Move();
if(!isPaused) {
visualizer.Update();
if(time%5 == 0) {
player.Move();
}
}
if(time == 300) {
spawnCherry();

53
src/main/java/pacmanGame/VisualizerPlainText.java

@ -38,29 +38,42 @@ public class VisualizerPlainText implements Visualizer {
for(int y = 0; y < map.size.y; y++) {
for(int x = 0; x < map.size.x; x++) {
Cell cell = map.GetCell(new Vector2(x, map.size.y - 1 - y));
boolean containsGhosts = false;
boolean containsPlayer = false;
for( int i = 0; i < gameManager.ghosts.length; i++) {
if(gameManager.ghosts[i].position.equals(cell.pos)) {
containsGhosts = true;
}
}
if(gameManager.player.position.equals(cell.pos)) {
containsPlayer = true;
}
if(containsPlayer) {
output += playerSprite;
}
else if(containsGhosts) {
output += ghostSprite;
}
else if (sprites.containsKey(cell.type)) {
output += sprites.get(cell.type);
if(gameManager.isPaused && 5 < y && y <= 10){
if(x == 0) {
if(y == 8){
output += "Game Paused!";
}
else {
output += "";
}
}
}
else {
System.out.println("unknown type " + cell.type);
boolean containsGhosts = false;
boolean containsPlayer = false;
for( int i = 0; i < gameManager.ghosts.length; i++) {
if(gameManager.ghosts[i].position.equals(cell.pos)) {
containsGhosts = true;
}
}
if(gameManager.player.position.equals(cell.pos)) {
containsPlayer = true;
}
if(containsPlayer) {
output += playerSprite;
}
else if(containsGhosts) {
output += ghostSprite;
}
else if (sprites.containsKey(cell.type)) {
output += sprites.get(cell.type);
}
else {
System.out.println("unknown type" + cell.type);
}
}
}
output += "\n";

Loading…
Cancel
Save