- Supported Bevy Versions: 0.15
- Supported Physics Engines: Avian, Rapier
- Geometry ✔️
- Only build geometry that has textures ✔️
- A post build map hook for spawning your entities ✔️
- XPBD physics ✔️
- Rapier physics ✔️
- Phong normals ❌ coming soon ❌
- Triggers ✔️
Run the example project with cargo run --release --features="avian" --example first_person
Under the example folder, you will find an example of how to use this plugin.
- The
Quevy Example
folder inside thetrenchbroom
folder is meant to be moved into the TrenchBroom game's folder (example:C:\Users\YOUR USER\AppData\Roaming\TrenchBroom\games\Qevy Example
) - Open TrenchBroom and select the
Qevy Example
game. - Set the game's path to the
example/assets
folder. - Open the
example.map
file located inexample/assets
.
Qevy supports the automatic generation of a configuration file on startup.
Qevy uses Bevy's Reflection to generate the file. All you have to do is to add the AutoCreateConfigPlugin
:
App::new()
.add_plugins((
DefaultPlugins,
qevy::MapAssetLoaderPlugin::default(),
qevy::auto_create_config::AutoCreateConfigPlugin::new("qevy_example.fgd".into()),
));
You can set the path and name of the file to be generated. It will be stored in bevy's assets
folder.
Now Qevy will try to generate a configuration file on startup, based on all registered structs. To register a struct, all you have to do is just:
App::new()
.register_qevy_entity::<TestBaseClass>();
And a qevy entity is a normal rust struct, which simply derives Reflect
and QevyEntity
:
#[derive(Reflect, Default, QevyEntity)]
#[reflect(QevyEntity, Default)]
#[qevy_entity(entity_type = "Base")]
struct TestBaseClass;
You can find an example of how to use this in the example
folder, called exporting_config.rs
.
Special thanks to Shfty over at Qodot for the wonderful Shambler crate which handles much of the heavy lifting.
This project is licensed under both MIT and Apache 2.0. You may use this project under the terms of either license.