[Bf-blender-cvs] [2c3ef36a0b7] blender-v2.83-release: Fix T77520: GPencil viewlayer filter produce crash with masking layers

Antonio Vazquez noreply at git.blender.org
Thu Jun 11 08:38:50 CEST 2020


Commit: 2c3ef36a0b7fe301e32137a17635ceefaa1de791
Author: Antonio Vazquez
Date:   Sun Jun 7 13:06:03 2020 +0200
Branches: blender-v2.83-release
https://developer.blender.org/rB2c3ef36a0b7fe301e32137a17635ceefaa1de791

Fix T77520: GPencil viewlayer filter produce crash with masking layers

If a layer is used for masking, it cannot be filtered by viewlayer because the masked layer needs to have the mask layers in the draw pipeline.

This check is only done in final render.

===================================================================

M	source/blender/blenkernel/intern/gpencil.c

===================================================================

diff --git a/source/blender/blenkernel/intern/gpencil.c b/source/blender/blenkernel/intern/gpencil.c
index 99ee2a0fc9e..1f6c0e96519 100644
--- a/source/blender/blenkernel/intern/gpencil.c
+++ b/source/blender/blenkernel/intern/gpencil.c
@@ -1832,6 +1832,25 @@ bool BKE_gpencil_from_image(SpaceImage *sima, bGPDframe *gpf, const float size,
   return done;
 }
 
+/**
+ * Helper to check if a layers is used as mask
+ * \param gpd Grease pencil datablock
+ * \param gpl_mask Actual Layer
+ * \return True if the layer is a mask
+ */
+static bool gpencil_is_layer_mask(bGPdata *gpd, bGPDlayer *gpl_mask)
+{
+  LISTBASE_FOREACH (bGPDlayer *, gpl, &gpd->layers) {
+    LISTBASE_FOREACH (bGPDlayer_Mask *, mask, &gpl->mask_layers) {
+      if (STREQ(gpl_mask->info, mask->name)) {
+        return true;
+      }
+    }
+  }
+
+  return false;
+}
+
 /* -------------------------------------------------------------------- */
 /** \name Iterators
  *
@@ -1873,7 +1892,11 @@ void BKE_gpencil_visible_stroke_iter(ViewLayer *view_layer,
      * This is used only in final render and never in Viewport. */
     if ((view_layer != NULL) && (gpl->viewlayername[0] != '\0') &&
         (!STREQ(view_layer->name, gpl->viewlayername))) {
-      continue;
+      /* If the layer is used as mask, cannot be filtered or the masking system
+       * will crash because needs the mask layer in the draw pipeline. */
+      if (!gpencil_is_layer_mask(gpd, gpl)) {
+        continue;
+      }
     }
 
     if (is_multiedit) {



More information about the Bf-blender-cvs mailing list