Collection of Bevy plugins offering generic asset loaders for common file formats.
Supported formats:
| format
| feature
| example
|
|:----------|:----------|:--------------------------------------|
| json
| json
| json.rs
|
| msgpack
| msgpack
| msgpack.rs
|
| ron
| ron
| ron.rs
|
| toml
| toml
| toml.rs
|
| yaml
| yaml
| yaml.rs
|
Enable the feature(s) for the format(s) that you want to use.
Define the types that you would like to load from files and derive serde::Deserialize
and bevy::reflect::TypeUuid
for them. The latter requires a unique uuid as an attribute:
```rust
use bevy::reflect::TypeUuid;
struct Level { positions: Vec<[f32;3]>, } ```
With your types ready, you can add asset plugins for each type. Every plugin gets the asset type as a generic parameter. You also need to configure custom file endings for each type: ```rust norun use bevy::prelude::*; use bevycommonassets::json::JsonAssetPlugin; use bevycommonassets::msgpack::MsgPackAssetPlugin; use bevycommonassets::ron::RonAssetPlugin; use bevycommonassets::toml::TomlAssetPlugin; use bevycommon_assets::yaml::YamlAssetPlugin;
fn main() {
App::new()
.addplugins(DefaultPlugins)
.addplugin(JsonAssetPlugin::
struct Level { positions: Vec<[f32; 3]>, } ```
See the examples for working Bevy apps using the different formats.
The main branch is compatible with the latest Bevy release.
Compatibility of bevy_common_assets
versions:
| bevy_common_assets
| bevy
|
|:---------------------|:-------|
| 0.3
| 0.8
|
| 0.1
- 0.2
| 0.7
|
| main
| 0.8
|
| bevy_main
| main
|
If you only need to load ron
files, bevy_asset_ron
offers the same functionality as bevy_common_assets
.
Dual-licensed under either of
at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.