diff options
| author | Ramaekers,Aldrik A.N <a.ramaekers@student.fontys.nl> | 2020-09-03 14:40:33 +0200 |
|---|---|---|
| committer | Ramaekers,Aldrik A.N <a.ramaekers@student.fontys.nl> | 2020-09-03 14:40:33 +0200 |
| commit | 5a045404f3c49022abeb75c27dfe6f82d35928f7 (patch) | |
| tree | a1dd8aa4091e9bf8d4377dc6d6f26cc9ca07ce47 /Pieces/Bishop.cs | |
| parent | 4811afb52c511565d2b13f36ed645243c7557803 (diff) | |
board setup and chess piece movement checks
Diffstat (limited to 'Pieces/Bishop.cs')
| -rw-r--r-- | Pieces/Bishop.cs | 42 |
1 files changed, 42 insertions, 0 deletions
diff --git a/Pieces/Bishop.cs b/Pieces/Bishop.cs new file mode 100644 index 0000000..10d1537 --- /dev/null +++ b/Pieces/Bishop.cs @@ -0,0 +1,42 @@ +using System; +using System.Collections.Generic; +using System.Drawing; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace Chess.Pieces +{ + class Bishop : ChessPiece + { + public Bishop(bool isWhite) : base(isWhite) + { + PieceImage = new Bitmap(!isWhite ? Chess.Properties.Resources.b_bishop_png_shadow_256px : Chess.Properties.Resources.w_bishop_png_shadow_256px); + } + + public override bool CanMoveTo(ChessBoard board, BoardTile currentTile, BoardTile destinationTile) + { + MoveCheckResult result; + + result = CanMoveDownLeft(board, currentTile, destinationTile); + if (result == MoveCheckResult.CanMove) return true; + if (result == MoveCheckResult.CantMove) return false; + + result = CanMoveDownRight(board, currentTile, destinationTile); + if (result == MoveCheckResult.CanMove) return true; + if (result == MoveCheckResult.CantMove) return false; + + result = CanMoveUpLeft(board, currentTile, destinationTile); + if (result == MoveCheckResult.CanMove) return true; + if (result == MoveCheckResult.CantMove) return false; + + result = CanMoveUpRight(board, currentTile, destinationTile); + if (result == MoveCheckResult.CanMove) return true; + if (result == MoveCheckResult.CantMove) return false; + + return false; + } + + + } +} |
