summaryrefslogtreecommitdiff
path: root/src/mbgl/renderer/render_source.hpp
diff options
context:
space:
mode:
authorMikhail Pozdnyakov <mikhail.pozdnyakov@mapbox.com>2019-07-08 17:49:32 +0300
committerMikhail Pozdnyakov <mikhail.pozdnyakov@mapbox.com>2019-07-08 17:49:32 +0300
commit07138ef4b9c337c919c8f7d3d8ba875828586e16 (patch)
treeda0c0830cdb4f75932666d19f538538cf75afeea /src/mbgl/renderer/render_source.hpp
parent532e9dc6ae1f62c7c46f24b1277240440ecfe9ea (diff)
downloadqtlocation-mapboxgl-07138ef4b9c337c919c8f7d3d8ba875828586e16.tar.gz
[core] Share render tiles lists between layersupstream/mikhail_share_render_tiles
This helps to avoid unneeded allocations.
Diffstat (limited to 'src/mbgl/renderer/render_source.hpp')
-rw-r--r--src/mbgl/renderer/render_source.hpp12
1 files changed, 9 insertions, 3 deletions
diff --git a/src/mbgl/renderer/render_source.hpp b/src/mbgl/renderer/render_source.hpp
index fc770f83cf..87ca06b453 100644
--- a/src/mbgl/renderer/render_source.hpp
+++ b/src/mbgl/renderer/render_source.hpp
@@ -43,7 +43,7 @@ public:
const ImageManager& imageManager;
};
-using RenderTiles = std::vector<std::reference_wrapper<const RenderTile>>;
+using RenderTiles = std::shared_ptr<const std::vector<std::reference_wrapper<const RenderTile>>>;
class RenderSource : protected TileObserver {
public:
@@ -64,8 +64,14 @@ public:
virtual void prepare(const SourcePrepareParameters&) = 0;
virtual void updateFadingTiles() = 0;
virtual bool hasFadingTiles() const = 0;
- // Returns a list of RenderTiles, sorted by tile id.
- virtual RenderTiles getRenderTiles() = 0;
+ // If supported, returns a shared list of RenderTiles, sorted by tile id and excluding tiles hold for fade;
+ // returns nullptr otherwise.
+ virtual RenderTiles getRenderTiles() const { return nullptr; }
+ // If supported, returns a shared list of RenderTiles, sorted in opposite y position, so tiles with overlapping
+ // symbols are drawn on top of each other, with lower symbols being drawn on top of higher symbols;
+ // returns nullptr otherwise.
+ virtual RenderTiles getRenderTilesSortedByYPosition() const { return nullptr; }
+ // If supported, returns pointer to image data; returns nullptr otherwise.
virtual const ImageSourceRenderData* getImageRenderData() const { return nullptr; }
virtual const Tile* getRenderedTile(const UnwrappedTileID&) const { return nullptr; }