diff --git a/src/ui/flutter/lib/mill/game.dart b/src/ui/flutter/lib/mill/game.dart index 2cb15a5e..115611fd 100644 --- a/src/ui/flutter/lib/mill/game.dart +++ b/src/ui/flutter/lib/mill/game.dart @@ -18,6 +18,7 @@ */ import 'package:sanmill/common/config.dart'; +import 'package:sanmill/engine/engine.dart'; import 'package:sanmill/mill/types.dart'; import 'mill.dart'; @@ -38,21 +39,44 @@ class Game { Map isSearching = {Color.black: false, Color.white: false}; + EngineType engineType; + bool aiIsSearching() { return isSearching[Color.black] == true || isSearching[Color.white] == true; } + void setWhoIsAi(EngineType type) { + engineType = type; + + switch (type) { + case EngineType.humanVsAi: + if (Config.whoMovesFirst == PlayerType.human) { + isAi[Color.black] = false; + isAi[Color.white] = true; + } else if (Config.whoMovesFirst == PlayerType.AI) { + isAi[Color.black] = true; + isAi[Color.white] = false; + } + break; + case EngineType.humanVsHuman: + isAi[Color.black] = false; + isAi[Color.white] = false; + break; + case EngineType.aiVsAi: + isAi[Color.black] = true; + isAi[Color.white] = true; + break; + case EngineType.humanVsCloud: + break; + default: + break; + } + } + void start() { position.reset(); - // TDOO - if (Config.whoMovesFirst == PlayerType.human) { - isAi[Color.black] = false; - isAi[Color.white] = true; - } else { - isAi[Color.black] = true; - isAi[Color.white] = false; - } + setWhoIsAi(engineType); } bool hasAnimation; diff --git a/src/ui/flutter/lib/widgets/game_page.dart b/src/ui/flutter/lib/widgets/game_page.dart index 1f6080f6..128b63ae 100644 --- a/src/ui/flutter/lib/widgets/game_page.dart +++ b/src/ui/flutter/lib/widgets/game_page.dart @@ -53,6 +53,10 @@ class _GamePageState extends State { @override void initState() { + print("engineType = ${widget.engineType}"); + + Game.shared.setWhoIsAi(widget.engineType); + super.initState(); Game.shared.init(); widget.engine.startup();