Allow input to fall through flashing messages
This is for parity with the original game
This commit is contained in:
parent
550713aaf8
commit
094d8e8617
2 changed files with 66 additions and 57 deletions
|
@ -5,7 +5,7 @@ use crate::resources::{flashing_message::FlashingMessageIntent, *};
|
||||||
|
|
||||||
mod player;
|
mod player;
|
||||||
|
|
||||||
pub fn handle_intent(bterm: &mut BTerm, world: &mut World, resources: &mut Resources) {
|
pub fn handle_intent(bterm: &mut BTerm, _world: &mut World, resources: &mut Resources) {
|
||||||
if let Some(key) = bterm.key {
|
if let Some(key) = bterm.key {
|
||||||
if let Some(flashing_message) = &resources.flashing_message {
|
if let Some(flashing_message) = &resources.flashing_message {
|
||||||
if let Some(intent) = &flashing_message.intent {
|
if let Some(intent) = &flashing_message.intent {
|
||||||
|
@ -25,27 +25,22 @@ pub fn handle_intent(bterm: &mut BTerm, world: &mut World, resources: &mut Resou
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn handle(world: &mut World, resources: &mut Resources, bterm: &mut BTerm) {
|
pub fn handle(world: &mut World, resources: &mut Resources, bterm: &mut BTerm) {
|
||||||
if resources.flashing_message.is_some() {
|
if resources.flashing_message.is_some() && bterm.key.is_some() {
|
||||||
if bterm.key.is_some() {
|
|
||||||
handle_intent(bterm, world, resources);
|
handle_intent(bterm, world, resources);
|
||||||
resources.flashing_message = None;
|
resources.flashing_message = None;
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
match bterm.key {
|
match bterm.key {
|
||||||
None => {}
|
None => {}
|
||||||
Some(key) => match key {
|
Some(key) => match key {
|
||||||
VirtualKeyCode::Left | VirtualKeyCode::J => {
|
VirtualKeyCode::Left | VirtualKeyCode::J => {
|
||||||
player::try_move(-1, 0, world, resources);
|
player::try_move(-1, 0, world, resources);
|
||||||
}
|
}
|
||||||
VirtualKeyCode::U | VirtualKeyCode::Home => {
|
VirtualKeyCode::U | VirtualKeyCode::Home => player::try_move(-1, -1, world, resources),
|
||||||
player::try_move(-1, -1, world, resources)
|
|
||||||
}
|
|
||||||
VirtualKeyCode::Up | VirtualKeyCode::I => {
|
VirtualKeyCode::Up | VirtualKeyCode::I => {
|
||||||
player::try_move(0, -1, world, resources);
|
player::try_move(0, -1, world, resources);
|
||||||
}
|
}
|
||||||
VirtualKeyCode::O | VirtualKeyCode::PageUp => {
|
VirtualKeyCode::O | VirtualKeyCode::PageUp => player::try_move(1, -1, world, resources),
|
||||||
player::try_move(1, -1, world, resources)
|
|
||||||
}
|
|
||||||
VirtualKeyCode::Right | VirtualKeyCode::K => {
|
VirtualKeyCode::Right | VirtualKeyCode::K => {
|
||||||
player::try_move(1, 0, world, resources);
|
player::try_move(1, 0, world, resources);
|
||||||
}
|
}
|
||||||
|
@ -55,9 +50,7 @@ pub fn handle(world: &mut World, resources: &mut Resources, bterm: &mut BTerm) {
|
||||||
VirtualKeyCode::Down | VirtualKeyCode::M => {
|
VirtualKeyCode::Down | VirtualKeyCode::M => {
|
||||||
player::try_move(0, 1, world, resources);
|
player::try_move(0, 1, world, resources);
|
||||||
}
|
}
|
||||||
VirtualKeyCode::N | VirtualKeyCode::End => {
|
VirtualKeyCode::N | VirtualKeyCode::End => player::try_move(-1, 1, world, resources),
|
||||||
player::try_move(-1, 1, world, resources)
|
|
||||||
}
|
|
||||||
VirtualKeyCode::W => {
|
VirtualKeyCode::W => {
|
||||||
player::whip(world, resources);
|
player::whip(world, resources);
|
||||||
}
|
}
|
||||||
|
@ -71,6 +64,9 @@ pub fn handle(world: &mut World, resources: &mut Resources, bterm: &mut BTerm) {
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
VirtualKeyCode::P => {
|
VirtualKeyCode::P => {
|
||||||
|
resources
|
||||||
|
.sound_output
|
||||||
|
.play_sound(resources.sound_effects.pause.clone());
|
||||||
resources.flashing_message =
|
resources.flashing_message =
|
||||||
Some(FlashingMessage::from(" Press any key to resume game. "));
|
Some(FlashingMessage::from(" Press any key to resume game. "));
|
||||||
}
|
}
|
||||||
|
@ -81,5 +77,4 @@ pub fn handle(world: &mut World, resources: &mut Resources, bterm: &mut BTerm) {
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -38,6 +38,7 @@ pub struct SoundEffects {
|
||||||
pub slow_hit: SoundSamples,
|
pub slow_hit: SoundSamples,
|
||||||
pub medium_hit: SoundSamples,
|
pub medium_hit: SoundSamples,
|
||||||
pub fast_hit: SoundSamples,
|
pub fast_hit: SoundSamples,
|
||||||
|
pub pause: SoundSamples,
|
||||||
rng: RandomNumberGenerator,
|
rng: RandomNumberGenerator,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -153,6 +154,19 @@ impl SoundEffects {
|
||||||
duration: Duration::from_millis(25),
|
duration: Duration::from_millis(25),
|
||||||
}],
|
}],
|
||||||
}),
|
}),
|
||||||
|
pause: sound_output.render_sound_effect(&SoundEffect {
|
||||||
|
sounds: {
|
||||||
|
let mut sounds = vec![Sound {
|
||||||
|
sound_type: SoundType::Tone(500),
|
||||||
|
duration: Duration::from_millis(100),
|
||||||
|
}];
|
||||||
|
sounds.extend((100..=200).rev().step_by(10).map(|x| Sound {
|
||||||
|
sound_type: SoundType::Tone(x),
|
||||||
|
duration: Duration::from_millis(20),
|
||||||
|
}));
|
||||||
|
sounds
|
||||||
|
},
|
||||||
|
}),
|
||||||
rng: RandomNumberGenerator::new(),
|
rng: RandomNumberGenerator::new(),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue