parallel_query/
parallel_query.rs1use bevy::{ecs::batching::BatchingStrategy, prelude::*};
4use rand::{Rng, SeedableRng};
5use rand_chacha::ChaCha8Rng;
6
7#[derive(Component, Deref)]
8struct Velocity(Vec2);
9
10fn spawn_system(mut commands: Commands, asset_server: Res<AssetServer>) {
11 commands.spawn(Camera2d);
12 let texture = asset_server.load("branding/icon.png");
13
14 let mut rng = ChaCha8Rng::seed_from_u64(19878367467713);
17 for z in 0..128 {
18 commands.spawn((
19 Sprite::from_image(texture.clone()),
20 Transform::from_scale(Vec3::splat(0.1))
21 .with_translation(Vec2::splat(0.0).extend(z as f32)),
22 Velocity(20.0 * Vec2::new(rng.r#gen::<f32>() - 0.5, rng.r#gen::<f32>() - 0.5)),
23 ));
24 }
25}
26
27fn move_system(mut sprites: Query<(&mut Transform, &Velocity)>) {
29 sprites
38 .par_iter_mut()
39 .for_each(|(mut transform, velocity)| {
40 transform.translation += velocity.extend(0.0);
41 });
42}
43
44fn bounce_system(window: Query<&Window>, mut sprites: Query<(&Transform, &mut Velocity)>) {
46 let Ok(window) = window.single() else {
47 return;
48 };
49 let width = window.width();
50 let height = window.height();
51 let left = width / -2.0;
52 let right = width / 2.0;
53 let bottom = height / -2.0;
54 let top = height / 2.0;
55 sprites
59 .par_iter_mut()
60 .batching_strategy(BatchingStrategy::fixed(32))
61 .for_each(|(transform, mut v)| {
62 if !(left < transform.translation.x
63 && transform.translation.x < right
64 && bottom < transform.translation.y
65 && transform.translation.y < top)
66 {
67 v.0 = -v.0;
69 }
70 });
71}
72
73fn main() {
74 App::new()
75 .add_plugins(DefaultPlugins)
76 .add_systems(Startup, spawn_system)
77 .add_systems(Update, (move_system, bounce_system))
78 .run();
79}