Compare commits
No commits in common. "fe3a5dec5b613c97b4e01ad4e1e12985ed7c320b" and "2e42de650dfebb4697d3c4bf80927fad613e2a5d" have entirely different histories.
fe3a5dec5b
...
2e42de650d
|
|
@ -1,8 +1,7 @@
|
||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
|
||||||
<project xmlns="http://maven.apache.org/POM/4.0.0"
|
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||||
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
|
|
||||||
<groupId>de.hs-mannheim.informatik.schach</groupId>
|
<groupId>de.hs-mannheim.informatik.schach</groupId>
|
||||||
|
|
@ -11,6 +10,7 @@
|
||||||
|
|
||||||
<name>schach</name>
|
<name>schach</name>
|
||||||
<description>A simple schach.</description>
|
<description>A simple schach.</description>
|
||||||
|
<!-- FIXME change it to the project's website -->
|
||||||
<url>http://www.example.com</url>
|
<url>http://www.example.com</url>
|
||||||
|
|
||||||
<properties>
|
<properties>
|
||||||
|
|
@ -19,31 +19,16 @@
|
||||||
<maven.compiler.target>8</maven.compiler.target>
|
<maven.compiler.target>8</maven.compiler.target>
|
||||||
</properties>
|
</properties>
|
||||||
|
|
||||||
<repositories>
|
|
||||||
<repository>
|
|
||||||
<id>jitpack.io</id>
|
|
||||||
<url>https://jitpack.io</url>
|
|
||||||
</repository>
|
|
||||||
</repositories>
|
|
||||||
|
|
||||||
<dependencies>
|
<dependencies>
|
||||||
<!-- Schachlib (bhlangonijr) -->
|
|
||||||
<dependency>
|
|
||||||
<groupId>com.github.bhlangonijr</groupId>
|
|
||||||
<artifactId>chesslib</artifactId>
|
|
||||||
<version>1.3.4</version>
|
|
||||||
</dependency>
|
|
||||||
<!-- JUnit 3 (wie im Template, ggf. auf JUnit 4/5 upgraden für moderne Projekte) -->
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>junit</groupId>
|
<groupId>junit</groupId>
|
||||||
<artifactId>junit</artifactId>
|
<artifactId>junit</artifactId>
|
||||||
<version>3.8.1</version>
|
<version>3.8.1</version>
|
||||||
<scope>test</scope>
|
|
||||||
</dependency>
|
</dependency>
|
||||||
</dependencies>
|
</dependencies>
|
||||||
|
|
||||||
<build>
|
<build>
|
||||||
<pluginManagement>
|
<pluginManagement><!-- lock down plugins versions to avoid using Maven defaults (may be moved to parent pom) -->
|
||||||
<plugins>
|
<plugins>
|
||||||
<plugin>
|
<plugin>
|
||||||
<artifactId>maven-clean-plugin</artifactId>
|
<artifactId>maven-clean-plugin</artifactId>
|
||||||
|
|
@ -57,6 +42,7 @@
|
||||||
<artifactId>maven-project-info-reports-plugin</artifactId>
|
<artifactId>maven-project-info-reports-plugin</artifactId>
|
||||||
<version>3.6.1</version>
|
<version>3.6.1</version>
|
||||||
</plugin>
|
</plugin>
|
||||||
|
<!-- see http://maven.apache.org/ref/current/maven-core/default-bindings.html#Plugin_bindings_for_jar_packaging -->
|
||||||
<plugin>
|
<plugin>
|
||||||
<artifactId>maven-resources-plugin</artifactId>
|
<artifactId>maven-resources-plugin</artifactId>
|
||||||
<version>3.3.1</version>
|
<version>3.3.1</version>
|
||||||
|
|
|
||||||
|
|
@ -1,11 +1,9 @@
|
||||||
package de.hs_mannheim.informatik.chess.main;
|
package de.hs_mannheim.informatik.chess.main;
|
||||||
import de.hs_mannheim.informatik.chess.gui.Gui;
|
import de.hs_mannheim.informatik.chess.gui.Gui;
|
||||||
|
|
||||||
|
|
||||||
public class Main{
|
public class Main{
|
||||||
|
|
||||||
public static void main( String[] args ){
|
public static void main( String[] args ){
|
||||||
new Gui();
|
new Gui();
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,90 +1,5 @@
|
||||||
package de.hs_mannheim.informatik.chess.model;
|
package de.hs_mannheim.informatik.chess.model;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import com.github.bhlangonijr.chesslib.Board;
|
|
||||||
import com.github.bhlangonijr.chesslib.Piece;
|
|
||||||
import com.github.bhlangonijr.chesslib.Square;
|
|
||||||
import com.github.bhlangonijr.chesslib.move.Move;
|
|
||||||
|
|
||||||
public class ChessEngine {
|
public class ChessEngine {
|
||||||
private Board board;
|
|
||||||
|
|
||||||
public ChessEngine() {
|
|
||||||
board = new Board();
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean move(String from, String to) {
|
|
||||||
Move move = new Move(Square.valueOf(from.toUpperCase()), Square.valueOf(to.toUpperCase()));
|
|
||||||
if (board.legalMoves().contains(move)) {
|
|
||||||
board.doMove(move);
|
|
||||||
return true;
|
|
||||||
} else {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public List<String> getLegalDestinations(String from) {
|
|
||||||
List<String> destinations = new ArrayList<>();
|
|
||||||
Square fromSq = Square.valueOf(from.toUpperCase());
|
|
||||||
for (Move move : board.legalMoves()) {
|
|
||||||
if (move.getFrom().equals(fromSq)) {
|
|
||||||
destinations.add(move.getTo().toString()); // z.B. "E4"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return destinations;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getPieceAt(String square) {
|
|
||||||
Piece piece = board.getPiece(Square.valueOf(square.toUpperCase()));
|
|
||||||
return piece.toString(); // z.B. "WHITE_PAWN"
|
|
||||||
}
|
|
||||||
|
|
||||||
public String[][] getBoardUnicode() {
|
|
||||||
String[][] unicodeBoard = new String[8][8];
|
|
||||||
for (int rank = 8; rank >= 1; rank--) {
|
|
||||||
for (int file = 0; file < 8; file++) {
|
|
||||||
Square square = Square.valueOf("" + (char)('A' + file) + rank);
|
|
||||||
Piece piece = board.getPiece(square);
|
|
||||||
unicodeBoard[8-rank][file] = pieceToUnicode(piece);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return unicodeBoard;
|
|
||||||
}
|
|
||||||
|
|
||||||
private String pieceToUnicode(Piece piece) {
|
|
||||||
switch (piece) {
|
|
||||||
case WHITE_KING: return "♔";
|
|
||||||
case WHITE_QUEEN: return "♕";
|
|
||||||
case WHITE_ROOK: return "♖";
|
|
||||||
case WHITE_BISHOP: return "♗";
|
|
||||||
case WHITE_KNIGHT: return "♘";
|
|
||||||
case WHITE_PAWN: return "♙";
|
|
||||||
case BLACK_KING: return "♚";
|
|
||||||
case BLACK_QUEEN: return "♛";
|
|
||||||
case BLACK_ROOK: return "♜";
|
|
||||||
case BLACK_BISHOP: return "♝";
|
|
||||||
case BLACK_KNIGHT: return "♞";
|
|
||||||
case BLACK_PAWN: return "♟";
|
|
||||||
default: return " ";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean isMated() {
|
|
||||||
return board.isMated();
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean isStalemate() {
|
|
||||||
return board.isStaleMate();
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean isDraw() {
|
|
||||||
return board.isDraw();
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getCurrentPlayer() {
|
|
||||||
return board.getSideToMove().toString(); // "WHITE" oder "BLACK"
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue