-
-
Notifications
You must be signed in to change notification settings - Fork 21.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[Bullet] move_and_slide() causes jitter when colliding with corners between walls #32182
Comments
I can confirm this. This is the reason I switched to rigid body physics instead. |
Yes, this is a problem of capsule collision shape and sphere shape. For now you may consider using a cylinder or a box shape with a ray shape at the bottom with length of the maximum step height your character can climb. |
I might be wrong, but I think jitter happens with a box shape too. (need to test this properly) |
Yep, looks like it's happening with a box shape as well. |
Hello there, I can confirm that this still occurs in v3.2 Alpha 2. As a side note, calling move_and_slide*() on each separate axis can help mitigate the issue like so:
As a side effect, the player unfortunately slides more slowly along walls and the jittering is only reduced when using Bullet instead of GodotPhysics using this method. It's also a pretty ugly hack. As far as using move_and_slide() as it was intended went, I tested this with reasonably complex CSG constructs and level geometry I made in Blender and the jitter occurs only with these, further corroborating @narcissawright's claim that it never happens with convex shapes. Here is a demonstration project that contains a simple CSG "garage" (the one immediately in front of the player in the scene). Moving into the corner produces jitter, but the “towers” behind the player, which are ordinary convex BoxShapes, do not produce jitter when moving into the corner. |
Duplicate of #29392? |
I confirm that this problem is still present in the 3.2rc1. @Calinou I think is a big problem, can we label it to be fixed in this milestone? Now if you have a simple 3d platform if you stay between 2 perfect aligned static platforms you will see this jittering and is frustrating to fix this issue. |
@grevius5 We need more information before we can look into fixing this. It'd be worth testing whether this issue occurs in Godot 3.0 (and to a lesser extent, 2.1). If the bug doesn't occur in those versions, you could then look into bisecting the commit where the bug started appearing. This requires building the engine from source many times, but it should be entirely feasible. In the meantime, I wonder if lawnjelly's smoothing-addon can be used to make the bug less noticeable. |
@Calinou you may be aware of this already (apologies if you are) but in #34596, @madmiraal provided some greatly needed specificity and cited this PR as the point at which the jittering started to appear in GodotPhysics and Bullet respectively. Do you think it could lend sufficient insight to the team? |
I had this problem in a 3D platformer I was making. When a character (a kinematic body) ran along a set of boxes (static objects) 1 unit high, my character's Y-coordinate would oscillate between 1.06 and 1.10 as they crossed a corner. For a character 1 unit high, this results in the camera jittering up and down by 4% everytime they crossed a boundary. I worked around the issue by scaling every object in my game by a factor of 1,000%. The jitter is still about 0.04, but when the objects are 10x bigger it's harder to notice. |
The small amount of jitter remaining after my previous fix (scaling everything up 1,000%) was still bothering me, so I came up with a second fix which removes the remaining jitter. Here's my new gravity function.
The jitter occurs because the Y velocity is a small number like -6, which is too slow for Godot to detect a collision in some cases. Then the Y velocity increases to something faster like -13 and Godot detects a collision. It alternates between these states every other frame, causing the jitter With this if statement I've added, the Y velocity is never a small number like -6, so Godot always detects a collision. You can adjust the '-10' value based on what works for you. |
Can be still reproduced in 3.2.4 beta 5, but occurs only when using Bullet Physics (default settings). Switching to Godot Physics 3D fixes the issue. |
I just experienced this bug on Godot 3.3. Switching to Godot Physics 3D fixed it for me as well. |
Switching to Godot Physics 3D does NOT fix this issue. |
To solve this problem, there must be a way to check that we are in the corner. |
I found a simple way, the jitter is almost imperceptible if you give a slight tilt for a СollisionShape, for example along the x-axis rotation degrees 0.1 and change the vector in move_and_slide() or whatever you have from (X, 0, Z) to (X, -0.1, Z). |
@VadimBigBoss Could you provide a minimal project to reproduce this issue with Godot Physics? |
Here is a very minimal 3D project that I believe reproduces this issue in both Bullet and GodotPhysics. Steps to Reproduce: (tested on 3.4.0)
I believe this proves it is a major issue that affects both of the 3D engines, affects a commonly used feature and occurs during very basic usage. note: I have made an equivalent project in Godot 4.0 (dev 2017590) and can reproduce the issue when Block on Wall is disabled. |
As mentioned in Shifty's Godot Character Movement Manifesto, the
In other words, create a function that wraps |
@Calinou: Instead of cross-posting an external tutorial, this should be documented somewhere, and even better if a wrapper were provided out of the box since it fixes a known issue. |
Thanks! That solved that issue. That link also is interesting too. I'll have to try those other things if I try to do more complicated stuff in the future. |
For the record, I can confirm that this issue is still reproducible in the current #32182 (comment) It does seem to be Bullet-specific indeed, switching the above three MRPs to GodotPhysics solves this specific issue. |
Changing Vector3.UP with Vector3(0, -0.1, 0) seem to solve issue for me (Godot 3.4.4) |
I have tried recreating this in various Godot 4.0 alphas and betas (including the current beta 9) and the effect is far less noticeable than in Godot 3.x. |
This issue is still present in GDPhysics, the bottom collision point can oscillate between 2 values when using move_and_slide_with_snap() Godot Version 3.5.2 Stable, even on a flat surface after colliding with some corner or edge |
Godot version:
3.1.1.stable.official
OS/device including version:
Linux / Fedora 30
Issue description:
move_and_slide() can cause a lot of jitter when KinematicBody collides with corners, or anything actually. (sometimes even with simple 90° corners)
You can observe this in pretty much every single project that uses move_and_slide(), including the FPS Tutorial from Godot documentation.
Notes:
Steps to reproduce:
Minimal reproduction project:
godot-fps-master.zip
The text was updated successfully, but these errors were encountered: