From 5e1a0f6da91ce76ded218b0ad1fcf06bde79b08d Mon Sep 17 00:00:00 2001 From: SeventhM <127357473+SeventhM@users.noreply.github.com> Date: Wed, 24 Jan 2024 13:44:02 -0800 Subject: [PATCH] Fix Spectator stats when viewing another civ (#10985) --- .../com/unciv/ui/screens/worldscreen/WorldScreen.kt | 2 ++ .../screens/worldscreen/bottombar/TileInfoTable.kt | 12 ++++++------ 2 files changed, 8 insertions(+), 6 deletions(-) diff --git a/core/src/com/unciv/ui/screens/worldscreen/WorldScreen.kt b/core/src/com/unciv/ui/screens/worldscreen/WorldScreen.kt index c9b71f9426..f05041d754 100644 --- a/core/src/com/unciv/ui/screens/worldscreen/WorldScreen.kt +++ b/core/src/com/unciv/ui/screens/worldscreen/WorldScreen.kt @@ -360,6 +360,8 @@ class WorldScreen( if (fogOfWar) minimapWrapper.update(selectedCiv) else minimapWrapper.update(viewingCiv) + if (fogOfWar) bottomTileInfoTable.selectedCiv = selectedCiv + else bottomTileInfoTable.selectedCiv = viewingCiv bottomTileInfoTable.updateTileTable(mapHolder.selectedTile) bottomTileInfoTable.x = stage.width - bottomTileInfoTable.width bottomTileInfoTable.y = if (game.settings.showMinimap) minimapWrapper.height else 0f diff --git a/core/src/com/unciv/ui/screens/worldscreen/bottombar/TileInfoTable.kt b/core/src/com/unciv/ui/screens/worldscreen/bottombar/TileInfoTable.kt index eebf2dd6c0..d5d234afb3 100644 --- a/core/src/com/unciv/ui/screens/worldscreen/bottombar/TileInfoTable.kt +++ b/core/src/com/unciv/ui/screens/worldscreen/bottombar/TileInfoTable.kt @@ -23,7 +23,7 @@ import com.unciv.ui.screens.worldscreen.WorldScreen import com.unciv.utils.DebugUtils class TileInfoTable(private val worldScreen: WorldScreen) : Table(BaseScreen.skin) { - val viewingCiv = worldScreen.viewingCiv + var selectedCiv = worldScreen.selectedCiv init { background = BaseScreen.skinStrings.getUiBackground( @@ -35,10 +35,10 @@ class TileInfoTable(private val worldScreen: WorldScreen) : Table(BaseScreen.ski internal fun updateTileTable(tile: Tile?) { clearChildren() - if (tile != null && (DebugUtils.VISIBLE_MAP || viewingCiv.hasExplored(tile)) ) { + if (tile != null && (DebugUtils.VISIBLE_MAP || selectedCiv.hasExplored(tile)) ) { add(getStatsTable(tile)) - add(MarkupRenderer.render(TileDescription.toMarkup(tile, viewingCiv), padding = 0f, iconDisplay = IconDisplay.None) { - UncivGame.Current.pushScreen(CivilopediaScreen(viewingCiv.gameInfo.ruleset, link = it)) + add(MarkupRenderer.render(TileDescription.toMarkup(tile, selectedCiv), padding = 0f, iconDisplay = IconDisplay.None) { + UncivGame.Current.pushScreen(CivilopediaScreen(selectedCiv.gameInfo.ruleset, link = it)) } ).pad(5f).row() if (DebugUtils.VISIBLE_MAP) add(tile.position.toPrettyString().toLabel()).colspan(2).pad(5f) @@ -54,7 +54,7 @@ class TileInfoTable(private val worldScreen: WorldScreen) : Table(BaseScreen.ski // padLeft = padRight + 5: for symmetry. An extra 5 for the distance yield number to // tile text comes from the pad up there in updateTileTable - for ((key, value) in tile.stats.getTileStats(viewingCiv)) { + for ((key, value) in tile.stats.getTileStats(selectedCiv)) { table.add(ImageGetter.getStatIcon(key.name)) .size(20f).align(Align.right).padLeft(10f) table.add(value.toInt().toLabel()) @@ -64,7 +64,7 @@ class TileInfoTable(private val worldScreen: WorldScreen) : Table(BaseScreen.ski table.touchable = Touchable.enabled table.onClick { Popup(worldScreen).apply { - for ((name, stats) in tile.stats.getTileStatsBreakdown(tile.getCity(), viewingCiv)) + for ((name, stats) in tile.stats.getTileStatsBreakdown(tile.getCity(), selectedCiv)) add("${name.tr()}: {${stats.clone()}}".toLabel()).row() addCloseButton() }.open()