Skip to content

Godot Jolt is a Godot extension that integrates the Jolt physics engine

License

Notifications You must be signed in to change notification settings

opsocket/godot-jolt

Repository files navigation

Godot Jolt

Godot Jolt is a native extension for the Godot game engine that allows you to use the Jolt physics engine to power Godot's 3D physics.

It functions as a drop-in replacement for Godot Physics, by implementing the same nodes that you would use normally, like RigidBody3D or CharacterBody3D.

Table of Contents

What features are there?

Better performance, mainly, but also just having different characteristics compared to Godot Physics.

There are also (completely optional) substitute nodes available for all the joints, which line up better with the interface that Jolt offers than what the default joints do. This allows for things like breakable joints, soft limits and the ability to override solver iterations per-joint.

What about determinism?

While Jolt itself offers deterministic simulations, Godot Jolt is not able to make such guarantees. Simulations in Godot Jolt may look deterministic, and may even happen to be deterministic, but this should not be relied upon if determinism is a hard requirement.

What's not supported?

  • SoftBody3D is not supported (yet)
  • WorldBoundaryShape3D is not supported
  • The physics server is not thread-safe (yet)
  • Double-precision builds of Godot are not supported (yet)
  • Memory usage is not reflected in Godot's performance monitors (yet)

What else is different?

  • Area3D detecting static bodies is opt-in, with a potentially heavy performance/memory cost
  • Joints only support soft limits through their substitutes (JoltHingeJoint3D, etc.)
  • Springs and motors are actually implemented in Generic6DOFJoint3D
  • Ray-casts using hit_back_faces will hit the back/inside of all shapes, not only concave ones
  • Shape-casts should be more accurate, but their cost also scale with the cast distance
  • Shape margins are used, but are treated as an upper bound and scale with the shape's extents
  • Manipulating a body's shape(s) after it has entered a scene tree can be costly
  • Contact impulses are estimations and won't be accurate when colliding with multiple bodies
  • HeightMapShape3D only supports square height maps with dimensions that are power-of-two

Also consider this note from Jolt's documentation:

In order for the simulation to be accurate, dynamic objects should be in the order of 0.1 to 10 meters long and have speeds in the order of 0 to 500 meters per second. Static object should be in the order of 0.1 to 2000 meters long.

What versions of Godot are supported?

Godot Jolt relies on the GDExtension API found in Godot 4 and only supports the latest stable version of Godot 4. Any custom build or pre-release of Godot, such as a beta or release candidate, may be incompatible and is therefore not supported.

What platforms are supported?

  • Windows (x86-64, x86)
  • Linux (x86-64, x86)
  • macOS (x86-64 + Apple Silicon)

Note that Linux support is limited by the version of glibc present on the system, which must be compatible with the one found in Ubuntu 20.04 (Focal Fossa).

How do I get started?

  1. Download it from GitHub or from Godot Asset Library
  2. Extract the files to your project directory
  3. Start (or restart) Godot
  4. Open your project settings
  5. Make sure "Advanced Settings" is enabled
  6. Go to "Physics" and then "3D"
  7. Change "Physics Engine" to "JoltPhysics3D"
  8. Restart Godot

What's the plan going forward?

In no particular order, here are some of the bigger items:

  • Adding new types of joints, like Jolt's DistanceConstraint
  • Adding support for double-precision, allowing for large worlds
  • Adding support for iOS and Android
  • Making the physics server thread-safe

See the v1.0.0 project board for a more up-to-date overview.

What settings are there?

See docs/settings.md for information about the project settings available in Godot Jolt.

How do I build from source?

See docs/building.md for information about how to build Godot Jolt from source.

What do the versions mean?

Godot Jolt adheres to Semantic Versioning, formatted as <major>.<minor>.<patch>. The major version will be incremented when backwards-incompatible API changes are made, the minor version will be incremented when backwards-compatible API changes are made and the patch version will be incremented when changes are made that don't affect the API.

"API", in this case, refers to any user-facing parts of the extension, such as nodes, properties, methods, parameters or project settings.

Note that major version 0.x.y carries a special meaning in semantic versioning, where even minor versions may contain backwards-incompatible changes.

See CHANGELOG.md for details about what notable changes were included in each version.

What's the license?

Godot Jolt is distributed under the MIT license. See LICENSE.txt for more details and THIRDPARTY.txt for third-party licenses.

About

Godot Jolt is a Godot extension that integrates the Jolt physics engine

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C++ 92.9%
  • CMake 5.9%
  • PowerShell 1.2%