summaryrefslogtreecommitdiff
path: root/src/mbgl/renderer/layers/render_fill_layer.cpp
diff options
context:
space:
mode:
authorAleksandar Stojiljkovic <aleksandar.stojiljkovic@mapbox.com>2019-05-24 17:46:57 +0300
committerGitHub <noreply@github.com>2019-05-24 17:46:57 +0300
commit788d54b2b472bc2743cbc4c8ecf26ad56f1ac8b4 (patch)
tree8df7fe25bb58e2c7f0764861ebe7030213afaa92 /src/mbgl/renderer/layers/render_fill_layer.cpp
parent1bef3b7d1d877c67db051b33e0516b36acee700d (diff)
downloadqtlocation-mapboxgl-788d54b2b472bc2743cbc4c8ecf26ad56f1ac8b4.tar.gz
FillBucket::triangles could be empty: skip creating buffer and draw. (#14761)
Diffstat (limited to 'src/mbgl/renderer/layers/render_fill_layer.cpp')
-rw-r--r--src/mbgl/renderer/layers/render_fill_layer.cpp24
1 files changed, 13 insertions, 11 deletions
diff --git a/src/mbgl/renderer/layers/render_fill_layer.cpp b/src/mbgl/renderer/layers/render_fill_layer.cpp
index cea40602d0..73b6c3d596 100644
--- a/src/mbgl/renderer/layers/render_fill_layer.cpp
+++ b/src/mbgl/renderer/layers/render_fill_layer.cpp
@@ -131,8 +131,9 @@ void RenderFillLayer::render(PaintParameters& parameters) {
// Only draw the fill when it's opaque and we're drawing opaque fragments,
// or when it's translucent and we're drawing translucent fragments.
- if ((evaluated.get<FillColor>().constantOr(Color()).a >= 1.0f
- && evaluated.get<FillOpacity>().constantOr(0) >= 1.0f) == (parameters.pass == RenderPass::Opaque)) {
+ if (bucket.triangleIndexBuffer &&
+ (evaluated.get<FillColor>().constantOr(Color()).a >= 1.0f &&
+ evaluated.get<FillOpacity>().constantOr(0) >= 1.0f) == (parameters.pass == RenderPass::Opaque)) {
draw(parameters.programs.getFillLayerPrograms().fill,
gfx::Triangles(),
parameters.depthModeForSublayer(1, parameters.pass == RenderPass::Opaque
@@ -225,15 +226,16 @@ void RenderFillLayer::render(PaintParameters& parameters) {
);
};
- draw(parameters.programs.getFillLayerPrograms().fillPattern,
- gfx::Triangles(),
- parameters.depthModeForSublayer(1, gfx::DepthMaskType::ReadWrite),
- *bucket.triangleIndexBuffer,
- bucket.triangleSegments,
- FillPatternProgram::TextureBindings{
- textures::image::Value{ geometryTile.iconAtlasTexture->getResource(), gfx::TextureFilterType::Linear },
- });
-
+ if (bucket.triangleIndexBuffer) {
+ draw(parameters.programs.getFillLayerPrograms().fillPattern,
+ gfx::Triangles(),
+ parameters.depthModeForSublayer(1, gfx::DepthMaskType::ReadWrite),
+ *bucket.triangleIndexBuffer,
+ bucket.triangleSegments,
+ FillPatternProgram::TextureBindings{
+ textures::image::Value{ geometryTile.iconAtlasTexture->getResource(), gfx::TextureFilterType::Linear },
+ });
+ }
if (evaluated.get<FillAntialias>() && unevaluated.get<FillOutlineColor>().isUndefined()) {
draw(parameters.programs.getFillLayerPrograms().fillOutlinePattern,
gfx::Lines { 2.0f },