Merge branch 'master' into blender2.8
[blender.git] / source / blender / makesrna / intern / rna_sculpt_paint.c
index acde2e0..2fe9bdd 100644 (file)
@@ -34,6 +34,7 @@
 #include "DNA_ID.h"
 #include "DNA_scene_types.h"
 #include "DNA_brush_types.h"
+#include "DNA_object_types.h"
 #include "DNA_screen_types.h"
 #include "DNA_space_types.h"
 
 #include "BLI_utildefines.h"
 #include "bmesh.h"
 
-static EnumPropertyItem particle_edit_hair_brush_items[] = {
-       {PE_BRUSH_NONE, "NONE", 0, "None", "Don't use any brush"},
-       {PE_BRUSH_COMB, "COMB", 0, "Comb", "Comb hairs"},
-       {PE_BRUSH_SMOOTH, "SMOOTH", 0, "Smooth", "Smooth hairs"},
-       {PE_BRUSH_ADD, "ADD", 0, "Add", "Add hairs"},
-       {PE_BRUSH_LENGTH, "LENGTH", 0, "Length", "Make hairs longer or shorter"},
-       {PE_BRUSH_PUFF, "PUFF", 0, "Puff", "Make hairs stand up"},
-       {PE_BRUSH_CUT, "CUT", 0, "Cut", "Cut hairs"},
-       {PE_BRUSH_WEIGHT, "WEIGHT", 0, "Weight", "Weight hair particles"},
-       {0, NULL, 0, NULL, NULL}
-};
-
 EnumPropertyItem rna_enum_gpencil_sculpt_brush_items[] = {
        {GP_EDITBRUSH_TYPE_SMOOTH, "SMOOTH", 0, "Smooth", "Smooth stroke points"},
        {GP_EDITBRUSH_TYPE_THICKNESS, "THICKNESS", 0, "Thickness", "Adjust thickness of strokes"},
@@ -92,137 +81,16 @@ EnumPropertyItem rna_enum_symmetrize_direction_items[] = {
 
 #include "BKE_context.h"
 #include "BKE_DerivedMesh.h"
-#include "BKE_pointcache.h"
-#include "BKE_particle.h"
 #include "BKE_depsgraph.h"
 #include "BKE_pbvh.h"
 
 #include "GPU_buffers.h"
 
-#include "ED_particle.h"
-
 static void rna_GPencil_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *UNUSED(ptr))
 {
        WM_main_add_notifier(NC_GPENCIL | NA_EDITED, NULL);
 }
 
-static EnumPropertyItem particle_edit_disconnected_hair_brush_items[] = {
-       {PE_BRUSH_NONE, "NONE", 0, "None", "Don't use any brush"},
-       {PE_BRUSH_COMB, "COMB", 0, "Comb", "Comb hairs"},
-       {PE_BRUSH_SMOOTH, "SMOOTH", 0, "Smooth", "Smooth hairs"},
-       {PE_BRUSH_LENGTH, "LENGTH", 0, "Length", "Make hairs longer or shorter"},
-       {PE_BRUSH_CUT, "CUT", 0, "Cut", "Cut hairs"},
-       {PE_BRUSH_WEIGHT, "WEIGHT", 0, "Weight", "Weight hair particles"},
-       {0, NULL, 0, NULL, NULL}
-};
-
-static EnumPropertyItem particle_edit_cache_brush_items[] = {
-       {PE_BRUSH_NONE, "NONE", 0, "None", "Don't use any brush"},
-       {PE_BRUSH_COMB, "COMB", 0, "Comb", "Comb paths"},
-       {PE_BRUSH_SMOOTH, "SMOOTH", 0, "Smooth", "Smooth paths"},
-       {PE_BRUSH_LENGTH, "LENGTH", 0, "Length", "Make paths longer or shorter"},
-       {0, NULL, 0, NULL, NULL}
-};
-
-static PointerRNA rna_ParticleEdit_brush_get(PointerRNA *ptr)
-{
-       ParticleEditSettings *pset = (ParticleEditSettings *)ptr->data;
-       ParticleBrushData *brush = NULL;
-
-       if (pset->brushtype != PE_BRUSH_NONE)
-               brush = &pset->brush[pset->brushtype];
-
-       return rna_pointer_inherit_refine(ptr, &RNA_ParticleBrush, brush);
-}
-
-static PointerRNA rna_ParticleBrush_curve_get(PointerRNA *ptr)
-{
-       return rna_pointer_inherit_refine(ptr, &RNA_CurveMapping, NULL);
-}
-
-static void rna_ParticleEdit_redo(Main *UNUSED(bmain), Scene *scene, PointerRNA *UNUSED(ptr))
-{
-       Object *ob = (scene->basact) ? scene->basact->object : NULL;
-       PTCacheEdit *edit = PE_get_current(scene, ob);
-
-       if (!edit)
-               return;
-
-       psys_free_path_cache(edit->psys, edit);
-}
-
-static void rna_ParticleEdit_update(Main *UNUSED(bmain), Scene *scene, PointerRNA *UNUSED(ptr))
-{
-       Object *ob = (scene->basact) ? scene->basact->object : NULL;
-
-       if (ob) DAG_id_tag_update(&ob->id, OB_RECALC_DATA);
-}
-static void rna_ParticleEdit_tool_set(PointerRNA *ptr, int value)
-{
-       ParticleEditSettings *pset = (ParticleEditSettings *)ptr->data;
-       
-       /* redraw hair completely if weight brush is/was used */
-       if ((pset->brushtype == PE_BRUSH_WEIGHT || value == PE_BRUSH_WEIGHT) && pset->scene) {
-               Object *ob = (pset->scene->basact) ? pset->scene->basact->object : NULL;
-               if (ob) {
-                       DAG_id_tag_update(&ob->id, OB_RECALC_DATA);
-                       WM_main_add_notifier(NC_OBJECT | ND_PARTICLE | NA_EDITED, NULL);
-               }
-       }
-
-       pset->brushtype = value;
-}
-static EnumPropertyItem *rna_ParticleEdit_tool_itemf(bContext *C, PointerRNA *UNUSED(ptr),
-                                                     PropertyRNA *UNUSED(prop), bool *UNUSED(r_free))
-{
-       Scene *scene = CTX_data_scene(C);
-       Object *ob = (scene->basact) ? scene->basact->object : NULL;
-#if 0
-       PTCacheEdit *edit = PE_get_current(scene, ob);
-       ParticleSystem *psys = edit ? edit->psys : NULL;
-#else
-       /* use this rather than PE_get_current() - because the editing cache is
-        * dependent on the cache being updated which can happen after this UI
-        * draws causing a glitch [#28883] */
-       ParticleSystem *psys = psys_get_current(ob);
-#endif
-
-       if (psys) {
-               if (psys->flag & PSYS_GLOBAL_HAIR) {
-                       return particle_edit_disconnected_hair_brush_items;
-               }
-               else {
-                       return particle_edit_hair_brush_items;
-               }
-       }
-
-       return particle_edit_cache_brush_items;
-}
-
-static int rna_ParticleEdit_editable_get(PointerRNA *ptr)
-{
-       ParticleEditSettings *pset = (ParticleEditSettings *)ptr->data;
-
-       return (pset->object && pset->scene && PE_get_current(pset->scene, pset->object));
-}
-static int rna_ParticleEdit_hair_get(PointerRNA *ptr)
-{
-       ParticleEditSettings *pset = (ParticleEditSettings *)ptr->data;
-
-       if (pset->scene) {
-               PTCacheEdit *edit = PE_get_current(pset->scene, pset->object);
-
-               return (edit && edit->psys);
-       }
-       
-       return 0;
-}
-
-static char *rna_ParticleEdit_path(PointerRNA *UNUSED(ptr))
-{
-       return BLI_strdup("tool_settings.particle_edit");
-}
-
 static int rna_Brush_mode_poll(PointerRNA *ptr, PointerRNA value)
 {
        Scene *scene = (Scene *)ptr->id.data;
@@ -302,11 +170,6 @@ static char *rna_UvSculpt_path(PointerRNA *UNUSED(ptr))
        return BLI_strdup("tool_settings.uv_sculpt");
 }
 
-static char *rna_ParticleBrush_path(PointerRNA *UNUSED(ptr))
-{
-       return BLI_strdup("tool_settings.particle_edit.brush");
-}
-
 static void rna_Paint_brush_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *ptr)
 {
        Paint *paint = ptr->data;
@@ -807,188 +670,6 @@ static void rna_def_image_paint(BlenderRNA *brna)
        RNA_def_property_clear_flag(prop, PROP_EDITABLE);       
 }
 
-static void rna_def_particle_edit(BlenderRNA *brna)
-{
-       StructRNA *srna;
-       PropertyRNA *prop;
-
-       static EnumPropertyItem select_mode_items[] = {
-               {SCE_SELECT_PATH, "PATH", ICON_PARTICLE_PATH, "Path", "Path edit mode"},
-               {SCE_SELECT_POINT, "POINT", ICON_PARTICLE_POINT, "Point", "Point select mode"},
-               {SCE_SELECT_END, "TIP", ICON_PARTICLE_TIP, "Tip", "Tip select mode"},
-               {0, NULL, 0, NULL, NULL}
-       };
-
-       static EnumPropertyItem puff_mode[] = {
-               {0, "ADD", 0, "Add", "Make hairs more puffy"},
-               {1, "SUB", 0, "Sub", "Make hairs less puffy"},
-               {0, NULL, 0, NULL, NULL}
-       };
-
-       static EnumPropertyItem length_mode[] = {
-               {0, "GROW", 0, "Grow", "Make hairs longer"},
-               {1, "SHRINK", 0, "Shrink", "Make hairs shorter"},
-               {0, NULL, 0, NULL, NULL}
-       };
-
-       static EnumPropertyItem edit_type_items[] = {
-               {PE_TYPE_PARTICLES, "PARTICLES", 0, "Particles", ""},
-               {PE_TYPE_SOFTBODY, "SOFT_BODY", 0, "Soft body", ""},
-               {PE_TYPE_CLOTH, "CLOTH", 0, "Cloth", ""},
-               {0, NULL, 0, NULL, NULL}
-       };
-
-
-       /* edit */
-
-       srna = RNA_def_struct(brna, "ParticleEdit", NULL);
-       RNA_def_struct_sdna(srna, "ParticleEditSettings");
-       RNA_def_struct_path_func(srna, "rna_ParticleEdit_path");
-       RNA_def_struct_ui_text(srna, "Particle Edit", "Properties of particle editing mode");
-
-       prop = RNA_def_property(srna, "tool", PROP_ENUM, PROP_NONE);
-       RNA_def_property_enum_sdna(prop, NULL, "brushtype");
-       RNA_def_property_enum_items(prop, particle_edit_hair_brush_items);
-       RNA_def_property_enum_funcs(prop, NULL, "rna_ParticleEdit_tool_set", "rna_ParticleEdit_tool_itemf");
-       RNA_def_property_ui_text(prop, "Tool", "");
-
-       prop = RNA_def_property(srna, "select_mode", PROP_ENUM, PROP_NONE);
-       RNA_def_property_enum_bitflag_sdna(prop, NULL, "selectmode");
-       RNA_def_property_enum_items(prop, select_mode_items);
-       RNA_def_property_ui_text(prop, "Selection Mode", "Particle select and display mode");
-       RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_ParticleEdit_update");
-
-       prop = RNA_def_property(srna, "use_preserve_length", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_sdna(prop, NULL, "flag", PE_KEEP_LENGTHS);
-       RNA_def_property_ui_text(prop, "Keep Lengths", "Keep path lengths constant");
-
-       prop = RNA_def_property(srna, "use_preserve_root", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_sdna(prop, NULL, "flag", PE_LOCK_FIRST);
-       RNA_def_property_ui_text(prop, "Keep Root", "Keep root keys unmodified");
-
-       prop = RNA_def_property(srna, "use_emitter_deflect", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_sdna(prop, NULL, "flag", PE_DEFLECT_EMITTER);
-       RNA_def_property_ui_text(prop, "Deflect Emitter", "Keep paths from intersecting the emitter");
-
-       prop = RNA_def_property(srna, "emitter_distance", PROP_FLOAT, PROP_UNSIGNED);
-       RNA_def_property_float_sdna(prop, NULL, "emitterdist");
-       RNA_def_property_ui_range(prop, 0.0f, 10.0f, 10, 3);
-       RNA_def_property_ui_text(prop, "Emitter Distance", "Distance to keep particles away from the emitter");
-
-       prop = RNA_def_property(srna, "use_fade_time", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_sdna(prop, NULL, "flag", PE_FADE_TIME);
-       RNA_def_property_ui_text(prop, "Fade Time", "Fade paths and keys further away from current frame");
-       RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_ParticleEdit_update");
-
-       prop = RNA_def_property(srna, "use_auto_velocity", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_sdna(prop, NULL, "flag", PE_AUTO_VELOCITY);
-       RNA_def_property_ui_text(prop, "Auto Velocity", "Calculate point velocities automatically");
-
-       prop = RNA_def_property(srna, "show_particles", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_sdna(prop, NULL, "flag", PE_DRAW_PART);
-       RNA_def_property_ui_text(prop, "Draw Particles", "Draw actual particles");
-       RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_ParticleEdit_redo");
-
-       prop = RNA_def_property(srna, "use_default_interpolate", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_sdna(prop, NULL, "flag", PE_INTERPOLATE_ADDED);
-       RNA_def_property_ui_text(prop, "Interpolate", "Interpolate new particles from the existing ones");
-
-       prop = RNA_def_property(srna, "default_key_count", PROP_INT, PROP_NONE);
-       RNA_def_property_int_sdna(prop, NULL, "totaddkey");
-       RNA_def_property_range(prop, 2, SHRT_MAX);
-       RNA_def_property_ui_range(prop, 2, 20, 10, 3);
-       RNA_def_property_ui_text(prop, "Keys", "How many keys to make new particles with");
-
-       prop = RNA_def_property(srna, "brush", PROP_POINTER, PROP_NONE);
-       RNA_def_property_struct_type(prop, "ParticleBrush");
-       RNA_def_property_pointer_funcs(prop, "rna_ParticleEdit_brush_get", NULL, NULL, NULL);
-       RNA_def_property_ui_text(prop, "Brush", "");
-
-       prop = RNA_def_property(srna, "draw_step", PROP_INT, PROP_NONE);
-       RNA_def_property_range(prop, 1, 10);
-       RNA_def_property_ui_text(prop, "Steps", "How many steps to draw the path with");
-       RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_ParticleEdit_redo");
-
-       prop = RNA_def_property(srna, "fade_frames", PROP_INT, PROP_NONE);
-       RNA_def_property_range(prop, 1, 100);
-       RNA_def_property_ui_text(prop, "Frames", "How many frames to fade");
-       RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_ParticleEdit_update");
-
-       prop = RNA_def_property(srna, "type", PROP_ENUM, PROP_NONE);
-       RNA_def_property_enum_sdna(prop, NULL, "edittype");
-       RNA_def_property_enum_items(prop, edit_type_items);
-       RNA_def_property_ui_text(prop, "Type", "");
-       RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_ParticleEdit_redo");
-
-       prop = RNA_def_property(srna, "is_editable", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_funcs(prop, "rna_ParticleEdit_editable_get", NULL);
-       RNA_def_property_clear_flag(prop, PROP_EDITABLE);
-       RNA_def_property_ui_text(prop, "Editable", "A valid edit mode exists");
-
-       prop = RNA_def_property(srna, "is_hair", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_funcs(prop, "rna_ParticleEdit_hair_get", NULL);
-       RNA_def_property_clear_flag(prop, PROP_EDITABLE);
-       RNA_def_property_ui_text(prop, "Hair", "Editing hair");
-
-       prop = RNA_def_property(srna, "object", PROP_POINTER, PROP_NONE);
-       RNA_def_property_clear_flag(prop, PROP_EDITABLE);
-       RNA_def_property_ui_text(prop, "Object", "The edited object");
-
-       prop = RNA_def_property(srna, "shape_object", PROP_POINTER, PROP_NONE);
-       RNA_def_property_flag(prop, PROP_EDITABLE);
-       RNA_def_property_ui_text(prop, "Shape Object", "Outer shape to use for tools");
-       RNA_def_property_pointer_funcs(prop, NULL, NULL, NULL, "rna_Mesh_object_poll");
-       RNA_def_property_update(prop, NC_OBJECT | ND_DRAW, "rna_ParticleEdit_redo");
-
-       /* brush */
-
-       srna = RNA_def_struct(brna, "ParticleBrush", NULL);
-       RNA_def_struct_sdna(srna, "ParticleBrushData");
-       RNA_def_struct_path_func(srna, "rna_ParticleBrush_path");
-       RNA_def_struct_ui_text(srna, "Particle Brush", "Particle editing brush");
-
-       prop = RNA_def_property(srna, "size", PROP_INT, PROP_PIXEL);
-       RNA_def_property_range(prop, 1, SHRT_MAX);
-       RNA_def_property_ui_range(prop, 1, MAX_BRUSH_PIXEL_RADIUS, 10, 3);
-       RNA_def_property_ui_text(prop, "Radius", "Radius of the brush in pixels");
-
-       prop = RNA_def_property(srna, "strength", PROP_FLOAT, PROP_FACTOR);
-       RNA_def_property_range(prop, 0.001, 1.0);
-       RNA_def_property_ui_text(prop, "Strength", "Brush strength");
-
-       prop = RNA_def_property(srna, "count", PROP_INT, PROP_NONE);
-       RNA_def_property_range(prop, 1, 1000);
-       RNA_def_property_ui_range(prop, 1, 100, 10, 3);
-       RNA_def_property_ui_text(prop, "Count", "Particle count");
-
-       prop = RNA_def_property(srna, "steps", PROP_INT, PROP_NONE);
-       RNA_def_property_int_sdna(prop, NULL, "step");
-       RNA_def_property_range(prop, 1, SHRT_MAX);
-       RNA_def_property_ui_range(prop, 1, 50, 10, 3);
-       RNA_def_property_ui_text(prop, "Steps", "Brush steps");
-
-       prop = RNA_def_property(srna, "puff_mode", PROP_ENUM, PROP_NONE);
-       RNA_def_property_enum_sdna(prop, NULL, "invert");
-       RNA_def_property_enum_items(prop, puff_mode);
-       RNA_def_property_ui_text(prop, "Puff Mode", "");
-
-       prop = RNA_def_property(srna, "use_puff_volume", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_sdna(prop, NULL, "flag", PE_BRUSH_DATA_PUFF_VOLUME);
-       RNA_def_property_ui_text(prop, "Puff Volume",
-                                "Apply puff to unselected end-points (helps maintain hair volume when puffing root)");
-
-       prop = RNA_def_property(srna, "length_mode", PROP_ENUM, PROP_NONE);
-       RNA_def_property_enum_sdna(prop, NULL, "invert");
-       RNA_def_property_enum_items(prop, length_mode);
-       RNA_def_property_ui_text(prop, "Length Mode", "");
-
-       /* dummy */
-       prop = RNA_def_property(srna, "curve", PROP_POINTER, PROP_NONE);
-       RNA_def_property_struct_type(prop, "CurveMapping");
-       RNA_def_property_pointer_funcs(prop, "rna_ParticleBrush_curve_get", NULL, NULL, NULL);
-       RNA_def_property_ui_text(prop, "Curve", "");
-}
-
 static void rna_def_gpencil_sculpt(BlenderRNA *brna)
 {
        static EnumPropertyItem prop_direction_items[] = {
@@ -1093,7 +774,6 @@ void RNA_def_sculpt_paint(BlenderRNA *brna)
        rna_def_uv_sculpt(brna);
        rna_def_vertex_paint(brna);
        rna_def_image_paint(brna);
-       rna_def_particle_edit(brna);
        rna_def_gpencil_sculpt(brna);
        RNA_define_animate_sdna(true);
 }