2021-06-19 07:52:33 +02:00
|
|
|
<div align="center">
|
2024-12-25 02:21:47 +01:00
|
|
|
<img src=".github/logo.png" alt="Logo by jnix" width="250">
|
2021-06-19 07:52:33 +02:00
|
|
|
<h1>Flywheel</h1>
|
2024-12-25 02:21:47 +01:00
|
|
|
<h6>Reinventing the wheel so you don't have to.</h6>
|
|
|
|
<a href='https://ci.tterrag.com/job/Flywheel/job/1.20.1/'><img src='https://ci.tterrag.com/job/Flywheel/job/1.20.1/badge/icon' alt="Jenkins"></a>
|
|
|
|
<a href="/LICENSE.md"><img src="https://img.shields.io/github/license/Engine-Room/Flywheel?style=flat&color=900c3f" alt="License"></a>
|
|
|
|
<br>
|
2021-06-22 19:05:31 +02:00
|
|
|
<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>
|
2024-12-25 02:21:47 +01:00
|
|
|
<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>
|
2021-06-19 07:52:33 +02:00
|
|
|
<br>
|
|
|
|
</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
|
|
|
|
2024-12-25 02:21:47 +01:00
|
|
|
Flywheel provides an alternate, unified path for entity and block entity rendering that takes advantage of GPU
|
|
|
|
instancing. Flywheel gives the developer the flexibility to define their instance formats and write custom shaders
|
|
|
|
to ingest that data.
|
2021-06-22 19:05:31 +02:00
|
|
|
|
2024-12-25 02:21:47 +01:00
|
|
|
To accommodate the developer and leave more in the hands of the engine, Flywheel provides a custom shader loading and
|
|
|
|
templating system to hide the details of the CPU/GPU interface.
|
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 {
|
2024-05-25 21:06:11 +02:00
|
|
|
compileOnly fg.deobf("dev.engine_room.flywheel:flywheel-forge-api-${minecraft_version}:${flywheel_version}")
|
|
|
|
runtimeOnly fg.deobf("dev.engine_room.flywheel:flywheel-forge-${minecraft_version}:${flywheel_version}")
|
2021-07-01 02:02:28 +02:00
|
|
|
}
|
2021-06-22 19:05:31 +02:00
|
|
|
```
|
2024-05-11 03:20:35 +02:00
|
|
|
`${flywheel_version}` gets replaced by the version of Flywheel you want to use, eg. `1.0.0-beta`
|
2024-05-25 21:06:11 +02:00
|
|
|
|
2024-05-11 03:20:35 +02:00
|
|
|
`${minecraft_version}` gets replaced by the version of Minecraft you're on, eg. `1.20.1`
|
2021-06-22 19:05:31 +02:00
|
|
|
|
2021-11-27 20:31:50 +01:00
|
|
|
For a list of available Flywheel versions, you can check [the maven](https://maven.tterrag.com/com/jozufozu/flywheel/Flywheel-Forge/).
|
2021-06-30 21:43:54 +02:00
|
|
|
|
2021-07-01 02:02:28 +02:00
|
|
|
If you aren't using mixed mappings (or just want to be safe), add the following properties to your run configurations:
|
2021-06-22 19:05:31 +02:00
|
|
|
```groovy
|
2021-07-01 02:02:28 +02:00
|
|
|
property 'mixin.env.remapRefMap', 'true'
|
|
|
|
property 'mixin.env.refMapRemappingFile', "${projectDir}/build/createSrgToMcp/output.srg"
|
2021-06-22 19:05:31 +02:00
|
|
|
```
|
2021-07-01 02:02:28 +02:00
|
|
|
This ensures that Flywheel's mixins get properly loaded in your dev env.
|