diff options
author | Sébastien Dailly <sebastien@chimrod.com> | 2014-08-29 14:44:44 +0200 |
---|---|---|
committer | Sébastien Dailly <sebastien@chimrod.com> | 2014-08-29 14:44:44 +0200 |
commit | d48ac3970ef04a404c42f30c72cbdc327178f0dc (patch) | |
tree | 2425a3bd33d91623cf4ae95380bd875ff3bcf2a8 /qml/pages | |
parent | e0184289f4d95d1d41959b5e043c9584cc66cefb (diff) |
Update js code
Diffstat (limited to 'qml/pages')
-rw-r--r-- | qml/pages/Goban.qml | 84 |
1 files changed, 9 insertions, 75 deletions
diff --git a/qml/pages/Goban.qml b/qml/pages/Goban.qml index 0dee0c8..420d22d 100644 --- a/qml/pages/Goban.qml +++ b/qml/pages/Goban.qml @@ -1,6 +1,6 @@ import QtQuick 2.0 -import "../actions.js" as Actions +import "../javascript/goban_util.js" as Actions Item { @@ -54,6 +54,7 @@ Item { if (aw !== undefined) { aw.forEach(function (pos) { goban.getItemAt(pos[0], pos[1]).put(currentPlayer, false); +// Actions.addPiece(pos[0] + (pos[1] * goban.columns), goban, currentPlayer, false, true, true); }); } @@ -61,7 +62,7 @@ Item { if (ab !== undefined) { ab.forEach(function (pos) { goban.getItemAt(pos[0], pos[1]).put(!currentPlayer, false); - +// Actions.addPiece(pos[0] + (pos[1] * goban.columns), goban, !currentPlayer, false, true, true); }); } } @@ -106,78 +107,9 @@ Item { return; } - var point = repeater.itemAt(index); - var elementType = point.getType(); - - if (elementType !== "") { - return; - } - - var neighbors = Actions.getNeighbors(index, goban.columns, goban.rows); - - function isPlayer(x) { - return repeater.itemAt(x).getType() === (currentPlayer ? "white" : "black"); - } - - function isOponnent(x) { - return repeater.itemAt(x).getType() === (currentPlayer ? "black" : "white"); - } - - function freeOrChain(x) { - var pointType = repeater.itemAt(x).getType(); - return pointType === "" || pointType === (currentPlayer ? "white" : "black"); - } - - if (neighbors.length !== 0) { - - var somethingToRemove = false; - - point.put(currentPlayer, true); - - /* - * Check for pieces to remove. - */ - neighbors.filter(isOponnent).forEach(function(neighbor) { - - var piecesToRemove = Actions.getChainToRemove(neighbor, repeater, goban.columns, goban.rows, isOponnent); - if (piecesToRemove.length !== 0) { - somethingToRemove = true; - } - piecesToRemove.forEach(function(x) { - repeater.itemAt(x).remove(true); - }) - }); - - /* - * Check for suicide. - */ - if (!somethingToRemove) { - var suicides = Actions.getChainToRemove(index, repeater, goban.columns, goban.rows, isPlayer); - if (suicides.length !== 0) { -// suicides.forEach(function(x) { -// repeater.itemAt(x).remove(true); -// }); - point.remove(false); - currentPlayer = !currentPlayer; - } - - } - - /* - * Remove the marks in the cases. - * - * The call to getChainToRemove add marks on the cases in order to - * prevent infinite looping. We need to clean the cases before any new - * click. - * - * We do not need to remove them before as we are not filtering the - * same pieces. - */ - for (var i = 0; i < goban.columns * goban.rows; i++) { - repeater.itemAt(i).mark = false; - } + if (Actions.addPiece(index, goban, currentPlayer, true, false, false)) { + currentPlayer = !currentPlayer; } - currentPlayer = !currentPlayer; } @@ -233,8 +165,6 @@ Item { visible: (!((index === goban.columns - 1 && !limitRight) || (index === 0 && !limitLeft))); } - - } /* @@ -251,6 +181,10 @@ Item { return repeater.itemAt(x + y * columns) } + function getElementAtIndex(index) { + return repeater.itemAt(index); + } + Repeater { model: goban.columns * goban.rows id : repeater |