#pragma once #include "geometry/point2d.hpp" #include "base/assert.hpp" #include namespace measurement_utils { enum class Units { Metric = 0, Imperial = 1 }; inline std::string DebugPrint(Units units) { switch (units) { case Units::Imperial: return "Units::Imperial"; case Units::Metric: return "Units::Metric"; } CHECK_SWITCH(); } inline double MetersToMiles(double m) { return m * 0.000621371192; } inline double MilesToMeters(double mi) { return mi * 1609.344; } inline double MetersToFeet(double m) { return m * 3.2808399; } inline double FeetToMeters(double ft) { return ft * 0.3048; } inline double FeetToMiles(double ft) { return ft * 5280; } inline double InchesToMeters(double in) { return in / 39.370; } inline double NauticalMilesToMeters(double nmi) { return nmi * 1852; } /// Takes into an account user settings [metric, imperial] /// @param[in] m meters /// @param[out] res formatted std::string for search /// @return should be direction arrow drawed? false if distance is to small (< 1.0) bool FormatDistance(double m, std::string & res); /// We always use meters and feet/yards for altitude std::string FormatAltitude(double altitudeInMeters); // Return value is measured in km/h for Metric and in mph for Imperial. std::string FormatSpeedWithDeviceUnits(double metersPerSecond); std::string FormatSpeedWithUnits(double metersPerSecond, Units units); std::string FormatSpeed(double metersPerSecond, Units units); std::string FormatSpeedUnits(Units units); /// @param[in] dac Digits after comma in seconds. /// Use dac == 3 for our common conversions to DMS. std::string FormatLatLonAsDMS(double lat, double lon, int dac = 3); void FormatLatLonAsDMS(double lat, double lon, std::string & latText, std::string & lonText, int dac = 3); std::string FormatMercatorAsDMS(m2::PointD const & mercator, int dac = 3); void FormatMercatorAsDMS(m2::PointD const & mercator, std::string & lat, std::string & lon, int dac = 3); /// Default dac == 6 for the simple decimal formatting. std::string FormatLatLon(double lat, double lon, int dac = 6); std::string FormatLatLon(double lat, double lon, bool withSemicolon, int dac = 6); void FormatLatLon(double lat, double lon, std::string & latText, std::string & lonText, int dac = 6); std::string FormatMercator(m2::PointD const & mercator, int dac = 6); void FormatMercator(m2::PointD const & mercator, std::string & lat, std::string & lon, int dac = 6); /// Converts OSM distance (height, ele etc.) to meters. /// @returns false if fails. bool OSMDistanceToMeters(std::string const & osmRawValue, double & outMeters); /// Converts OSM distance (height, ele etc.) to meters std::string. /// @returns empty std::string on failure. std::string OSMDistanceToMetersString(std::string const & osmRawValue, bool supportZeroAndNegativeValues = true, int digitsAfterComma = 2); } // namespace measurement_utils