Move SpawnAsteroid event into events.rs
This commit is contained in:
@@ -8,8 +8,7 @@ use std::time::Duration;
|
|||||||
use bevy::prelude::*;
|
use bevy::prelude::*;
|
||||||
|
|
||||||
use crate::{
|
use crate::{
|
||||||
GameAssets, Lifetime, WorldSize, config::ASTEROID_LIFETIME, events::AsteroidDestroy,
|
config::ASTEROID_LIFETIME, events::{AsteroidDestroy, SpawnAsteroid}, physics::Velocity, GameAssets, Lifetime, WorldSize
|
||||||
physics::Velocity,
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#[derive(Component, Deref, DerefMut)]
|
#[derive(Component, Deref, DerefMut)]
|
||||||
@@ -51,13 +50,6 @@ impl AsteroidSpawner {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Event)]
|
|
||||||
pub struct SpawnAsteroid {
|
|
||||||
pos: Vec2,
|
|
||||||
vel: Vec2,
|
|
||||||
size: AsteroidSize,
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Update the asteroid spawn timer and spawn any asteroids
|
/// Update the asteroid spawn timer and spawn any asteroids
|
||||||
/// that are due this frame.
|
/// that are due this frame.
|
||||||
pub fn tick_asteroid_manager(
|
pub fn tick_asteroid_manager(
|
||||||
|
|||||||
@@ -1,5 +1,7 @@
|
|||||||
use bevy::prelude::*;
|
use bevy::prelude::*;
|
||||||
|
|
||||||
|
use crate::asteroids::AsteroidSize;
|
||||||
|
|
||||||
/// Signals that the player's ship has been destroyed.
|
/// Signals that the player's ship has been destroyed.
|
||||||
/// Used when the player collides with an asteroid.
|
/// Used when the player collides with an asteroid.
|
||||||
#[derive(Event)]
|
#[derive(Event)]
|
||||||
@@ -10,6 +12,13 @@ pub(crate) struct ShipDestroy;
|
|||||||
#[derive(Event)]
|
#[derive(Event)]
|
||||||
pub(crate) struct AsteroidDestroy(pub Entity);
|
pub(crate) struct AsteroidDestroy(pub Entity);
|
||||||
|
|
||||||
|
#[derive(Event)]
|
||||||
|
pub struct SpawnAsteroid {
|
||||||
|
pub pos: Vec2,
|
||||||
|
pub vel: Vec2,
|
||||||
|
pub size: AsteroidSize,
|
||||||
|
}
|
||||||
|
|
||||||
// TODO: BulletDestroy
|
// TODO: BulletDestroy
|
||||||
// Which depends on the still-pending Bullet component creation.
|
// Which depends on the still-pending Bullet component creation.
|
||||||
|
|
||||||
|
|||||||
@@ -73,7 +73,7 @@ impl Plugin for AsteroidPlugin {
|
|||||||
)
|
)
|
||||||
.run_if(in_state(GameState::Playing)),
|
.run_if(in_state(GameState::Playing)),
|
||||||
)
|
)
|
||||||
.add_event::<asteroids::SpawnAsteroid>()
|
.add_event::<events::SpawnAsteroid>()
|
||||||
.add_event::<events::AsteroidDestroy>()
|
.add_event::<events::AsteroidDestroy>()
|
||||||
.add_event::<events::ShipDestroy>()
|
.add_event::<events::ShipDestroy>()
|
||||||
.add_event::<events::BulletDestroy>();
|
.add_event::<events::BulletDestroy>();
|
||||||
|
|||||||
Reference in New Issue
Block a user