Skip to content

Commit

Permalink
Merge pull request #42306 from madmiraal/fix-39947
Browse files Browse the repository at this point in the history
Update Bullet Area overlaps when Area properties or shapes change.
  • Loading branch information
pouleyKetchoupp authored Nov 18, 2021
2 parents b7260e0 + 0d3e853 commit 756eab2
Show file tree
Hide file tree
Showing 6 changed files with 12 additions and 7 deletions.
4 changes: 4 additions & 0 deletions modules/bullet/area_bullet.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -153,6 +153,7 @@ int AreaBullet::find_overlapping_object(CollisionObjectBullet *p_colObj) {

void AreaBullet::set_monitorable(bool p_monitorable) {
monitorable = p_monitorable;
updated = true;
}

bool AreaBullet::is_monitoring() const {
Expand All @@ -162,6 +163,7 @@ bool AreaBullet::is_monitoring() const {
void AreaBullet::main_shape_changed() {
CRASH_COND(!get_main_shape());
btGhost->setCollisionShape(get_main_shape());
updated = true;
}

void AreaBullet::reload_body() {
Expand Down Expand Up @@ -192,6 +194,7 @@ void AreaBullet::on_collision_filters_change() {
if (space) {
space->reload_collision_filters(this);
}
updated = true;
}

void AreaBullet::add_overlap(CollisionObjectBullet *p_otherObject) {
Expand Down Expand Up @@ -276,6 +279,7 @@ void AreaBullet::set_event_callback(Type p_callbackObjectType, const Callable &p
set_godot_object_flags(get_godot_object_flags() | GOF_IS_MONITORING_AREA);
} else {
set_godot_object_flags(get_godot_object_flags() & (~GOF_IS_MONITORING_AREA));
clear_overlaps(true);
}
}

Expand Down
2 changes: 1 addition & 1 deletion modules/bullet/area_bullet.h
Original file line number Diff line number Diff line change
Expand Up @@ -152,7 +152,7 @@ class AreaBullet : public RigidCollisionObjectBullet {

virtual void on_collision_filters_change();
virtual void on_collision_checker_start() {}
virtual void on_collision_checker_end() { isTransformChanged = false; }
virtual void on_collision_checker_end() { updated = false; }

void add_overlap(CollisionObjectBullet *p_otherObject);
void put_overlap_as_exit(int p_index);
Expand Down
3 changes: 2 additions & 1 deletion modules/bullet/collision_object_bullet.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -187,6 +187,7 @@ void CollisionObjectBullet::on_exit_area(AreaBullet *p_area) {

void CollisionObjectBullet::set_godot_object_flags(int flags) {
bt_collision_object->setUserIndex2(flags);
updated = true;
}

int CollisionObjectBullet::get_godot_object_flags() const {
Expand Down Expand Up @@ -220,7 +221,7 @@ const btTransform &CollisionObjectBullet::get_transform__bullet() const {
}

void CollisionObjectBullet::notify_transform_changed() {
isTransformChanged = true;
updated = true;
}

RigidCollisionObjectBullet::~RigidCollisionObjectBullet() {
Expand Down
6 changes: 3 additions & 3 deletions modules/bullet/collision_object_bullet.h
Original file line number Diff line number Diff line change
Expand Up @@ -128,7 +128,7 @@ class CollisionObjectBullet : public RIDBullet {
/// New area is added when overlap with new area (AreaBullet::addOverlap), then is removed when it exit (CollisionObjectBullet::onExitArea)
/// This array is used mainly to know which area hold the pointer of this object
Vector<AreaBullet *> areasOverlapped;
bool isTransformChanged = false;
bool updated = false;

public:
CollisionObjectBullet(Type p_type);
Expand Down Expand Up @@ -206,9 +206,9 @@ class CollisionObjectBullet : public RIDBullet {
Transform3D get_transform() const;
virtual void set_transform__bullet(const btTransform &p_global_transform);
virtual const btTransform &get_transform__bullet() const;

bool is_transform_changed() const { return isTransformChanged; }
virtual void notify_transform_changed();

bool is_updated() const { return updated; }
};

class RigidCollisionObjectBullet : public CollisionObjectBullet, public ShapeOwnerBullet {
Expand Down
2 changes: 1 addition & 1 deletion modules/bullet/rigid_body_bullet.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -420,7 +420,7 @@ void RigidBodyBullet::on_collision_checker_start() {

void RigidBodyBullet::on_collision_checker_end() {
// Always true if active and not a static or kinematic body
isTransformChanged = btBody->isActive() && !btBody->isStaticOrKinematicObject();
updated = btBody->isActive() && !btBody->isStaticOrKinematicObject();
}

bool RigidBodyBullet::add_collision_object(RigidBodyBullet *p_otherObject, const Vector3 &p_hitWorldLocation, const Vector3 &p_hitLocalLocation, const Vector3 &p_hitNormal, const real_t &p_appliedImpulse, int p_other_shape_index, int p_local_shape_index) {
Expand Down
2 changes: 1 addition & 1 deletion modules/bullet/space_bullet.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -700,7 +700,7 @@ void SpaceBullet::check_ghost_overlaps() {
RigidCollisionObjectBullet *otherObject = static_cast<RigidCollisionObjectBullet *>(overlapped_bt_co->getUserPointer());
btVector3 other_body_scale(otherObject->get_bt_body_scale());

if (!area->is_transform_changed() && !otherObject->is_transform_changed()) {
if (!area->is_updated() && !otherObject->is_updated()) {
hasOverlap = -1 != area->find_overlapping_object(otherObject);
goto collision_found;
}
Expand Down

0 comments on commit 756eab2

Please sign in to comment.