summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Jan Mulder <jlmulder@xs4all.nl>2017-08-07 13:07:36 +0200
committerGravatar Dirk Hohndel <dirk@hohndel.org>2017-08-10 09:13:26 -0700
commita072c635bc8a952a7d1386783ccc91d6381e8114 (patch)
treea2c26d6006f728258fa2854f5d42b4b55b99539a
parent9f290dcdb0395711a38540f79d04e7748cbdde3e (diff)
downloadsubsurface-a072c635bc8a952a7d1386783ccc91d6381e8114.tar.gz
fix weights rounding
Simplify and fix prestation of weights. Due to the attempt to round only the grams part (by just adding 50 to it, and truncating afterwards) a weird effect was introduced. For example, a value 0.98 was presented as 0.10. Just replay the old logic, and see what happens. Rewrote the logic to a simpler and better one. fixes: #532 Signed-off-by: Jan Mulder <jlmulder@xs4all.nl>
-rw-r--r--core/qthelper.cpp8
1 files changed, 2 insertions, 6 deletions
diff --git a/core/qthelper.cpp b/core/qthelper.cpp
index 0c5446e6a..b9698e6b8 100644
--- a/core/qthelper.cpp
+++ b/core/qthelper.cpp
@@ -43,12 +43,8 @@ QString weight_string(int weight_in_grams)
{
QString str;
if (get_units()->weight == units::KG) {
- int gr = weight_in_grams % 1000;
- int kg = weight_in_grams / 1000;
- if (kg >= 20.0)
- str = QString("%1").arg(kg + (gr >= 500 ? 1 : 0));
- else
- str = QString("%1.%2").arg(kg).arg((unsigned)(gr + 50) / 100);
+ double kg = (double) weight_in_grams / 1000.0;
+ str = QString("%1").arg(kg, 0, 'f', kg >= 20.0 ? 0 : 1);
} else {
double lbs = grams_to_lbs(weight_in_grams);
str = QString("%1").arg(lbs, 0, 'f', lbs >= 40.0 ? 0 : 1);