summaryrefslogtreecommitdiff
path: root/Pieces/Bishop.cs
diff options
context:
space:
mode:
authorRamaekers,Aldrik A.N <a.ramaekers@student.fontys.nl>2020-09-03 14:40:33 +0200
committerRamaekers,Aldrik A.N <a.ramaekers@student.fontys.nl>2020-09-03 14:40:33 +0200
commit5a045404f3c49022abeb75c27dfe6f82d35928f7 (patch)
treea1dd8aa4091e9bf8d4377dc6d6f26cc9ca07ce47 /Pieces/Bishop.cs
parent4811afb52c511565d2b13f36ed645243c7557803 (diff)
board setup and chess piece movement checks
Diffstat (limited to 'Pieces/Bishop.cs')
-rw-r--r--Pieces/Bishop.cs42
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;
+ }
+
+
+ }
+}