|
|
|
@ -1,23 +1,25 @@ |
|
|
|
|
|
|
|
class GameLogic{ |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
constructor(pieceList = [], missedOportunities = [], currentPlayer = "white") { |
|
|
|
|
|
|
|
this.pieceList = pieceList; |
|
|
|
|
|
|
|
this.missedOportunities = missedOportunities; |
|
|
|
|
|
|
|
this.currentPlayer = currentPlayer; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
const pieceList = new Array(); |
|
|
|
isMissedOportunity(pieceRecord) { |
|
|
|
missedOportunities = new Array(); |
|
|
|
|
|
|
|
currentPlayer = "white"; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function isMissedOportunity(pieceRecord) { |
|
|
|
|
|
|
|
const id = pieceRecord.id; |
|
|
|
const id = pieceRecord.id; |
|
|
|
return missedOportunities.includes(id); |
|
|
|
return this.missedOportunities.includes(id); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
function generateDefaultPositions(){ |
|
|
|
generateDefaultPositions(){ |
|
|
|
|
|
|
|
|
|
|
|
var id = 0; |
|
|
|
var id = 0; |
|
|
|
|
|
|
|
|
|
|
|
for (let i = 0; i < 8; i++) { |
|
|
|
for (let i = 0; i < 8; i++) { |
|
|
|
for (let j = 0; j < 3; j++) { |
|
|
|
for (let j = 0; j < 3; j++) { |
|
|
|
if((i+j) % 2 == 0){ |
|
|
|
if((i+j) % 2 == 0){ |
|
|
|
pieceRecord = {id:id, x:i, y:j, player:"white", type:"basic"}; |
|
|
|
const pieceRecord = {id:id, x:i, y:j, player:"white", type:"basic"}; |
|
|
|
pieceList.push(pieceRecord); |
|
|
|
this.pieceList.push(pieceRecord); |
|
|
|
id++; |
|
|
|
id++; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
@ -27,44 +29,44 @@ function generateDefaultPositions(){ |
|
|
|
for (let i = 0; i < 8; i++) { |
|
|
|
for (let i = 0; i < 8; i++) { |
|
|
|
for (let j = 5; j < 8; j++) { |
|
|
|
for (let j = 5; j < 8; j++) { |
|
|
|
if((i+j) % 2 == 0){ |
|
|
|
if((i+j) % 2 == 0){ |
|
|
|
pieceRecord = {id:id, x:i, y:j, player:"black", type:"basic"}; |
|
|
|
const pieceRecord = {id:id, x:i, y:j, player:"black", type:"basic"}; |
|
|
|
pieceList.push(pieceRecord); |
|
|
|
this.pieceList.push(pieceRecord); |
|
|
|
id++; |
|
|
|
id++; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
function getPieceRecord(x,y){ |
|
|
|
getPieceRecord(x,y){ |
|
|
|
if (x > 7 || x < 0 || y > 7 || y < 0) { |
|
|
|
if (x > 7 || x < 0 || y > 7 || y < 0) { |
|
|
|
return false; |
|
|
|
return false; |
|
|
|
} |
|
|
|
} |
|
|
|
return pieceList.find(pieceRecord => pieceRecord.x == x && pieceRecord.y == y); |
|
|
|
return this.pieceList.find(pieceRecord => pieceRecord.x == x && pieceRecord.y == y); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function nukePieceRecord(pieceRecord) { |
|
|
|
nukePieceRecord(pieceRecord) { |
|
|
|
const index = pieceList.findIndex(record => record.id == pieceRecord.id); |
|
|
|
const index = this.pieceList.findIndex(record => record.id == pieceRecord.id); |
|
|
|
pieceList.splice(index, 1); |
|
|
|
this.pieceList.splice(index, 1); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
function updatePieceRecord(pieceRecord) { |
|
|
|
updatePieceRecord(pieceRecord) { |
|
|
|
const index = pieceList.findIndex(record => record.id == pieceRecord.id); |
|
|
|
const index = this.pieceList.findIndex(record => record.id == pieceRecord.id); |
|
|
|
pieceList[index] = pieceRecord; |
|
|
|
this.pieceList[index] = pieceRecord; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
function updatePieceRecordPosition(pieceRecord, x, y) { |
|
|
|
updatePieceRecordPosition(pieceRecord, x, y) { |
|
|
|
pieceRecord.x = x; |
|
|
|
pieceRecord.x = x; |
|
|
|
pieceRecord.y = y; |
|
|
|
pieceRecord.y = y; |
|
|
|
updatePieceRecord(pieceRecord); |
|
|
|
this.updatePieceRecord(pieceRecord); |
|
|
|
return pieceRecord; |
|
|
|
return pieceRecord; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function getCasualties(oldX, oldY, newX, newY) { |
|
|
|
getCasualties(oldX, oldY, newX, newY) { |
|
|
|
const directionX = (newX > oldX) ? 1 : -1; |
|
|
|
const directionX = (newX > oldX) ? 1 : -1; |
|
|
|
const directionY = (newY > oldY) ? 1 : -1; |
|
|
|
const directionY = (newY > oldY) ? 1 : -1; |
|
|
|
|
|
|
|
|
|
|
|
@ -74,7 +76,7 @@ function getCasualties(oldX, oldY, newX, newY) { |
|
|
|
const x = oldX + (i*directionX); |
|
|
|
const x = oldX + (i*directionX); |
|
|
|
const y = oldY + (i*directionY); |
|
|
|
const y = oldY + (i*directionY); |
|
|
|
|
|
|
|
|
|
|
|
pieceRecord = getPieceRecord(x,y); |
|
|
|
pieceRecord = this.getPieceRecord(x,y); |
|
|
|
|
|
|
|
|
|
|
|
if (pieceRecord) { |
|
|
|
if (pieceRecord) { |
|
|
|
casualties.push(pieceRecord); |
|
|
|
casualties.push(pieceRecord); |
|
|
|
@ -83,19 +85,19 @@ function getCasualties(oldX, oldY, newX, newY) { |
|
|
|
|
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
return casualties; |
|
|
|
return casualties; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
function getLoser() { |
|
|
|
getLoser() { |
|
|
|
if (!pieceList.find(pieceRecord => pieceRecord.player == "white")) { |
|
|
|
if (!this.pieceList.find(pieceRecord => pieceRecord.player == "white")) { |
|
|
|
return "white"; |
|
|
|
return "white"; |
|
|
|
} |
|
|
|
} |
|
|
|
if (!pieceList.find(pieceRecord => pieceRecord.player == "black")) { |
|
|
|
if (!this.pieceList.find(pieceRecord => pieceRecord.player == "black")) { |
|
|
|
return "black"; |
|
|
|
return "black"; |
|
|
|
} |
|
|
|
} |
|
|
|
return null; |
|
|
|
return null; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
function continuableInDirectionForQueen(directionX, directionY, pieceRecord) { |
|
|
|
continuableInDirectionForQueen(directionX, directionY, pieceRecord) { |
|
|
|
|
|
|
|
|
|
|
|
const pieceX = pieceRecord.x; |
|
|
|
const pieceX = pieceRecord.x; |
|
|
|
const pieceY = pieceRecord.y; |
|
|
|
const pieceY = pieceRecord.y; |
|
|
|
@ -110,7 +112,7 @@ function continuableInDirectionForQueen(directionX, directionY, pieceRecord) { |
|
|
|
return false; |
|
|
|
return false; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
const record = getPieceRecord(x, y); |
|
|
|
const record = this.getPieceRecord(x, y); |
|
|
|
|
|
|
|
|
|
|
|
if (record) { |
|
|
|
if (record) { |
|
|
|
if (record.player == player) { |
|
|
|
if (record.player == player) { |
|
|
|
@ -118,8 +120,8 @@ function continuableInDirectionForQueen(directionX, directionY, pieceRecord) { |
|
|
|
return false; |
|
|
|
return false; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
const firstBlockRecord = getPieceRecord(x+directionX,y+directionY); |
|
|
|
const firstBlockRecord = this.getPieceRecord(x+directionX,y+directionY); |
|
|
|
const secondBlockRecord = getPieceRecord(x-directionX,y-directionY); |
|
|
|
const secondBlockRecord = this.getPieceRecord(x-directionX,y-directionY); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return ((!firstBlockRecord || firstBlockRecord.id == pieceRecord.id) && (!secondBlockRecord || secondBlockRecord.id == pieceRecord.id)); |
|
|
|
return ((!firstBlockRecord || firstBlockRecord.id == pieceRecord.id) && (!secondBlockRecord || secondBlockRecord.id == pieceRecord.id)); |
|
|
|
@ -129,67 +131,67 @@ function continuableInDirectionForQueen(directionX, directionY, pieceRecord) { |
|
|
|
|
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
return false; |
|
|
|
return false; |
|
|
|
} |
|
|
|
} |
|
|
|
function continuable(pieceRecord){ |
|
|
|
continuable(pieceRecord){ |
|
|
|
const x = pieceRecord.x; |
|
|
|
const x = pieceRecord.x; |
|
|
|
const y = pieceRecord.y; |
|
|
|
const y = pieceRecord.y; |
|
|
|
const player = pieceRecord.player; |
|
|
|
const player = pieceRecord.player; |
|
|
|
const type = pieceRecord.type; |
|
|
|
const type = pieceRecord.type; |
|
|
|
|
|
|
|
|
|
|
|
if(player == "white" && ((getPieceRecord(x+1, y+1) && getPieceRecord(x+1, y+1).player != player && !getPieceRecord(x+2, y+2) && (y+2) < 8 && (x+2) < 8) || ((getPieceRecord(x-1, y+1) && getPieceRecord(x-1, y+1).player != player && !getPieceRecord(x-2, y+2) && (y+2) < 8 && (x-2) > 0)))){ |
|
|
|
if(player == "white" && ((this.getPieceRecord(x+1, y+1) && this.getPieceRecord(x+1, y+1).player != player && !this.getPieceRecord(x+2, y+2) && (y+2) < 8 && (x+2) < 8) || ((this.getPieceRecord(x-1, y+1) && this.getPieceRecord(x-1, y+1).player != player && !this.getPieceRecord(x-2, y+2) && (y+2) < 8 && (x-2) > 0)))){ |
|
|
|
|
|
|
|
|
|
|
|
return true; |
|
|
|
return true; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
if( player == "black" && ((getPieceRecord(x+1, y-1) && getPieceRecord(x+1, y-1).player != player && !getPieceRecord(x+2, y-2) && (y-2) > 0 && (x+2) < 8) || ((getPieceRecord(x-1, y-1) && getPieceRecord(x-1, y-1).player != player && !getPieceRecord(x-2, y-2) && (y-2) > 0 && (x-2) > 0)))){ |
|
|
|
if( player == "black" && ((this.getPieceRecord(x+1, y-1) && this.getPieceRecord(x+1, y-1).player != player && !this.getPieceRecord(x+2, y-2) && (y-2) > 0 && (x+2) < 8) || ((this.getPieceRecord(x-1, y-1) && this.getPieceRecord(x-1, y-1).player != player && !this.getPieceRecord(x-2, y-2) && (y-2) > 0 && (x-2) > 0)))){ |
|
|
|
|
|
|
|
|
|
|
|
return true; |
|
|
|
return true; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
if(type == "queen"){ |
|
|
|
if(type == "queen"){ |
|
|
|
|
|
|
|
|
|
|
|
return (continuableInDirectionForQueen(1,1,pieceRecord) || continuableInDirectionForQueen(-1,-1,pieceRecord) || continuableInDirectionForQueen(-1,1,pieceRecord) || continuableInDirectionForQueen(1,-1,pieceRecord)); |
|
|
|
return (this.continuableInDirectionForQueen(1,1,pieceRecord) || this.continuableInDirectionForQueen(-1,-1,pieceRecord) || this.continuableInDirectionForQueen(-1,1,pieceRecord) || this.continuableInDirectionForQueen(1,-1,pieceRecord)); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
return false; |
|
|
|
return false; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
function getOportunities(pieceRecord){ |
|
|
|
getOportunities(pieceRecord){ |
|
|
|
const player = pieceRecord.player; |
|
|
|
const player = pieceRecord.player; |
|
|
|
const opportunities = new Array(); |
|
|
|
const opportunities = new Array(); |
|
|
|
|
|
|
|
|
|
|
|
pieceList.forEach(record => { |
|
|
|
this.pieceList.forEach(record => { |
|
|
|
if (record.player == player && record != pieceRecord && continuable(record)) { |
|
|
|
if (record.player == player && record != pieceRecord && this.continuable(record)) { |
|
|
|
|
|
|
|
|
|
|
|
opportunities.push(record.id); |
|
|
|
opportunities.push(record.id); |
|
|
|
} |
|
|
|
} |
|
|
|
}); |
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
return opportunities; |
|
|
|
return opportunities; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
function getOportunitiesIncludingSelf(pieceRecord){ |
|
|
|
getOportunitiesIncludingSelf(pieceRecord){ |
|
|
|
const player = pieceRecord.player; |
|
|
|
const player = pieceRecord.player; |
|
|
|
const opportunities = new Array(); |
|
|
|
const opportunities = new Array(); |
|
|
|
|
|
|
|
|
|
|
|
pieceList.forEach(record => { |
|
|
|
this.pieceList.forEach(record => { |
|
|
|
if (record.player == player && continuable(record)) { |
|
|
|
if (record.player == player && this.continuable(record)) { |
|
|
|
|
|
|
|
|
|
|
|
opportunities.push(record.id); |
|
|
|
opportunities.push(record.id); |
|
|
|
} |
|
|
|
} |
|
|
|
}); |
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
return opportunities; |
|
|
|
return opportunities; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
function isMoveValid(pieceRecord, x, y){ |
|
|
|
isMoveValid(pieceRecord, x, y){ |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if(0 > y > 7 || 0 > x > 7){ |
|
|
|
if(0 > y > 7 || 0 > x > 7){ |
|
|
|
return false; |
|
|
|
return false; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
if (getPieceRecord(x,y)) { |
|
|
|
if (this.getPieceRecord(x,y)) { |
|
|
|
return false; |
|
|
|
return false; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
@ -220,7 +222,7 @@ function isMoveValid(pieceRecord, x, y){ |
|
|
|
const nowX = currentX + (i*directionX); |
|
|
|
const nowX = currentX + (i*directionX); |
|
|
|
const nowY = currentY + (i*directionY); |
|
|
|
const nowY = currentY + (i*directionY); |
|
|
|
|
|
|
|
|
|
|
|
if (inWayPieceRecord = getPieceRecord(nowX, nowY)) { |
|
|
|
if (inWayPieceRecord = this.getPieceRecord(nowX, nowY)) { |
|
|
|
|
|
|
|
|
|
|
|
if(inWayPieceRecord.player == player){ |
|
|
|
if(inWayPieceRecord.player == player){ |
|
|
|
return false; |
|
|
|
return false; |
|
|
|
@ -245,12 +247,12 @@ function isMoveValid(pieceRecord, x, y){ |
|
|
|
|
|
|
|
|
|
|
|
return true; |
|
|
|
return true; |
|
|
|
|
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
function swapPlayers() {
|
|
|
|
swapPlayers() {
|
|
|
|
currentPlayer = (currentPlayer == "white") ? "black" : "white"; |
|
|
|
this.currentPlayer = (this.currentPlayer == "white") ? "black" : "white"; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
function makeMove(pieceRecord, x, y){ |
|
|
|
makeMove(pieceRecord, x, y){ |
|
|
|
const player = pieceRecord.player; |
|
|
|
const player = pieceRecord.player; |
|
|
|
|
|
|
|
|
|
|
|
if (!isMoveValid(pieceRecord, x, y)) { |
|
|
|
if (!isMoveValid(pieceRecord, x, y)) { |
|
|
|
@ -260,18 +262,18 @@ function makeMove(pieceRecord, x, y){ |
|
|
|
const oldX = pieceRecord.x; |
|
|
|
const oldX = pieceRecord.x; |
|
|
|
const oldY = pieceRecord.y; |
|
|
|
const oldY = pieceRecord.y; |
|
|
|
|
|
|
|
|
|
|
|
const casualties = getCasualties(oldX, oldY, x, y); |
|
|
|
const casualties = this.getCasualties(oldX, oldY, x, y); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
casualties.forEach(casualty => { |
|
|
|
casualties.forEach(casualty => { |
|
|
|
nukePieceRecord(casualty); |
|
|
|
this.nukePieceRecord(casualty); |
|
|
|
}); |
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
missedOportunities = new Array(); |
|
|
|
this.missedOportunities = new Array(); |
|
|
|
oportunities = getOportunitiesIncludingSelf(pieceRecord); |
|
|
|
oportunities = this.getOportunitiesIncludingSelf(pieceRecord); |
|
|
|
|
|
|
|
|
|
|
|
if(casualties.length == 0 && oportunities.length != 0) { |
|
|
|
if(casualties.length == 0 && oportunities.length != 0) { |
|
|
|
missedOportunities = oportunities; |
|
|
|
this.missedOportunities = oportunities; |
|
|
|
|
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
@ -285,22 +287,25 @@ function makeMove(pieceRecord, x, y){ |
|
|
|
|
|
|
|
|
|
|
|
const updatedPieceRecord = updatePieceRecordPosition(pieceRecord, x, y); |
|
|
|
const updatedPieceRecord = updatePieceRecordPosition(pieceRecord, x, y); |
|
|
|
|
|
|
|
|
|
|
|
if (continuable(updatedPieceRecord) && casualties.length > 0 && pieceRecord.type == original_type) { |
|
|
|
if (this.continuable(updatedPieceRecord) && casualties.length > 0 && pieceRecord.type == original_type) { |
|
|
|
return 2; |
|
|
|
return 2; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return 1; |
|
|
|
return 1; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
function nukePieceRecordThatMissedOportunity(pieceRecord) { |
|
|
|
nukePieceRecordThatMissedOportunity(pieceRecord) { |
|
|
|
if (missedOportunities.includes(pieceRecord.id)) { |
|
|
|
if (this.missedOportunities.includes(pieceRecord.id)) { |
|
|
|
missedOportunities = new Array(); |
|
|
|
this.missedOportunities = new Array(); |
|
|
|
nukePieceRecord(pieceRecord); |
|
|
|
this.nukePieceRecord(pieceRecord); |
|
|
|
return true; |
|
|
|
return true; |
|
|
|
} |
|
|
|
} |
|
|
|
return false; |
|
|
|
return false; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
generateDefaultPositions(); |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
module.exports = GameLogic; |