diff --git a/src/ui/flutter/lib/game/battle.dart b/src/ui/flutter/lib/game/battle.dart index c620f340..5aae5e54 100644 --- a/src/ui/flutter/lib/game/battle.dart +++ b/src/ui/flutter/lib/game/battle.dart @@ -38,7 +38,7 @@ class Battle { } newGame() { - Battle.shared.position.initDefaultPosition(); + Battle.shared.position.init(); _focusIndex = _blurIndex = Move.invalidIndex; } diff --git a/src/ui/flutter/lib/mill/position.dart b/src/ui/flutter/lib/mill/position.dart index 2c03c339..42b47019 100644 --- a/src/ui/flutter/lib/mill/position.dart +++ b/src/ui/flutter/lib/mill/position.dart @@ -94,6 +94,10 @@ class Position { _recorder = MillRecorder(lastCapturedPosition: fen()); } + init() { + Position.init(); + } + Position.boardToGrid() { _grid = List(); for (int sq = 0; sq < _board.length; sq++) { @@ -164,9 +168,20 @@ class Position { return selectPieceSQ(makeSquare(file, rank)); } - void putPiece(var pt, int index) { + bool putPiece(var pt, int index) { + var sq = indexToSquare[index]; + + if (sq == null) { + print("putPiece skip index: $index"); + return false; + } + _grid[index] = pt; - _board[indexToSquare[index]] = pt; + _board[sq] = pt; + + print("putPiece: pt = $pt, index = $index, sq = $sq"); + + return true; } bool putPieceFR(int file, int rank) { diff --git a/src/ui/flutter/lib/routes/battle_page.dart b/src/ui/flutter/lib/routes/battle_page.dart index 74c3f054..aee6dc16 100644 --- a/src/ui/flutter/lib/routes/battle_page.dart +++ b/src/ui/flutter/lib/routes/battle_page.dart @@ -51,7 +51,7 @@ class _BattlePageState extends State { String _status = ''; bool _analysising = false; - static int flag = 0; + //static int flag = 0; @override void initState() { @@ -72,8 +72,11 @@ class _BattlePageState extends State { final position = Battle.shared.position; //position - flag++; - position.putPiece(flag % 2 == 0 ? '@' : 'O', index); + //flag++; + //position.putPiece(flag % 2 == 0 ? '@' : 'O', index); + if (position.putPiece('@', index) == false) { + return; + } // 仅 Position 中的 side 指示一方能动棋 if (position.side != Color.black) return;