summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAnsis Brammanis <brammanis@gmail.com>2015-03-25 16:27:28 -0700
committerKonstantin Käfer <mail@kkaefer.com>2015-03-26 10:45:23 +0100
commit9080f25d3164ef949d86bfc9e37368fe75e4be89 (patch)
tree16c05dde9cd1078b295896dc89fb80c150e8bcd3
parent552522ea94d0297b7ad10d1923e9d3b9aa9b8482 (diff)
downloadqtlocation-mapboxgl-9080f25d3164ef949d86bfc9e37368fe75e4be89.tar.gz
fix sprite padding, fixes
https://github.com/mapbox/mapbox-gl-styles/issues/50#issuecomment-86159351
-rw-r--r--src/mbgl/geometry/sprite_atlas.cpp28
1 files changed, 14 insertions, 14 deletions
diff --git a/src/mbgl/geometry/sprite_atlas.cpp b/src/mbgl/geometry/sprite_atlas.cpp
index 187253b147..23487d024f 100644
--- a/src/mbgl/geometry/sprite_atlas.cpp
+++ b/src/mbgl/geometry/sprite_atlas.cpp
@@ -171,31 +171,31 @@ void SpriteAtlas::copy(const Rect<dimension>& dst, const SpritePosition& src, co
if (wrap) {
// We're copying from the same image so we don't have to scale again.
const uint32_t border = 1;
+ const uint32_t borderX = dstPos.x != 0 ? border : 0;
+ const uint32_t borderY = dstPos.y != 0 ? border : 0;
+
// Left border
- if (dstPos.x >= border) {
- util::nearestNeighborScale(
- dstData, dstSize, { dstPos.x + dstPos.w - border - 1, dstPos.y, border, dstPos.h },
- dstData, dstSize, { dstPos.x - border, dstPos.y, border, dstPos.h });
- }
+ util::nearestNeighborScale(
+ dstData, dstSize, { dstPos.x + dstPos.w - borderX, dstPos.y, borderX, dstPos.h },
+ dstData, dstSize, { dstPos.x - borderX, dstPos.y, borderX, dstPos.h });
+
// Right border
util::nearestNeighborScale(dstData, dstSize, { dstPos.x, dstPos.y, border, dstPos.h },
dstData, dstSize,
{ dstPos.x + dstPos.w, dstPos.y, border, dstPos.h });
// Top border
- if (dstPos.y >= border) {
- util::nearestNeighborScale(
- dstData, dstSize, { dstPos.x - border, dstPos.y + dstPos.h - border - 1,
- dstPos.w + 2 * border, border },
- dstData, dstSize,
- { dstPos.x - border, dstPos.y - border, dstPos.w + 2 * border, border });
- }
+ util::nearestNeighborScale(
+ dstData, dstSize, { dstPos.x - borderX, dstPos.y + dstPos.h - borderY,
+ dstPos.w + border + borderX, borderY },
+ dstData, dstSize,
+ { dstPos.x - borderX, dstPos.y - borderY, dstPos.w + 2 * borderX, borderY });
// Bottom border
util::nearestNeighborScale(
- dstData, dstSize, { dstPos.x - border, dstPos.y, dstPos.w + 2 * border, border },
+ dstData, dstSize, { dstPos.x - borderX, dstPos.y, dstPos.w + 2 * borderX, border },
dstData, dstSize,
- { dstPos.x - border, dstPos.y + dstPos.h, dstPos.w + 2 * border, border });
+ { dstPos.x - borderX, dstPos.y + dstPos.h, dstPos.w + border + borderX, border });
}
dirty = true;