d06aa0042e
Bump the version up , after the two fixes from @Azorlogh :) |
||
---|---|---|
assets | ||
crates | ||
docs | ||
examples | ||
tools/gltf_auto_export | ||
.gitignore | ||
Cargo.lock | ||
Cargo.toml | ||
LICENSE_APACHE.md | ||
LICENSE_MIT.md | ||
LICENSE.md | ||
README.md |
Blender_bevy_components_workflow
Crates & tools for adding components from gltf files in the Bevy game engine.
It enables minimalistic Blender (gltf) centric workflow for Bevy, ie defining entites & their components inside Blender using Blender's objects custom properties. Aka "Blender as editor for Bevy"
It also allows you to setup 'blueprints' in Blender by using collections (the recomended way to go most of the time), or directly on single use objects .
Features
- Useful if you want to use Blender (or any editor allowing to export gltf with configurable gltf_extras) as your Editor
- define Bevy components as custom properties in Blender (some visually , some using RON, though an older JSON version is also available)
- no plugin or extra tools needed in Blender (but I provide a little Blender plugin to auto-export to gltf on save (and more !) if you want !)
- define components in Blender Collections & override any of them in your collection instances if you want
- ability to automatically turn your Blender collections into gltf Blueprints for reuse
- minimal setup & code, you can have something basic running fast
- minimal dependencies: Bevy, Serde & Ron only !
- opensource
Crates
-
bevy_gltf_components This crate allows you to define components direclty inside gltf files and instanciate/inject the components on the Bevy side. There is a video tutorial/explanation if you want, or you can read the crate docs/ basic example
-
bevy_gltf_blueprints This crate adds the ability to define Blueprints/Prefabs for Bevy inside gltf files and spawn them in Bevy. With the ability to override and add components when spawning. There is a video tutorial/explanation for this one too, or you can read the crate docs/ basic example
Tools
Blender: gltf_auto_export
- for convenience I also added a Blender addon that automatically exports your level/world from Blender to gltf whenever you save your Blend file
- it also supports automatical exports of collections as Gltf blueprints & more !
Please read the README of the add-on for installation & use instructions
Examples
- basic use of
bevy_gltf_components
only, to spawn entities with components defined inside gltf files - advanced more advanced example : use of
bevy_gltf_blueprints
to spawn a level and then populate it with entities coming from different gltf files, live (at runtime) spawning of entities etc - animation how to use and trigger animations from gltf files (a feature of
bevy_gltf_blueprints
)
Workflow
The workflow goes as follows (once you got your Bevy code setup)
- create & register all your components you want to be able to set from the Blender side (this is basic Bevy, no specific work needed)
-
Create an object / collection (for reuse) in Blender
-
Go to object properties => add a property, and add your component data
-
unit structs, enums, and more complex strucs / components are all supported, (if the fields are basic data types at least, have not tried more complex ones yet, but should also work)
- for structs with no params (unit structs): use a STRING property & an empty value
- for structs with params: use a RON representation of your fields (see below)
- for tupple strucs you can use any of the built in Blender custom property types: Strings, Booleans, floats, Vectors, etc
In rust:
(the Rust struct for these components for reference is here )
In rust:
(the Rust struct for this component for reference is here )
There is an other examples of using various Component types: Enums, Tupple structs, strucs with fields etc here, even colors, Vecs (arrays), Vec2, Vec3 etc are all supported
-
-
for collections & their instances:
-
I usually create a library scene with nested collections
- the leaf collections are the assets you use in your level
- add an empty called xxxx_components
- add the components as explained in the previous part
-
In the Level/world itself, just create an instance of the collection (standard Blender, ie Shift+A -> collection instance -> pick the collection)
-
-
export your level as a glb/gltf file :
- using Blender's default gltf exporter !!IMPORTANT you need to check the following:
- or much better, using gltf_auto_export
-
load it in Bevy (see the demo main file for this)
-
you should see the components attached to your entities in Bevy
note: you get a warning if there are any unregistered components in your gltf file (they get ignored) you will get a warning per entity
Limitations / issues
- some components have to be defined in
text
in Blender, might try using the AppTypeRegistry and some Python code on the Blender side for a nicer UI (although this loses the "fast & easy, no tooling" approach) - Some of
bevy_rapier
/physics code / ways to define colliders could perhaps be done better within Blender (currently it also goes via RON) - there seem to be some random system ordering issues that I am still investigating (only when replacing proxy components, no breaking bugs, just restarting your Bevy app is enough)
Future work
- I have a number of other tools/ code helpers that I have not yet included here, because they need cleanup/ might make this example too complex
- simplified animation logic: ie instead of having to manually specify the animations you need from a gltf file, it is integrated with the spawning system above, which creates a
Animations
component in all entities that have anAnimationPlayer
and you can simply query for both to easilly control your animations per entity.
Credits
- somebody I cannot recall helped me originally with the gltf loading tracker in the Bevy Discord, so thanks ! And if it was you, please let me know so I can give credit where credit is due :)
Contributors
Thanks to all the contributors helping out with this project ! Big kudos to you, contributions are always appreciated ! :)
License
This repo, all its code, contents & assets is Dual-licensed under either of
- Apache License, Version 2.0, (LICENSE-APACHE or https://www.apache.org/licenses/LICENSE-2.0)
- MIT license (LICENSE-MIT or https://opensource.org/licenses/MIT)