GP: New Autolock Inactive Layer
authorAntonioya <blendergit@gmail.com>
Wed, 31 Oct 2018 10:00:02 +0000 (11:00 +0100)
committerAntonioya <blendergit@gmail.com>
Wed, 31 Oct 2018 10:00:28 +0000 (11:00 +0100)
This option locks any layer no active to avoid any accidental change.

release/scripts/startup/bl_ui/properties_data_gpencil.py
source/blender/blenkernel/intern/gpencil.c
source/blender/makesdna/DNA_gpencil_types.h
source/blender/makesrna/intern/rna_gpencil.c

index a40ba463603d65a63603025bae01927b3d3d9e5f..7f7813cad365c47e04fdfae06beb7c1016a40635 100644 (file)
@@ -160,6 +160,10 @@ class DATA_PT_gpencil_datapanel(Panel):
         if gpl:
             row.prop(gpl, "opacity", text="Opacity", slider=True)
 
+            # autolock layers
+            row = layout.row(align=True)
+            row.prop(gpd, "use_autolock_layers", text="Autolock Inactive Layers")
+
 
 class DATA_PT_gpencil_layer_optionpanel(LayerDataButtonsPanel, Panel):
     bl_space_type = 'PROPERTIES'
index 97aed40e998ccbc8e709b1505f97afdba5401aaa..63d7f3697f0417380ee2f00e8459420a1559af53 100644 (file)
@@ -996,11 +996,18 @@ void BKE_gpencil_layer_setactive(bGPdata *gpd, bGPDlayer *active)
                return;
 
        /* loop over layers deactivating all */
-       for (gpl = gpd->layers.first; gpl; gpl = gpl->next)
+       for (gpl = gpd->layers.first; gpl; gpl = gpl->next) {
                gpl->flag &= ~GP_LAYER_ACTIVE;
+               if (gpd->flag & GP_DATA_AUTOLOCK_LAYERS) {
+                       gpl->flag |= GP_LAYER_LOCKED;
+               }
+       }
 
        /* set as active one */
        active->flag |= GP_LAYER_ACTIVE;
+       if (gpd->flag & GP_DATA_AUTOLOCK_LAYERS) {
+               active->flag &= ~GP_LAYER_LOCKED;
+       }
 }
 
 /* delete the active gp-layer */
index 2c59dd899a927a164790ec918b74b3457b8740c5..42070839facd14433c09380002c7ce97f16f6db3 100644 (file)
@@ -448,6 +448,8 @@ typedef enum eGPdata_Flag {
        GP_DATA_STROKE_POLYGON = (1 << 18),
        /* Use adaptative UV scales */
        GP_DATA_UV_ADAPTATIVE = (1 << 19),
+       /* Autolock not active layers */
+       GP_DATA_AUTOLOCK_LAYERS = (1 << 20),
 } eGPdata_Flag;
 
 /* gpd->onion_flag */
index 73f26e9848e10417c0914e62ff12cdbaf7a801d1..9a8673e9a268a6fa38b8245b6b8464629f0ba8c1 100644 (file)
@@ -101,6 +101,38 @@ static void rna_GPencil_update(Main *UNUSED(bmain), Scene *UNUSED(scene), Pointe
        WM_main_add_notifier(NC_GPENCIL | NA_EDITED, NULL);
 }
 
+static void rna_GPencil_autolock(Main *bmain, Scene *scene, PointerRNA *ptr)
+{
+       bGPdata *gpd = (bGPdata *)ptr->id.data;
+       bGPDlayer *gpl = NULL;
+
+       if (gpd->flag & GP_DATA_AUTOLOCK_LAYERS) {
+               bGPDlayer *layer = BKE_gpencil_layer_getactive(gpd);
+
+               /* Lock all other layers */
+               for (gpl = gpd->layers.first; gpl; gpl = gpl->next) {
+                       /* unlock active layer */
+                       if (gpl == layer) {
+                               gpl->flag &= ~GP_LAYER_LOCKED;
+                       }
+                       else {
+                               gpl->flag |= GP_LAYER_LOCKED;
+                       }
+               }
+       }
+       else {
+               /* If disable is better unlock all layers by default or it looks there is
+                * a problem in the UI because the user expects all layers will be unlocked
+                */
+               for (gpl = gpd->layers.first; gpl; gpl = gpl->next) {
+                       gpl->flag &= ~GP_LAYER_LOCKED;
+               }
+       }
+
+       /* standard update */
+       rna_GPencil_update(bmain, scene, ptr);
+}
+
 static void rna_GPencil_editmode_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *ptr)
 {
        bGPdata *gpd = (bGPdata *)ptr->id.data;
@@ -1410,6 +1442,12 @@ static void rna_def_gpencil_data(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "Adaptative UV", "Automatic UVs are calculated depending of the stroke size");
        RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, "rna_GPencil_update");
 
+       prop = RNA_def_property(srna, "use_autolock_layers", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", GP_DATA_AUTOLOCK_LAYERS);
+       RNA_def_property_ui_text(prop, "Autolock Layers",
+               "Lock automatically all layers except active one to avoid accidental changes");
+       RNA_def_property_update(prop, NC_GPENCIL | ND_DATA, "rna_GPencil_autolock");
+
        prop = RNA_def_property(srna, "edit_line_color", PROP_FLOAT, PROP_COLOR_GAMMA);
        RNA_def_property_float_sdna(prop, NULL, "line_color");
        RNA_def_property_array(prop, 4);