Commit: 84becb870f8e0785bdfca0f381c7b06f415e4e6a
Author: Campbell Barton
Date:   Mon Jun 4 17:58:07 2018 +0200
Branches: blender2.8
https://developer.blender.org/rB84becb870f8e0785bdfca0f381c7b06f415e4e6a

Merge branch 'master' into blender2.8

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



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

diff --cc source/blender/makesrna/intern/rna_particle.c
index 3af0ac63d96,5b0b718fc28..4f9ac94dec1
--- a/source/blender/makesrna/intern/rna_particle.c
+++ b/source/blender/makesrna/intern/rna_particle.c
@@@ -619,28 -674,37 +620,50 @@@ static void rna_Particle_reset_dependen
        rna_Particle_reset(bmain, scene, ptr);
  }
  
 -static void rna_Particle_change_type(Main *bmain, Scene *scene, PointerRNA 
*ptr)
 +static void rna_Particle_change_type(Main *bmain, Scene *UNUSED(scene), 
PointerRNA *ptr)
  {
 -      particle_recalc(bmain, scene, ptr, PSYS_RECALC_RESET | 
PSYS_RECALC_TYPE);
 -      DAG_relations_tag_update(bmain);
 +      ParticleSettings *part = ptr->id.data;
 +
 +      /* Iterating over all object is slow, but no better solution exists at 
the moment. */
 +      for (Object *ob = bmain->object.first; ob; ob = ob->id.next) {
 +              for (ParticleSystem *psys = ob->particlesystem.first; psys; 
psys = psys->next) {
 +                      if (psys->part == part) {
 +                              psys_changed_type(ob, psys);
 +                              psys->recalc |= PSYS_RECALC_RESET;
 +                              DEG_id_tag_update(&ob->id, OB_RECALC_DATA);
 +                      }
 +              }
 +      }
 +
 +      WM_main_add_notifier(NC_OBJECT | ND_PARTICLE | NA_EDITED, NULL);
 +      DEG_relations_tag_update(bmain);
  }
  
- static void rna_Particle_change_physics(Main *bmain, Scene *scene, PointerRNA 
*ptr)
+ static void rna_Particle_change_physics_type(Main *bmain, Scene *scene, 
PointerRNA *ptr)
  {
        particle_recalc(bmain, scene, ptr, PSYS_RECALC_RESET | 
PSYS_RECALC_PHYS);
+       
+       ParticleSettings *part = (ParticleSettings *)ptr->data;
+ 
+       if (part->phystype == PART_PHYS_BOIDS && part->boids == NULL) {
+               BoidState *state;
+ 
+               part->boids = MEM_callocN(sizeof(BoidSettings), "Boid 
Settings");
+               boid_default_settings(part->boids);
+ 
+               state = boid_new_state(part->boids);
+               BLI_addtail(&state->rules, 
boid_new_rule(eBoidRuleType_Separate));
+               BLI_addtail(&state->rules, boid_new_rule(eBoidRuleType_Flock));
+ 
+               ((BoidRule*)state->rules.first)->flag |= BOIDRULE_CURRENT;
+ 
+               state->flag |= BOIDSTATE_CURRENT;
+               BLI_addtail(&part->boids->states, state);
+       }
+       else if (part->phystype == PART_PHYS_FLUID && part->fluid == NULL) {
+               part->fluid = MEM_callocN(sizeof(SPHFluidSettings), "SPH Fluid 
Settings");
+               BKE_particlesettings_fluid_default_settings(part);
+       }
  }
  
  static void rna_Particle_redo_child(Main *bmain, Scene *scene, PointerRNA 
*ptr)

_______________________________________________
Bf-blender-cvs mailing list
[email protected]
https://lists.blender.org/mailman/listinfo/bf-blender-cvs

Reply via email to