diff options
| author | Ovnuniarchos | 2015-12-14 02:56:11 +0100 |
|---|---|---|
| committer | Ovnuniarchos | 2015-12-14 02:56:49 +0100 |
| commit | 89efebbf561fa19d29533acdd3716f8d1385595a (patch) | |
| tree | 0c20563f42e01914c0134ffa0102e5d51f90b326 /servers/physics/body_sw.cpp | |
| parent | 7f96f0603e16a970c7b0ea1fba936e56baf80d4a (diff) | |
| download | godot-89efebbf561fa19d29533acdd3716f8d1385595a.tar.gz godot-89efebbf561fa19d29533acdd3716f8d1385595a.tar.zst godot-89efebbf561fa19d29533acdd3716f8d1385595a.zip | |
New and corrected are override modes.
Diffstat (limited to 'servers/physics/body_sw.cpp')
| -rw-r--r-- | servers/physics/body_sw.cpp | 30 |
1 files changed, 21 insertions, 9 deletions
diff --git a/servers/physics/body_sw.cpp b/servers/physics/body_sw.cpp index c66e73b43..79d08b1e7 100644 --- a/servers/physics/body_sw.cpp +++ b/servers/physics/body_sw.cpp @@ -406,29 +406,41 @@ void BodySW::integrate_forces(real_t p_step) { return; AreaSW *def_area = get_space()->get_default_area(); - AreaSW *damp_area = def_area; + // AreaSW *damp_area = def_area; ERR_FAIL_COND(!def_area); int ac = areas.size(); - bool replace = false; + bool stopped = false; gravity = Vector3(0,0,0); area_linear_damp = 0; area_angular_damp = 0; if (ac) { areas.sort(); const AreaCMP *aa = &areas[0]; - damp_area = aa[ac-1].area; - for(int i=ac-1;i>=0;i--) { - _compute_area_gravity_and_dampenings(aa[i].area); - if (aa[i].area->get_space_override_mode() == PhysicsServer::AREA_SPACE_OVERRIDE_REPLACE) { - replace = true; - break; + // damp_area = aa[ac-1].area; + for(int i=ac-1;i>=0 && !stopped;i--) { + PhysicsServer::AreaSpaceOverrideMode mode=aa[i].area->get_space_override_mode(); + switch (mode) { + case PhysicsServer::AREA_SPACE_OVERRIDE_COMBINE: + case PhysicsServer::AREA_SPACE_OVERRIDE_COMBINE_REPLACE: { + _compute_area_gravity_and_dampenings(aa[i].area); + stopped = mode==PhysicsServer::AREA_SPACE_OVERRIDE_COMBINE_REPLACE; + } break; + case PhysicsServer::AREA_SPACE_OVERRIDE_REPLACE: + case PhysicsServer::AREA_SPACE_OVERRIDE_REPLACE_COMBINE: { + gravity = Vector3(0,0,0); + area_angular_damp = 0; + area_linear_damp = 0; + _compute_area_gravity_and_dampenings(aa[i].area); + stopped = mode==PhysicsServer::AREA_SPACE_OVERRIDE_REPLACE; + } break; + default: {} } } } - if( !replace ) { + if( !stopped ) { _compute_area_gravity_and_dampenings(def_area); } |
