Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAntonio Vazquez <blendergit@gmail.com>2020-06-07 14:06:03 +0300
committerAntonio Vazquez <blendergit@gmail.com>2020-06-07 14:06:39 +0300
commitdc6cee4724fba547c729b0d59dc1ee07dfcca0c0 (patch)
treedb32eedac9a2e58c013a3730e69041704bc0b49b /source/blender/blenkernel/intern/gpencil.c
parent8f25cfdbfda05b7ab875448ff46c9c88ed5392ee (diff)
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.
Diffstat (limited to 'source/blender/blenkernel/intern/gpencil.c')
-rw-r--r--source/blender/blenkernel/intern/gpencil.c25
1 files changed, 24 insertions, 1 deletions
diff --git a/source/blender/blenkernel/intern/gpencil.c b/source/blender/blenkernel/intern/gpencil.c
index 75cd16f13a0..1e24d61380c 100644
--- a/source/blender/blenkernel/intern/gpencil.c
+++ b/source/blender/blenkernel/intern/gpencil.c
@@ -1840,6 +1840,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
*
@@ -1881,7 +1900,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) {