summaryrefslogtreecommitdiff
path: root/src/mbgl/renderer/layers/render_background_layer.cpp
diff options
context:
space:
mode:
authorAleksandar Stojiljkovic <aleksandar.stojiljkovic@mapbox.com>2019-08-01 12:23:04 +0300
committerAleksandar Stojiljkovic <aleksandar.stojiljkovic@mapbox.com>2019-08-01 13:42:56 +0300
commit0a3f2cef1c2fadf51fb1705465a9e33b714a047c (patch)
tree1b41b6707bc496d27f7213f32df430860036eb61 /src/mbgl/renderer/layers/render_background_layer.cpp
parent8fda03a686d9efd4db7178e93efb898c3d9f43ae (diff)
downloadqtlocation-mapboxgl-0a3f2cef1c2fadf51fb1705465a9e33b714a047c.tar.gz
[core] Enable opaque pass for background layer. fix heatmap+background test.upstream/astojilj-background
Follow the approach from mapbox-gl-js for enabling opaque pass for background layer (same as for fill layer). Fix combinations/heatmap-translucent--background-opaque render test.
Diffstat (limited to 'src/mbgl/renderer/layers/render_background_layer.cpp')
-rw-r--r--src/mbgl/renderer/layers/render_background_layer.cpp20
1 files changed, 17 insertions, 3 deletions
diff --git a/src/mbgl/renderer/layers/render_background_layer.cpp b/src/mbgl/renderer/layers/render_background_layer.cpp
index 885b6fe9b2..4725bce435 100644
--- a/src/mbgl/renderer/layers/render_background_layer.cpp
+++ b/src/mbgl/renderer/layers/render_background_layer.cpp
@@ -37,8 +37,14 @@ void RenderBackgroundLayer::evaluate(const PropertyEvaluationParameters &paramet
parameters.getCrossfadeParameters(),
unevaluated.evaluate(parameters));
- passes = properties->evaluated.get<style::BackgroundOpacity>() > 0 ? RenderPass::Translucent
- : RenderPass::None;
+ passes = properties->evaluated.get<style::BackgroundOpacity>() == 0.0f
+ ? RenderPass::None
+ : (!unevaluated.get<style::BackgroundPattern>().isUndefined()
+ || properties->evaluated.get<style::BackgroundOpacity>() < 1.0f
+ || properties->evaluated.get<style::BackgroundColor>().a < 1.0f)
+ ? RenderPass::Translucent
+ // Supply both - evaluated based on opaquePassCutoff in render().
+ : RenderPass::Opaque | RenderPass::Translucent;
properties->renderPasses = mbgl::underlying_type(passes);
evaluatedProperties = std::move(properties);
}
@@ -77,7 +83,9 @@ void RenderBackgroundLayer::render(PaintParameters& parameters) {
parameters.context,
*parameters.renderPass,
gfx::Triangles(),
- parameters.depthModeForSublayer(0, gfx::DepthMaskType::ReadOnly),
+ parameters.depthModeForSublayer(0, parameters.pass == RenderPass::Opaque
+ ? gfx::DepthMaskType::ReadWrite
+ : gfx::DepthMaskType::ReadOnly),
gfx::StencilMode::disabled(),
parameters.colorModeForRenderPass(),
gfx::CullFaceMode::disabled(),
@@ -118,6 +126,12 @@ void RenderBackgroundLayer::render(PaintParameters& parameters) {
);
}
} else {
+ auto backgroundRenderPass = (evaluated.get<BackgroundColor>().a >= 1.0f
+ && evaluated.get<BackgroundOpacity>() >= 1.0f
+ && parameters.currentLayer >= parameters.opaquePassCutoff) ? RenderPass::Opaque : RenderPass::Translucent;
+ if (parameters.pass != backgroundRenderPass) {
+ return;
+ }
for (const auto& tileID : util::tileCover(parameters.state, parameters.state.getIntegerZoom())) {
draw(
parameters.programs.getBackgroundLayerPrograms().background,