More efficient use of the charts space (#9505)

This commit is contained in:
Jack Rainy 2023-06-03 22:07:25 +03:00 committed by GitHub
parent 00712e49a8
commit aebd529400
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -13,6 +13,7 @@ import com.unciv.logic.civilization.Civilization
import com.unciv.ui.components.extensions.surroundWithCircle
import com.unciv.ui.screens.victoryscreen.VictoryScreenCivGroup
import com.unciv.ui.screens.victoryscreen.VictoryScreenCivGroup.DefeatedPlayerStyle
import kotlin.math.min
import kotlin.math.ceil
import kotlin.math.log10
import kotlin.math.max
@ -71,19 +72,18 @@ class LineChart(
return (0 until maxLabels + 1).map { (it * stepSize) }
}
private fun getNextNumberDivisibleByPowOfTen(maxValue: Int): Int {
val numberOfDigits = ceil(log10(maxValue.toDouble())).toInt()
val maxLabelValue = when {
numberOfDigits <= 0 -> 1
else -> {
// Some examples:
// If `maxValue = 97` => `oneWithZeros = 10^(2-1) = 10 => ceil(97/10) * 10 = 100
// If `maxValue = 567` => `oneWithZeros = 10^(3-1) = 100 => ceil(567/100) * 100 = 600
/**
* Returns the next number of power 10, with maximal step <= 100.
* Examples: 0 => 0, 3 => 10, 97 => 100, 567 => 600, 123321 => 123400
*/
private fun getNextNumberDivisibleByPowOfTen(value: Int): Int {
if (value == 0) return 0
val numberOfDigits = min(ceil(log10(value.toDouble())).toInt(), 3)
val oneWithZeros = 10.0.pow(numberOfDigits - 1)
ceil(maxValue.toDouble() / oneWithZeros).toInt() * oneWithZeros.toInt()
}
}
return maxLabelValue
// E.g., 3 => 10^(2-1) = 10 ; ceil(3 / 10) * 10 = 10
// 567 => 10^(3-1) = 100 ; ceil(567 / 100) * 100 = 600
// 123321 => 10^(3-1) = 100 ; ceil(123321 / 100) * 100 = 123400
return (ceil(value / oneWithZeros) * oneWithZeros).toInt()
}
override fun draw(batch: Batch, parentAlpha: Float) {