Skip to content

SayKos/ChessBoard

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

48 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

ChessBoard

Small library to help you to manage an entire chess game and serialize it to Json.

It helps you:

  • Create new game with start or specific chessmen positions or with Json serialized format;
  • Get acceptable cells for every chessman;
  • Make movements and get correct game status after it;
  • Serialize game to Json.

Usage

Serialized game

How does serialized game look like you can find here: StartPositions.json. Line breaks were added just for readability.

Board presentation

Board is two-dimensional array (8 rows and 8 columns). Board stored in BoardCells property of ChessBoard instance.

//       _________________________________
// 0	  |   |   |   |   |   |   |   |   |
//       _________________________________
// 1	  |   |   |   |   |   |   |   |   |
//       _________________________________
// 2	  |   |   |   |   |   |   |   |   |
//       _________________________________
// 3	  |   |   |   |   |   |   |   |   |
//       _________________________________
// 4	  |   |   |   |   |   |   |   |   |
//       _________________________________
// 5	  |   |   |   |   |   |   |   |   |
//       _________________________________
// 6	  |   |   |   |   |   |   |   |   |
//       _________________________________
// 7	  |   |   |   |   |   |   |   |   |
//       _________________________________
//			
//         0   1   2   3   4   5   6   7   
Cell cell = chessboard.BoardCells[3, 5]; // cell on 3 row and 5 column

Create new instance

New instance and set start position

var chessBoard = new ChessBoard();
chessBoard.SetStartPosition(); // Set default start positions for all chessmen and GameStatus.WhiteTurn status.

New instance with predefined board cells

var chessBoard = new ChessBoard(boardCells); // BoardCell[8, 8]

New instance with serialized chess board

var chessBoard = new ChessBoard(serializedChessBoard); // string

Get current status of the game

Status is enum that can be:

  • WhiteTurn,
  • BlackTurn,
  • ShahForWhite,
  • ShahForBlack,
  • WhiteWin,
  • BlackWin,
  • StalemateForBlack,
  • StalemateForWhite,
  • Draw
GameStatus status = chessboard.Status;

Also new status returned as result of MoveChessman method:

GameStatus status = chessboard.MoveChessman(oldPosition, newPosition);

Get serialized chess board

string status = chessboard.GetSerializedChessBoard();

Make movement for the specific chessman

To make movement you just need to specify old and new cells:

Cell oldPosition = new Cell(3, 5);
Cell newPosition = new Cell(3, 6);

GameStatus status = chessboard.MoveChessman(oldPosition, newPosition);

Also, in case of Pawn moving to the last row, you need to specify new type for Pawn transformation (promotion):

ChessmenType? newType = ChessmenType.Queen; // Can’t be as King or Pawn
GameStatus status = chessboard.MoveChessman(oldPosition, newPosition, newType);

Get acceptable cells for the specific cell

You can get acceptable cells for any chessman. You need to specify it’s cell:

Cell queenCell = new Cell(3, 5);
List<Cell> acceptableCells = chessboard.GetAcceptableCells(queenCell);

Stop game by giving up

It will set Status as BlackWin or WhiteWin depeding on specified Color.

chessboard.GiveUp(Color.Black);

Check that game is not over

Just checking that game status is not WhiteWin, BlackWin, StalemateForWhite, StalemateForBlack or Draw;

bool isGameOver = chessboard.IsGameOver();

About

Library to help manage of chess game

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages