summaryrefslogtreecommitdiff
path: root/src/mbgl/renderer/layers/render_fill_layer.cpp
diff options
context:
space:
mode:
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 },