notgiven688 / jitterphysics2

Fast, simple, and dependency-free physics engine written in C# with a clear and user-friendly API.
MIT License
237 stars 19 forks source link
csharp dotnet physics-engine

screenshot Jitter Physics 2

GitHub Actions Workflow Status Nuget Discord

Jitter Physics 2, the evolution of Jitter Physics, is an impulse-based dynamics engine with a semi-implicit Euler integrator. It is a fast, simple, and dependency-free engine written in C# with a clear and user-friendly API.

Run a small demo directly in the browser!

There is a tiny demo available for the Godot engine.

The official NuGet package can be found here.

See below for a fully-featured demo.


screenshot screenshot

screenshot screenshot

Getting Started

Jitter is cross-platform. The src directory contains four projects:

Project Description
Jitter2 The main library housing Jitter2's functionalities.
JitterDemo Features demo scenes rendered with OpenGL, tested on Linux and Windows.
JitterBenchmark The setup for conducting benchmarks using BenchmarkDotNet.
JitterTests Unit tests utilizing NUnit.

To run the demo scenes:

JitterDemo uses GLFW for accessing OpenGL and managing windows, and cimgui for GUI rendering. The project contains these native binaries in a precompiled form. On Linux you may have to install GLFW, e.g. on Ubuntu sudo apt-get install libglfw3-dev.

Features

Documentation

Find the documentation here.

Credits

Grateful acknowledgment to Erin Catto, Dirk Gregorius, Erwin Coumans, Gino van den Bergen, Daniel Chappuis, Marijn Tamis, Danny Chapman, Gary Snethen, and Christer Ericson for sharing their knowledge through forum posts, talks, code, papers, and books.

Special thanks also to the contributors of the predecessor projects JigLibX and Jitter.

Contribute 👋

Contributions of all forms are welcome! Feel free to fork the project and create a pull request.