diff --git a/GameObjects/GameObjects/Architecture.cs b/GameObjects/GameObjects/Architecture.cs index 926ab29e..2c5eaf69 100644 --- a/GameObjects/GameObjects/Architecture.cs +++ b/GameObjects/GameObjects/Architecture.cs @@ -703,9 +703,18 @@ public void AI() this.AIWork(false); this.AITransfer(); this.InsideTacticsAI(); + this.AIExpand(); ExtensionInterface.call("AIArchitecture", new Object[] { this.Scenario, this }); } + private void AIExpand() + { + if (this.ExpandAvail()) + { + this.Expand(); + } + } + private void AIExecute() { if (base.Scenario.IsPlayer(this.BelongedFaction)) return; @@ -13429,6 +13438,27 @@ public bool ExpandAvail() return true; } + public void Expand() + { + this.Fund -= this.ExpandFund(); + foreach (Point point in this.ExpandPoint()) + { + this.ArchitectureArea.AddPoint(point); + } + + + this.ContactArea = this.ArchitectureArea.GetContactArea(false); + this.ViewArea = GameArea.GetAreaFromArea(this.ArchitectureArea, this.ViewDistance, this.Kind.HasObliqueView, base.Scenario, this.BelongedFaction); + this.LongViewArea = GameArea.GetAreaFromArea(this.ArchitectureArea, this.LongViewDistance, this.Kind.HasObliqueView, base.Scenario, this.BelongedFaction); + this.BaseFoodSurplyArea = this.LongViewArea; + + foreach (Point point in this.ArchitectureArea.Area) + { + base.Scenario.MapTileData[point.X, point.Y].TileArchitecture = this; + } + + base.Scenario.SetMapTileArchitecture(this); + } public PersonList meifaxianhuaiyundefeiziliebiao() { diff --git a/WorldOfTheThreeKingdoms/YouxiPingmu/ScreenManager.cs b/WorldOfTheThreeKingdoms/YouxiPingmu/ScreenManager.cs index fb83154e..e24c2d95 100644 --- a/WorldOfTheThreeKingdoms/YouxiPingmu/ScreenManager.cs +++ b/WorldOfTheThreeKingdoms/YouxiPingmu/ScreenManager.cs @@ -1094,24 +1094,7 @@ public void SetCreatingTroopPosition(Point position) internal void ArchitectureExpand() { - this.CurrentArchitecture.Fund -= this.CurrentArchitecture.ExpandFund(); - foreach (Point point in this.CurrentArchitecture.ExpandPoint()) - { - this.CurrentArchitecture.ArchitectureArea.AddPoint(point); - } - - - this.CurrentArchitecture.ContactArea = this.CurrentArchitecture.ArchitectureArea.GetContactArea(false); - this.CurrentArchitecture.ViewArea = GameArea.GetAreaFromArea(this.CurrentArchitecture.ArchitectureArea, this.CurrentArchitecture.ViewDistance, this.CurrentArchitecture.Kind.HasObliqueView, this.gameScenario, this.CurrentArchitecture.BelongedFaction); - this.CurrentArchitecture.LongViewArea = GameArea.GetAreaFromArea(this.CurrentArchitecture.ArchitectureArea, this.CurrentArchitecture.LongViewDistance, this.CurrentArchitecture.Kind.HasObliqueView, this.gameScenario, this.CurrentArchitecture.BelongedFaction); - this.CurrentArchitecture.BaseFoodSurplyArea = this.CurrentArchitecture.LongViewArea; - - foreach (Point point in this.CurrentArchitecture.ArchitectureArea.Area) - { - this.gameScenario.MapTileData[point.X, point.Y].TileArchitecture = this.CurrentArchitecture; - } - - this.gameScenario.SetMapTileArchitecture(this.CurrentArchitecture); + this.CurrentArchitecture.Expand(); } }