2021-06-19 07:52:33 +02:00
|
|
|
<div align="center">
|
2023-11-26 22:46:23 +01:00
|
|
|
<img src="https://i.imgur.com/yVFgPpr.png" alt="Logo by @voxel_dani on Twitter" width="250">
|
|
|
|
<h1>Flywheel</h1>
|
|
|
|
<h6>A modern engine for modded Minecraft.</h6>
|
|
|
|
<a href='https://ci.tterrag.com/job/Flywheel/job/Fabric/job/1.18/'><img src='https://ci.tterrag.com/job/Flywheel/job/Fabric/job/1.18/badge/icon' alt="Jenkins"></a>
|
|
|
|
<a href="https://github.com/Jozufozu/Flywheel/blob/HEAD/LICENSE.md"><img src="https://img.shields.io/github/license/Jozufozu/Flywheel?style=flat&color=900c3f" alt="License"></a>
|
|
|
|
<a href="https://discord.gg/xjD59ThnXy"><img src="https://img.shields.io/discord/841464837406195712?color=5865f2&label=Discord&style=flat" alt="Discord"></a>
|
|
|
|
<a href="https://www.curseforge.com/minecraft/mc-mods/flywheel"><img src="http://cf.way2muchnoise.eu/486392.svg" alt="Curseforge Downloads"></a>
|
|
|
|
<a href="https://modrinth.com/mod/flywheel"><img src="https://img.shields.io/modrinth/dt/flywheel?logo=modrinth&label=&suffix=%20&style=flat&color=242629&labelColor=5ca424&logoColor=1c1c1c" alt="Modrinth"></a>
|
|
|
|
<br></br>
|
2021-06-19 07:52:33 +02:00
|
|
|
</div>
|
2021-06-22 19:17:48 +02:00
|
|
|
|
|
|
|
### About
|
2021-06-16 20:45:16 +02:00
|
|
|
|
2021-06-30 21:43:54 +02:00
|
|
|
The goal of this project is to provide tools for mod developers so they no longer have to worry about performance, or
|
|
|
|
limitations of Minecraft's archaic rendering engine. That said, this is primarily an outlet for me to have fun with
|
|
|
|
graphics programming.
|
2021-06-16 20:45:16 +02:00
|
|
|
|
2021-06-19 07:52:33 +02:00
|
|
|
### Instancing
|
2021-06-16 20:45:16 +02:00
|
|
|
|
2023-11-26 22:46:23 +01:00
|
|
|
Flywheel provides an alternate, unified path for entity and block entity rendering that takes advantage of GPU
|
2021-06-30 21:43:54 +02:00
|
|
|
instancing. In doing so, Flywheel gives the developer the flexibility to define their own vertex and instance formats,
|
|
|
|
and write custom shaders to ingest that data.
|
2021-06-16 20:45:16 +02:00
|
|
|
|
2021-06-19 07:52:33 +02:00
|
|
|
### Shaders
|
2021-06-20 01:52:23 +02:00
|
|
|
|
2023-11-26 22:46:23 +01:00
|
|
|
To accommodate the developer and leave more in the hands of the engine, Flywheel provides a custom shader loading and
|
2021-06-30 21:43:54 +02:00
|
|
|
templating system to hide the details of the CPU/GPU interface. This system is a work in progress. There will be
|
|
|
|
breaking changes, and I make no guarantees of backwards compatibility.
|
2021-06-20 01:52:23 +02:00
|
|
|
|
|
|
|
### Plans
|
2021-06-22 19:05:31 +02:00
|
|
|
|
2021-06-30 21:43:54 +02:00
|
|
|
- Vanilla performance improvements
|
|
|
|
- Compute shader particles
|
|
|
|
- Deferred rendering
|
|
|
|
- Different renderers for differently aged hardware
|
2021-06-22 19:05:31 +02:00
|
|
|
|
|
|
|
### Getting Started (For Developers)
|
|
|
|
|
2021-07-01 02:02:28 +02:00
|
|
|
Add the following repo and dependency to your `build.gradle`:
|
2021-06-30 21:43:54 +02:00
|
|
|
|
2021-06-22 19:05:31 +02:00
|
|
|
```groovy
|
|
|
|
repositories {
|
|
|
|
maven {
|
|
|
|
name "tterrag maven"
|
|
|
|
url "https://maven.tterrag.com/"
|
|
|
|
}
|
|
|
|
}
|
2021-07-01 02:02:28 +02:00
|
|
|
|
|
|
|
dependencies {
|
2023-11-26 22:46:23 +01:00
|
|
|
modImplementation "com.jozufozu.flywheel:flywheel-fabric-${flywheel_minecraft_version}:${flywheel_version}"
|
2021-07-01 02:02:28 +02:00
|
|
|
}
|
2021-06-22 19:05:31 +02:00
|
|
|
```
|
2023-11-26 22:46:23 +01:00
|
|
|
`${flywheel_version}` gets replaced by the version of Flywheel you want to use, eg. `0.6.9`.
|
|
|
|
`${flywheel_minecraft_version}` gets replaced by the version of Minecraft, eg. `1.18.2`.
|
2021-06-22 19:05:31 +02:00
|
|
|
|
2023-11-26 22:46:23 +01:00
|
|
|
For a list of available Flywheel versions, you can check [the maven](https://maven.tterrag.com/com/jozufozu/flywheel/).
|