diff options
author | Alexander Shalamov <alexander.shalamov@mapbox.com> | 2020-02-15 01:38:45 +0200 |
---|---|---|
committer | Alexander Shalamov <alexander.shalamov@mapbox.com> | 2020-02-17 10:14:05 +0200 |
commit | b97f40469b6f3d386ae93bc9a23722ff017162f0 (patch) | |
tree | a94e1b72152429176b30c33d1c83fea877960204 /src/mbgl/sprite | |
parent | 02274e76019bcfb938f50cdb638eca49c33de786 (diff) | |
download | qtlocation-mapboxgl-b97f40469b6f3d386ae93bc9a23722ff017162f0.tar.gz |
[core] Fix sprite sheet merging in Style::Impl::onSpriteLoaded
If we get a new sprite sheet from the server, we need to merge current
sprite sheet with a new one, while overwiting duplicates and keeping
old unique images in a style.
Diffstat (limited to 'src/mbgl/sprite')
-rw-r--r-- | src/mbgl/sprite/sprite_parser.cpp | 18 |
1 files changed, 12 insertions, 6 deletions
diff --git a/src/mbgl/sprite/sprite_parser.cpp b/src/mbgl/sprite/sprite_parser.cpp index 40e63d2d7d..155269cdbc 100644 --- a/src/mbgl/sprite/sprite_parser.cpp +++ b/src/mbgl/sprite/sprite_parser.cpp @@ -1,5 +1,6 @@ #include <mbgl/sprite/sprite_parser.hpp> #include <mbgl/style/image.hpp> +#include <mbgl/style/image_impl.hpp> #include <mbgl/util/exception.hpp> #include <mbgl/util/logging.hpp> @@ -8,6 +9,7 @@ #include <mbgl/util/rapidjson.hpp> #include <mbgl/util/string.hpp> +#include <algorithm> #include <cmath> #include <limits> @@ -25,10 +27,9 @@ std::unique_ptr<style::Image> createStyleImage(const std::string& id, style::ImageStretches&& stretchY, optional<style::ImageContent> content) { // Disallow invalid parameter configurations. - if (width <= 0 || height <= 0 || width > 1024 || height > 1024 || - ratio <= 0 || ratio > 10 || - srcX >= image.size.width || srcY >= image.size.height || - srcX + width > image.size.width || srcY + height > image.size.height) { + if (width <= 0 || height <= 0 || width > 1024 || height > 1024 || ratio <= 0 || ratio > 10 || + srcX >= image.size.width || srcY >= image.size.height || srcX + width > image.size.width || + srcY + height > image.size.height) { Log::Error(Event::Sprite, "Can't create image with invalid metrics: %ux%u@%u,%u in %ux%u@%sx sprite", width, @@ -41,10 +42,10 @@ std::unique_ptr<style::Image> createStyleImage(const std::string& id, return nullptr; } - PremultipliedImage dstImage({ width, height }); + PremultipliedImage dstImage({width, height}); // Copy from the source image into our individual sprite image - PremultipliedImage::copy(image, dstImage, { srcX, srcY }, { 0, 0 }, { width, height }); + PremultipliedImage::copy(image, dstImage, {srcX, srcY}, {0, 0}, {width, height}); try { return std::make_unique<style::Image>( @@ -196,6 +197,11 @@ std::vector<Immutable<style::Image::Impl>> parseSprite(const std::string& encode } } } + + assert([&images] { + std::sort(images.begin(), images.end()); + return std::unique(images.begin(), images.end()) == images.end(); + }()); return images; } |