vphysics_jolt/README.md

106 lines
6.5 KiB
Markdown

![VPhysics Jolt Logo](assets/cube_base_nobg.png "VPhysics Jolt")
## What is Volt? ⚡
Volt (VPhysics Jolt) is a replacement for Source's VPhysics which uses IVP/Havok using [Jolt Physics](https://github.com/jrouwe/JoltPhysics/)<br>
Created by [Joshua Ashton (🐸✨)](https://github.com/Joshua-Ashton) [@phys_ballsocket](https://twitter.com/phys_ballsocket) and [Josh Dowell (Slartibarty)](https://github.com/Slartibarty) [@Slartbarty](https://twitter.com/Slartbarty).
Volt is designed to be incredibly high performance, supporting thousands of objects at once without bringing tick/framerate down to a crawl.
In our testing, the performance overhead from having thousands of objects moving at once, now comes from the client code needing to update/render, as going out of the PVS of these objects will still cause them to be simulated, but will no longer be rendered.
## Features
Volt is mostly feature complete, but is missing some things such as support for raycast vehicles, breakable constraints, and perhaps other things we've missed!
It is our goal to implement any missing features at some point.
Below is a feature table of Volt vs VPhysics and the Bullet VPhysics project.
If we missed anything we don't support or we do, feel free to add to it.
It is not meant to be a bash on anyone elses work however, the Bullet VPhysics project was a great inspiration to us!
| Feature | VPhysics | Volt (VPhysics Jolt) | Bullet VPhysics |
|:--------------|:--------:|:-------------:|:---------------:|
| Constraints (except Pulleys) | ✔️ | ✔️ | ✔️ |
| Pulleys | ✔️ | ❌ | ❌ |
| Breakable constraints | ✔️ | ❌ | ❌ |
| Motors (Motion Controllers) | ✔️ | ✔️ | ✔️ |
| Motors (Constraint) | ✔️ | ✔️ | ❌ |
| Ragdolls | ✔️ | ✔️ (some bugs) | ✔️ |
| Triggers | ✔️ | ✔️ | ❌ |
| Object touch callbacks | ✔️ | ✔️ | ❌ |
| Prop damage/breaking | ✔️ | ✔️ | ❌ |
| Fluid events | ✔️ | ✔️ | ❌ |
| Prop splashing effects | ✔️ | ✔️ | ❌ |
| Wheeled Vehicles | ✔️ | ✔️ | ✔️ |
| Raycast Vehicles (ie. Airboat) | ✔️ | ❌ | 〰️ (janky) |
| NPCs/Doors (Shadow Controllers) | ✔️ | ✔️ | ✔️ |
| Save/Restore Support | ✔️ | ✔️ | ❌ |
| Portal Support | ✔️ | ✔️ | ❌ |
| Game per-object collide callback support<br>eg. no-collide | ✔️ | ✔️ | ❌ |
| Crash-resistant solver | ❌ | ✔️ | (no data) |
| Supports thousands of objects without lag | ❌ | ✔️ | ❌ |
| Multithreaded | ❌ | ✔️ | ✔️ (partially) |
| Proper player controller | ✔️ | ❌ (needs work!) | ✔️ (partially) |
## Bugs
VPhysics Jolt is not without its flaws, however. See the [issue tracker](https://github.com/Joshua-Ashton/VPhysics-Jolt/issues) for bugs that are known.
There are definitely going to be bugs that we don't know about or haven't encountered, or different quirks across engine branches.
## How to build
The Volt code is provided as-is, it is up to you to build it for your SDK, etc.
Volt should build fine against Source SDK 2013 and Alien Swarm SDK on a MSVC or GCC compiler with at least C++20 support.
*If you are building directly against the public SDK 2013 and Alien Swarm SDKs, you will need to do minor work to memoverride.cpp to make it compatible with the newer compilers and newer Windows SDKs.*
Unfortunately we cannot redistribute the additional code/headers needed to build Volt for games such as Garry's Mod which uses a different VPhysics interface (CS:GO's) to what is found in the Valve-provided public SDKs.
For full build instructions pertaining to SDK 2013, refernce [build.md](/build.md).
## Download
Development builds for each commit for SDK2013 SP/MP + ASW are available as artifacts on each commit on GitHub through GitHub Actions.</br>
Development builds for each commit for Garry's Mod are available on [froggi.es](https://git.froggi.es/joshua/vphysics_jolt_gmod_builds).
For each release, binary builds are provided for Garry's Mod and Source SDK 2013 on the [Releases](https://github.com/Joshua-Ashton/VPhysics-Jolt/releases/) page.
## Media
### Lots of Melons + Dumpster
[![Lots of Melons + Dumpster](https://img.youtube.com/vi/gPDQkmfQCsc/0.jpg)](https://www.youtube.com/watch?v=gPDQkmfQCsc "Lots of Melons + Dumpster")
### Physically Simulated Chain
[![Physically Simulated Chain](https://img.youtube.com/vi/tVmQTmbSJM0/0.jpg)](https://www.youtube.com/watch?v=tVmQTmbSJM0 "Physically Simulated Chain")
### Lots of Balls Test
[![Lots of Balls Test](https://img.youtube.com/vi/tYfiTyRtmz8/0.jpg)](https://www.youtube.com/watch?v=tYfiTyRtmz8 "Lots of Balls Test")
### Wheels + Weld Car Dupe Test
[![Weld Car Dupe Test](https://img.youtube.com/vi/5_QbbXbIrg8/0.jpg)](https://www.youtube.com/watch?v=5_QbbXbIrg8 "Weld Car Dupe Test")
### Door + NPC (Physics Shadowed Objects) Test
[![Door + NPC (Physics Shadowed Objects) Test](https://img.youtube.com/vi/SdEj7HTuJmU/0.jpg)](https://www.youtube.com/watch?v=SdEj7HTuJmU "Door + NPC (Physics Shadowed Objects) Test")
### Lots of Cubes + Ragdolls + Funnel
[![Lots of Cubes + Ragdolls + Funnel](https://img.youtube.com/vi/CLVnSwg33Dk/0.jpg)](https://www.youtube.com/watch?v=CLVnSwg33Dk "Lots of Cubes + Ragdolls + Funnel")
### Slow Mo Cubes
[![Slow Mo Cubes](https://img.youtube.com/vi/GzW_4bufwEk/0.jpg)](https://www.youtube.com/watch?v=GzW_4bufwEk "Slow Mo Cubes")
### Propane in Dumpster
[![Propane in Dumpster](https://img.youtube.com/vi/10vvRJVHGQc/0.jpg)](https://www.youtube.com/watch?v=10vvRJVHGQc "Propane in Dumpster")
*Have some cool media of stuff going on in Volt you'd like to add? Feel free to make a pull request!*
## Projects using Volt
### [Portal 2: Desolation](https://emberspark.games/desolation/)
### [Prelude: Online](https://prelude.online/)
# Have fun! 🐸⚡