bevy/examples/asset/hot_asset_reloading.rs

39 lines
1.3 KiB
Rust
Raw Normal View History

2020-05-17 03:18:30 +00:00
use bevy::prelude::*;
/// Hot reloading allows you to modify assets on disk and they will be "live reloaded" while your game is running.
/// This lets you immediately see the results of your changes without restarting the game.
2020-07-28 20:43:07 +00:00
/// This example illustrates hot reloading mesh changes.
2020-05-17 03:18:30 +00:00
fn main() {
App::build()
.add_plugins(DefaultPlugins)
.add_startup_system(setup.system())
2020-05-17 03:18:30 +00:00
.run();
}
fn setup(commands: &mut Commands, asset_server: Res<AssetServer>) {
// Load our mesh:
let scene_handle = asset_server.load("models/monkey/Monkey.gltf#Scene0");
2020-05-17 03:18:30 +00:00
2020-05-17 17:29:42 +00:00
// Tell the asset server to watch for asset changes on disk:
2020-05-17 03:18:30 +00:00
asset_server.watch_for_changes().unwrap();
2020-05-17 17:29:42 +00:00
// Any changes to the mesh will be reloaded automatically! Try making a change to Monkey.gltf.
// You should see the changes immediately show up in your app.
2020-05-17 03:18:30 +00:00
2020-05-17 17:29:42 +00:00
// Add entities to the world:
2020-07-10 04:18:35 +00:00
commands
2020-05-17 03:18:30 +00:00
// mesh
.spawn_scene(scene_handle)
2020-05-17 03:18:30 +00:00
// light
.spawn(LightBundle {
transform: Transform::from_xyz(4.0, 5.0, 4.0),
2020-05-17 03:18:30 +00:00
..Default::default()
})
// camera
.spawn(PerspectiveCameraBundle {
transform: Transform::from_xyz(2.0, 2.0, 6.0)
.looking_at(Vec3::default(), Vec3::unit_y()),
2020-05-17 03:18:30 +00:00
..Default::default()
});
}