diff options
| author | Bananeweizen <Bananeweizen@gmx.de> | 2013-05-19 10:47:35 -0700 |
|---|---|---|
| committer | Bananeweizen <Bananeweizen@gmx.de> | 2013-05-19 10:47:35 -0700 |
| commit | 2877ae13cb8084ab777cbb89b7c546a36abb0884 (patch) | |
| tree | 739544443fdb2ab0dd8b7edbe56eb4d2a65849f7 /main/src | |
| parent | 87b0d529c01ade9b3efb68b88696677be866600b (diff) | |
| parent | a654659a06a14df7c04e5123ec30040a32e1450b (diff) | |
| download | cgeo-2877ae13cb8084ab777cbb89b7c546a36abb0884.zip cgeo-2877ae13cb8084ab777cbb89b7c546a36abb0884.tar.gz cgeo-2877ae13cb8084ab777cbb89b7c546a36abb0884.tar.bz2 | |
Merge pull request #2719 from campbeb/fix2714
Fix #2714 - Support imperial units in compass speech
Diffstat (limited to 'main/src')
| -rw-r--r-- | main/src/cgeo/geocaching/speech/TextFactory.java | 37 |
1 files changed, 28 insertions, 9 deletions
diff --git a/main/src/cgeo/geocaching/speech/TextFactory.java b/main/src/cgeo/geocaching/speech/TextFactory.java index 6b25147..0e13564 100644 --- a/main/src/cgeo/geocaching/speech/TextFactory.java +++ b/main/src/cgeo/geocaching/speech/TextFactory.java @@ -1,8 +1,10 @@ package cgeo.geocaching.speech; import cgeo.geocaching.R; +import cgeo.geocaching.Settings; import cgeo.geocaching.cgeoapplication; import cgeo.geocaching.geopoint.Geopoint; +import cgeo.geocaching.geopoint.IConversion; import cgeo.geocaching.utils.AngleUtils; import java.util.Locale; @@ -21,18 +23,35 @@ public class TextFactory { private static String getDistance(Geopoint position, Geopoint target) { float kilometers = position.distanceTo(target); - if (kilometers >= 5.0) { - return getString(R.string.tts_kilometers, String.valueOf(Math.round(kilometers))); + + if (Settings.isUseMetricUnits()) { + if (kilometers >= 5.0) { + return getString(R.string.tts_kilometers, String.valueOf(Math.round(kilometers))); + } + if (kilometers >= 1.0) { + String digits = String.format(Locale.getDefault(), "%.1f", kilometers); + return getString(R.string.tts_kilometers, digits); + } + int meters = (int) (kilometers * 1000.0); + if (meters > 50) { + return getString(R.string.tts_meters, String.valueOf(Math.round(meters / 10.0) * 10)); + } + return getString(R.string.tts_meters, String.valueOf(meters)); + } + + float miles = kilometers / IConversion.MILES_TO_KILOMETER; + if (miles >= 3.0) { + return getString(R.string.tts_miles, String.valueOf(Math.round(miles))); } - if (kilometers >= 1.0) { - String digits = String.format(Locale.getDefault(), "%.1f", kilometers); - return getString(R.string.tts_kilometers, digits); + if (miles >= 0.2) { // approx 1000 ft + String digits = String.format(Locale.getDefault(), "%.1f", miles); + return getString(R.string.tts_miles, digits); } - int meters = (int) (kilometers * 1000.0); - if (meters > 50) { - return getString(R.string.tts_meters, String.valueOf(Math.round(meters / 10.0) * 10)); + int feet = (int) (kilometers * 1000.0 * IConversion.METERS_TO_FEET); + if (feet > 300) { + return getString(R.string.tts_feet, String.valueOf(Math.round(feet / 10.0) * 10)); } - return getString(R.string.tts_meters, String.valueOf(meters)); + return getString(R.string.tts_feet, String.valueOf(feet)); } private static String getString(int resourceId, Object... formatArgs) { |
