summaryrefslogtreecommitdiff
path: root/Pieces/Rook.cs
diff options
context:
space:
mode:
Diffstat (limited to 'Pieces/Rook.cs')
-rw-r--r--Pieces/Rook.cs40
1 files changed, 40 insertions, 0 deletions
diff --git a/Pieces/Rook.cs b/Pieces/Rook.cs
new file mode 100644
index 0000000..29c17c0
--- /dev/null
+++ b/Pieces/Rook.cs
@@ -0,0 +1,40 @@
+using System;
+using System.Collections.Generic;
+using System.Drawing;
+using System.Linq;
+using System.Text;
+using System.Threading.Tasks;
+
+namespace Chess.Pieces
+{
+ class Rook : ChessPiece
+ {
+ public Rook(bool isWhite) : base(isWhite)
+ {
+ PieceImage = new Bitmap(!isWhite ? Chess.Properties.Resources.b_rook_png_shadow_256px : Chess.Properties.Resources.w_rook_png_shadow_256px);
+ }
+
+ public override bool CanMoveTo(ChessBoard board, BoardTile currentTile, BoardTile destinationTile)
+ {
+ MoveCheckResult result;
+
+ result = CanMoveDown(board, currentTile, destinationTile);
+ if (result == MoveCheckResult.CanMove) return true;
+ if (result == MoveCheckResult.CantMove) return false;
+
+ result = CanMoveUp(board, currentTile, destinationTile);
+ if (result == MoveCheckResult.CanMove) return true;
+ if (result == MoveCheckResult.CantMove) return false;
+
+ result = CanMoveLeft(board, currentTile, destinationTile);
+ if (result == MoveCheckResult.CanMove) return true;
+ if (result == MoveCheckResult.CantMove) return false;
+
+ result = CanMoveRight(board, currentTile, destinationTile);
+ if (result == MoveCheckResult.CanMove) return true;
+ if (result == MoveCheckResult.CantMove) return false;
+
+ return false;
+ }
+ }
+}