Fix cast_motion sometimes failing
- Fixes Godot physics failing when the cast Shape is inside of, or already colliding with another Shape. - Fixes Bullet physics failing when there is no motion. - Ensures Godot and Bullet physics behave the same. - Updates the documentation to exclude the caveats for the failures and differences.
This commit is contained in:
parent
803f6d2388
commit
2e99b5b137
5 changed files with 13 additions and 9 deletions
|
@ -16,8 +16,9 @@
|
||||||
<argument index="0" name="shape" type="Physics2DShapeQueryParameters">
|
<argument index="0" name="shape" type="Physics2DShapeQueryParameters">
|
||||||
</argument>
|
</argument>
|
||||||
<description>
|
<description>
|
||||||
Checks how far the shape can travel toward a point. If the shape can not move, the array will be empty.
|
Checks how far a [Shape2D] can move without colliding. All the parameters for the query, including the shape and the motion, are supplied through a [Physics2DShapeQueryParameters] object.
|
||||||
[b]Note:[/b] Both the shape and the motion are supplied through a [Physics2DShapeQueryParameters] object. The method will return an array with two floats between 0 and 1, both representing a fraction of [code]motion[/code]. The first is how far the shape can move without triggering a collision, and the second is the point at which a collision will occur. If no collision is detected, the returned array will be [code][1, 1][/code].
|
Returns an array with the safe and unsafe proportions (between 0 and 1) of the motion. The safe proportion is the maximum fraction of the motion that can be made without a collision. The unsafe proportion is the minimum fraction of the distance that must be moved for a collision. If no collision is detected a result of [code][1.0, 1.0][/code] will be returned.
|
||||||
|
[b]Note:[/b] Any [Shape2D]s that the shape is already colliding with e.g. inside of, will be ignored. Use [method collide_shape] to determine the [Shape2D]s that the shape is already colliding with.
|
||||||
</description>
|
</description>
|
||||||
</method>
|
</method>
|
||||||
<method name="collide_shape">
|
<method name="collide_shape">
|
||||||
|
|
|
@ -18,8 +18,9 @@
|
||||||
<argument index="1" name="motion" type="Vector3">
|
<argument index="1" name="motion" type="Vector3">
|
||||||
</argument>
|
</argument>
|
||||||
<description>
|
<description>
|
||||||
Checks whether the shape can travel to a point. The method will return an array with two floats between 0 and 1, both representing a fraction of [code]motion[/code]. The first is how far the shape can move without triggering a collision, and the second is the point at which a collision will occur. If no collision is detected, the returned array will be [code][1, 1][/code].
|
Checks how far a [Shape] can move without colliding. All the parameters for the query, including the shape, are supplied through a [PhysicsShapeQueryParameters] object.
|
||||||
If the shape can not move, the returned array will be [code][0, 0][/code] under Bullet, and empty under GodotPhysics.
|
Returns an array with the safe and unsafe proportions (between 0 and 1) of the motion. The safe proportion is the maximum fraction of the motion that can be made without a collision. The unsafe proportion is the minimum fraction of the distance that must be moved for a collision. If no collision is detected a result of [code][1.0, 1.0][/code] will be returned.
|
||||||
|
[b]Note:[/b] Any [Shape]s that the shape is already colliding with e.g. inside of, will be ignored. Use [method collide_shape] to determine the [Shape]s that the shape is already colliding with.
|
||||||
</description>
|
</description>
|
||||||
</method>
|
</method>
|
||||||
<method name="collide_shape">
|
<method name="collide_shape">
|
||||||
|
|
|
@ -179,8 +179,10 @@ bool BulletPhysicsDirectSpaceState::cast_motion(const RID &p_shape, const Transf
|
||||||
bt_xform_to.getOrigin() += bt_motion;
|
bt_xform_to.getOrigin() += bt_motion;
|
||||||
|
|
||||||
if ((bt_xform_to.getOrigin() - bt_xform_from.getOrigin()).fuzzyZero()) {
|
if ((bt_xform_to.getOrigin() - bt_xform_from.getOrigin()).fuzzyZero()) {
|
||||||
|
r_closest_safe = 1.0f;
|
||||||
|
r_closest_unsafe = 1.0f;
|
||||||
bulletdelete(btShape);
|
bulletdelete(btShape);
|
||||||
return false;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
GodotClosestConvexResultCallback btResult(bt_xform_from.getOrigin(), bt_xform_to.getOrigin(), &p_exclude, p_collide_with_bodies, p_collide_with_areas);
|
GodotClosestConvexResultCallback btResult(bt_xform_from.getOrigin(), bt_xform_to.getOrigin(), &p_exclude, p_collide_with_bodies, p_collide_with_areas);
|
||||||
|
|
|
@ -265,11 +265,11 @@ bool PhysicsDirectSpaceStateSW::cast_motion(const RID &p_shape, const Transform
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
//test initial overlap
|
//test initial overlap, ignore objects it's inside of.
|
||||||
sep_axis = p_motion.normalized();
|
sep_axis = p_motion.normalized();
|
||||||
|
|
||||||
if (!CollisionSolverSW::solve_distance(shape, p_xform, col_obj->get_shape(shape_idx), col_obj_xform, point_A, point_B, aabb, &sep_axis)) {
|
if (!CollisionSolverSW::solve_distance(shape, p_xform, col_obj->get_shape(shape_idx), col_obj_xform, point_A, point_B, aabb, &sep_axis)) {
|
||||||
return false;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
//just do kinematic solving
|
//just do kinematic solving
|
||||||
|
|
|
@ -269,10 +269,10 @@ bool Physics2DDirectSpaceStateSW::cast_motion(const RID &p_shape, const Transfor
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
//test initial overlap
|
//test initial overlap, ignore objects it's inside of.
|
||||||
if (CollisionSolver2DSW::solve(shape, p_xform, Vector2(), col_obj->get_shape(shape_idx), col_obj_xform, Vector2(), NULL, NULL, NULL, p_margin)) {
|
if (CollisionSolver2DSW::solve(shape, p_xform, Vector2(), col_obj->get_shape(shape_idx), col_obj_xform, Vector2(), NULL, NULL, NULL, p_margin)) {
|
||||||
|
|
||||||
return false;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
//just do kinematic solving
|
//just do kinematic solving
|
||||||
|
|
Loading…
Reference in a new issue