summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorJohn Firebaugh <john.firebaugh@gmail.com>2016-05-12 14:27:12 -0700
committerJohn Firebaugh <john.firebaugh@gmail.com>2016-05-13 09:01:32 -0700
commit8ec0b70722c704545c4c1953799c43481a038489 (patch)
tree6ebe4c9eaa09629c39a1be1ab4bfc53b8a0176bf /src
parent57fcfabd77a834245e7ae62d4e11439d114eaf71 (diff)
downloadqtlocation-mapboxgl-8ec0b70722c704545c4c1953799c43481a038489.tar.gz
[core] Use mapbox::geometry::box in queryRenderedFeatures
Diffstat (limited to 'src')
-rw-r--r--src/mbgl/map/map.cpp26
1 files changed, 16 insertions, 10 deletions
diff --git a/src/mbgl/map/map.cpp b/src/mbgl/map/map.cpp
index a4f9422184..2c2b9f910c 100644
--- a/src/mbgl/map/map.cpp
+++ b/src/mbgl/map/map.cpp
@@ -736,23 +736,29 @@ std::vector<TileCoordinate> pointsToCoordinates(const std::vector<ScreenCoordina
std::vector<Feature> Map::queryRenderedFeatures(const ScreenCoordinate& point, const optional<std::vector<std::string>>& layerIDs) {
if (!impl->style) return {};
- auto queryGeometry = pointsToCoordinates({ point }, impl->transform.getState());
- return impl->style->queryRenderedFeatures(queryGeometry, impl->transform.getZoom(), impl->transform.getAngle(), layerIDs);
+ return impl->style->queryRenderedFeatures(
+ pointsToCoordinates({ point }, impl->transform.getState()),
+ impl->transform.getZoom(),
+ impl->transform.getAngle(),
+ layerIDs);
}
-std::vector<Feature> Map::queryRenderedFeatures(const std::array<ScreenCoordinate, 2>& box, const optional<std::vector<std::string>>& layerIDs) {
+std::vector<Feature> Map::queryRenderedFeatures(const ScreenBox& box, const optional<std::vector<std::string>>& layerIDs) {
if (!impl->style) return {};
std::vector<ScreenCoordinate> queryPoints {
- { box[0].x, box[0].y },
- { box[1].x, box[0].y },
- { box[1].x, box[1].y },
- { box[0].x, box[1].y },
- { box[0].x, box[0].y }
+ box.min,
+ { box.max.x, box.min.y },
+ box.max,
+ { box.min.x, box.max.y },
+ box.min
};
- auto queryGeometry = pointsToCoordinates(queryPoints, impl->transform.getState());
- return impl->style->queryRenderedFeatures(queryGeometry, impl->transform.getZoom(), impl->transform.getAngle(), layerIDs);
+ return impl->style->queryRenderedFeatures(
+ pointsToCoordinates(queryPoints, impl->transform.getState()),
+ impl->transform.getZoom(),
+ impl->transform.getAngle(),
+ layerIDs);
}