From 45db23bd95f4945e235e2c2af7c2b24856cf35aa Mon Sep 17 00:00:00 2001 From: Damjan94 Date: Sun, 1 Jul 2018 15:18:25 +0200 Subject: [PATCH] added the ability to scroll the cities in cities overview screen (#187) * added the ability to scroll the cities in cities overview screen * fixed the includes * shortned the code a bit --- core/src/com/unciv/ui/EmpireOverviewScreen.kt | 101 +++++++++++------- 1 file changed, 65 insertions(+), 36 deletions(-) diff --git a/core/src/com/unciv/ui/EmpireOverviewScreen.kt b/core/src/com/unciv/ui/EmpireOverviewScreen.kt index b6642e64e5..249947f6ac 100644 --- a/core/src/com/unciv/ui/EmpireOverviewScreen.kt +++ b/core/src/com/unciv/ui/EmpireOverviewScreen.kt @@ -1,8 +1,7 @@ package com.unciv.ui -import com.badlogic.gdx.scenes.scene2d.ui.Label -import com.badlogic.gdx.scenes.scene2d.ui.Table -import com.badlogic.gdx.scenes.scene2d.ui.TextButton +import com.badlogic.gdx.scenes.scene2d.ui.* +import com.badlogic.gdx.utils.Align import com.unciv.UnCivGame import com.unciv.logic.civilization.CivilizationInfo import com.unciv.ui.utils.* @@ -11,14 +10,15 @@ import kotlin.math.roundToInt class EmpireOverviewScreen : CameraStageBaseScreen(){ init { val civInfo = UnCivGame.Current.gameInfo.getPlayerCivilization() - val closeButton = TextButton("Close".tr(), skin) + closeButton.addClickListener { UnCivGame.Current.setWorldScreen() } closeButton.y = stage.height - closeButton.height - 5 stage.addActor(closeButton) val table=Table() table.defaults().pad(20f) + table.add(getCityInfoTable(civInfo)) table.add(getHappinessTable(civInfo)) table.add(getGoldTable(civInfo)) @@ -26,8 +26,6 @@ class EmpireOverviewScreen : CameraStageBaseScreen(){ stage.addActor(table) } - - private fun getHappinessTable(civInfo: CivilizationInfo): Table { val happinessTable = Table(skin) happinessTable.defaults().pad(5f) @@ -60,39 +58,70 @@ class EmpireOverviewScreen : CameraStageBaseScreen(){ } private fun getCityInfoTable(civInfo: CivilizationInfo): Table { - val cityInfotable = Table() - cityInfotable.skin = skin - cityInfotable.defaults().pad(5f) - cityInfotable.add(Label("Cities", skin).setFont(24)).colspan(8).row() - cityInfotable.add() - cityInfotable.add(ImageGetter.getStatIcon("Population")).size(20f) - cityInfotable.add(ImageGetter.getStatIcon("Food")).size(20f) - cityInfotable.add(ImageGetter.getStatIcon("Gold")).size(20f) - cityInfotable.add(ImageGetter.getStatIcon("Science")).size(20f) - cityInfotable.add(ImageGetter.getStatIcon("Production")).size(20f) - cityInfotable.add(ImageGetter.getStatIcon("Culture")).size(20f) - cityInfotable.add(ImageGetter.getStatIcon("Happiness")).size(20f).row() + val iconSize = 20f//if you set this too low, there is a chance that the tables will be misaligned + val padding = 5f + + val cityInfoTableIcons = Table(skin) + cityInfoTableIcons.defaults().pad(padding).align(Align.center) + + cityInfoTableIcons.add(Label("Cities", skin).setFont(24)).colspan(8).align(Align.center).row() + cityInfoTableIcons.add() + cityInfoTableIcons.add(ImageGetter.getStatIcon("Population")).size(iconSize) + cityInfoTableIcons.add(ImageGetter.getStatIcon("Food")).size(iconSize) + cityInfoTableIcons.add(ImageGetter.getStatIcon("Gold")).size(iconSize) + cityInfoTableIcons.add(ImageGetter.getStatIcon("Science")).size(iconSize) + cityInfoTableIcons.add(ImageGetter.getStatIcon("Production")).size(iconSize) + cityInfoTableIcons.add(ImageGetter.getStatIcon("Culture")).size(iconSize) + cityInfoTableIcons.add(ImageGetter.getStatIcon("Happiness")).size(iconSize) + cityInfoTableIcons.pack() + + val cityInfoTableDetails = Table(skin) + cityInfoTableDetails.defaults().pad(padding).minWidth(iconSize).align(Align.left)//we need the min width so we can align the different tables for (city in civInfo.cities) { - cityInfotable.add(city.name) - cityInfotable.add(city.population.population.toString()) - cityInfotable.add(city.cityStats.currentCityStats.food.roundToInt().toString()) - cityInfotable.add(city.cityStats.currentCityStats.gold.roundToInt().toString()) - cityInfotable.add(city.cityStats.currentCityStats.science.roundToInt().toString()) - cityInfotable.add(city.cityStats.currentCityStats.production.roundToInt().toString()) - cityInfotable.add(city.cityStats.currentCityStats.culture.roundToInt().toString()) - cityInfotable.add(city.cityStats.currentCityStats.happiness.roundToInt().toString()).row() + cityInfoTableDetails.add(city.name) + cityInfoTableDetails.add(city.cityConstructions.getCityProductionTextForCityButton()).actor!!.setAlignment(Align.left) + cityInfoTableDetails.add(city.population.population.toString()).actor!!.setAlignment(Align.center) + cityInfoTableDetails.add(city.cityStats.currentCityStats.food.roundToInt().toString()).actor!!.setAlignment(Align.center) + cityInfoTableDetails.add(city.cityStats.currentCityStats.gold.roundToInt().toString()).actor!!.setAlignment(Align.center) + cityInfoTableDetails.add(city.cityStats.currentCityStats.science.roundToInt().toString()).actor!!.setAlignment(Align.center) + cityInfoTableDetails.add(city.cityStats.currentCityStats.production.roundToInt().toString()).actor!!.setAlignment(Align.center) + cityInfoTableDetails.add(city.cityStats.currentCityStats.culture.roundToInt().toString()).actor!!.setAlignment(Align.center) + cityInfoTableDetails.add(city.cityStats.currentCityStats.happiness.roundToInt().toString()).actor!!.setAlignment(Align.center) + cityInfoTableDetails.row() } - cityInfotable.add("Total") - cityInfotable.add(civInfo.cities.sumBy { it.population.population }.toString()) - cityInfotable.add("") - cityInfotable.add(civInfo.cities.sumBy { it.cityStats.currentCityStats.gold.toInt() }.toString()) - cityInfotable.add(civInfo.cities.sumBy { it.cityStats.currentCityStats.science.toInt() }.toString()) - cityInfotable.add("") - cityInfotable.add(civInfo.cities.sumBy { it.cityStats.currentCityStats.culture.toInt() }.toString()) - cityInfotable.add(civInfo.cities.sumBy { it.cityStats.currentCityStats.happiness.toInt() }.toString()) + cityInfoTableDetails.pack() - cityInfotable.pack() - return cityInfotable + val cityInfoScrollPane = ScrollPane(cityInfoTableDetails) + cityInfoScrollPane.pack() + cityInfoScrollPane.setOverscroll(false, false)//I think it feels better with no overscroll + + val cityInfoTableTotal = Table(skin) + cityInfoTableTotal.defaults().pad(padding).minWidth(iconSize)//we need the min width so we can align the different tables + + cityInfoTableTotal.add("Total") + cityInfoTableTotal.add(civInfo.cities.sumBy { it.population.population }.toString()).actor!!.setAlignment(Align.center) + cityInfoTableTotal.add()//an intended empty space + cityInfoTableTotal.add(civInfo.cities.sumBy { it.cityStats.currentCityStats.gold.toInt() }.toString()).actor!!.setAlignment(Align.center) + cityInfoTableTotal.add(civInfo.cities.sumBy { it.cityStats.currentCityStats.science.toInt() }.toString()).actor!!.setAlignment(Align.center) + cityInfoTableTotal.add()//an intended empty space + cityInfoTableTotal.add(civInfo.cities.sumBy { it.cityStats.currentCityStats.culture.toInt() }.toString()).actor!!.setAlignment(Align.center) + cityInfoTableTotal.add(civInfo.cities.sumBy { it.cityStats.currentCityStats.happiness.toInt() }.toString()).actor!!.setAlignment(Align.center) + + cityInfoTableTotal.pack() + + val table = Table(skin) + //since the names of the cities are on the left, and the length of the names varies + //we align every row to the right, coz we set the size of the other(number) cells to the image size + //and thus, we can guarantee that the tables will be aligned + table.defaults().pad(padding).align(Align.right) + + table.add(cityInfoTableIcons).row() + val height = if(cityInfoTableDetails.rows > 0) cityInfoTableDetails.getRowHeight(0)*4f else 100f //if there are no cities, set the height of the scroll pane to 100 + table.add(cityInfoScrollPane).width(cityInfoTableDetails.width).height(height).row() + table.add(cityInfoTableTotal) + table.pack() + + return table } } \ No newline at end of file