From 3ec0231bb7ed923e82c08ac37950c1fdc366620d Mon Sep 17 00:00:00 2001 From: Ryan Hamley Date: Wed, 24 Oct 2018 18:38:54 -0700 Subject: [PATCH] [core] Avoid wrapping longitude values of exactly 180 and 360 (#12797) (#13006) --- include/mbgl/util/geo.hpp | 2 +- scripts/changelog_staging/invalid-latlngbounds.json | 4 ++++ 2 files changed, 5 insertions(+), 1 deletion(-) create mode 100644 scripts/changelog_staging/invalid-latlngbounds.json diff --git a/include/mbgl/util/geo.hpp b/include/mbgl/util/geo.hpp index dacdb968f37..2df32a7b26f 100644 --- a/include/mbgl/util/geo.hpp +++ b/include/mbgl/util/geo.hpp @@ -61,7 +61,7 @@ class LatLng { // world, unwrap the start longitude to ensure the shortest path is taken. void unwrapForShortestPath(const LatLng& end) { const double delta = std::abs(end.lon - lon); - if (delta < util::LONGITUDE_MAX || delta > util::DEGREES_MAX) return; + if (delta <= util::LONGITUDE_MAX || delta >= util::DEGREES_MAX) return; if (lon > 0 && end.lon < 0) lon -= util::DEGREES_MAX; else if (lon < 0 && end.lon > 0) lon += util::DEGREES_MAX; } diff --git a/scripts/changelog_staging/invalid-latlngbounds.json b/scripts/changelog_staging/invalid-latlngbounds.json new file mode 100644 index 00000000000..32bb8760204 --- /dev/null +++ b/scripts/changelog_staging/invalid-latlngbounds.json @@ -0,0 +1,4 @@ +{ + "core": "When using longitude values of +-180° in LatLngBounds, the longitude was being improperly wrapped resulting in an unexpected bounding box.", + "issue": 12797 +}