mirror of
https://github.com/bevyengine/bevy
synced 2024-12-25 12:33:07 +00:00
51 lines
1.4 KiB
Rust
51 lines
1.4 KiB
Rust
|
use bevy_ecs::prelude::*;
|
||
|
use rand::Rng;
|
||
|
use std::ops::Deref;
|
||
|
|
||
|
// In this example we add a counter resource and increase it's value in one system,
|
||
|
// while a different system prints the current count to the console.
|
||
|
fn main() {
|
||
|
// Create a world
|
||
|
let mut world = World::new();
|
||
|
|
||
|
// Add the counter resource
|
||
|
world.insert_resource(Counter { value: 0 });
|
||
|
|
||
|
// Create a schedule and a stage
|
||
|
let mut schedule = Schedule::default();
|
||
|
let mut update = SystemStage::parallel();
|
||
|
|
||
|
// Add systems to increase the counter and to print out the current value
|
||
|
update.add_system(increase_counter.system().label(CounterSystem::Increase));
|
||
|
update.add_system(print_counter.system().after(CounterSystem::Increase));
|
||
|
schedule.add_stage("update", update);
|
||
|
|
||
|
for iteration in 1..=10 {
|
||
|
println!("Simulating frame {}/10", iteration);
|
||
|
schedule.run(&mut world);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Counter resource to be increased and read by systems
|
||
|
#[derive(Debug)]
|
||
|
struct Counter {
|
||
|
pub value: i32,
|
||
|
}
|
||
|
|
||
|
// System label to enforce a run order of our systems
|
||
|
#[derive(SystemLabel, Debug, Clone, PartialEq, Eq, Hash)]
|
||
|
enum CounterSystem {
|
||
|
Increase,
|
||
|
}
|
||
|
|
||
|
fn increase_counter(mut counter: ResMut<Counter>) {
|
||
|
if rand::thread_rng().gen_bool(0.5) {
|
||
|
counter.value += 1;
|
||
|
println!(" Increased counter value");
|
||
|
}
|
||
|
}
|
||
|
|
||
|
fn print_counter(counter: Res<Counter>) {
|
||
|
println!(" {:?}", counter.deref());
|
||
|
}
|