summaryrefslogtreecommitdiff
path: root/src/mbgl/renderer/render_layer.cpp
diff options
context:
space:
mode:
authorAsheem Mamoowala <asheem.mamoowala@mapbox.com>2017-05-26 16:54:36 -0700
committerGitHub <noreply@github.com>2017-05-26 16:54:36 -0700
commitf0d0e7423b610782fdbed576bc2a442b82c8e1f8 (patch)
tree22beb252e48af8afc71d2c56b9db456407431803 /src/mbgl/renderer/render_layer.cpp
parent2e0ceeb9c1ee1cc2c705644e4b32ac429487699e (diff)
downloadqtlocation-mapboxgl-f0d0e7423b610782fdbed576bc2a442b82c8e1f8.tar.gz
Refactor RenderLayer and RenderSource to be more friendly for Non-tiled sources (#9058)
Diffstat (limited to 'src/mbgl/renderer/render_layer.cpp')
-rw-r--r--src/mbgl/renderer/render_layer.cpp27
1 files changed, 26 insertions, 1 deletions
diff --git a/src/mbgl/renderer/render_layer.cpp b/src/mbgl/renderer/render_layer.cpp
index cf7f772e16..4bffb87cf1 100644
--- a/src/mbgl/renderer/render_layer.cpp
+++ b/src/mbgl/renderer/render_layer.cpp
@@ -8,6 +8,8 @@
#include <mbgl/renderer/layers/render_raster_layer.hpp>
#include <mbgl/renderer/layers/render_symbol_layer.hpp>
#include <mbgl/style/types.hpp>
+#include <mbgl/renderer/render_tile.hpp>
+#include <mbgl/tile/tile.hpp>
namespace mbgl {
@@ -62,4 +64,27 @@ bool RenderLayer::needsRendering(float zoom) const {
&& baseImpl->maxZoom >= zoom;
}
-} // namespace mbgl
+void RenderLayer::setRenderTiles(std::vector<std::reference_wrapper<RenderTile>> tiles) {
+ renderTiles = std::move(tiles);
+}
+
+void RenderLayer::uploadBuckets(gl::Context& context, RenderSource*) {
+ for (const auto& tileRef : renderTiles) {
+ const auto& bucket = tileRef.get().tile.getBucket(*baseImpl);
+ if (bucket && bucket->needsUpload()) {
+ bucket->upload(context);
+ }
+ }
+}
+
+void RenderLayer::render(Painter& painter, PaintParameters& parameters, RenderSource*) {
+ for (auto& tileRef : renderTiles) {
+ auto& tile = tileRef.get();
+ auto bucket = tile.tile.getBucket(*baseImpl);
+ bucket->render(painter, parameters, *this, tile);
+ }
+}
+
+
+} //namespace mbgl
+