Merge pull request #212 from dagkalis/feature_186

turn number to negative on minus-btn long-press
This commit is contained in:
Tibor Kaputa 2021-11-03 23:06:25 +01:00 committed by GitHub
commit cdf1cbf4e0
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 23 additions and 0 deletions

View file

@ -42,6 +42,10 @@ class MainActivity : SimpleActivity(), Calculator {
btn_power.setOnClickListener { calc.handleOperation(POWER); checkHaptic(it) }
btn_root.setOnClickListener { calc.handleOperation(ROOT); checkHaptic(it) }
btn_minus.setOnLongClickListener {
calc.turnToNegative()
}
btn_clear.setOnClickListener { calc.handleClear(); checkHaptic(it) }
btn_clear.setOnLongClickListener { calc.handleReset(); true }

View file

@ -123,6 +123,25 @@ class CalculatorImpl(calculator: Calculator, private val context: Context) {
showNewResult(inputDisplayedFormula)
}
fun turnToNegative(): Boolean {
if (inputDisplayedFormula.isEmpty()) {
return false
}
if (!inputDisplayedFormula.trimStart('-').any { it.toString() in operations } && inputDisplayedFormula.replace(",", "").toDouble() != 0.0) {
inputDisplayedFormula = if (inputDisplayedFormula.first() == '-') {
inputDisplayedFormula.substring(1)
} else {
"-$inputDisplayedFormula"
}
showNewResult(inputDisplayedFormula)
return true
}
return false
}
// handle percents manually, it doesn't seem to be possible via net.objecthunter:exp4j. "%" is used only for modulo there
private fun handlePercent() {
var result = calculatePercentage(baseValue, getSecondValue(), lastOperation)