mirror of
https://gitlab.com/veloren/veloren.git
synced 2024-08-30 18:12:32 +00:00
Added more cow noises, prepare for merge
This commit is contained in:
parent
9510869870
commit
b8749dc219
@ -10,6 +10,8 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
||||
### Added
|
||||
- Added a skill tree for mining, which gains xp from mining ores and gems.
|
||||
- Added debug line info to release builds, enhancing the usefulness of panic backtraces
|
||||
- NPCs and animals can now make sounds in response to certain events
|
||||
- Players can press H to greet others
|
||||
|
||||
### Changed
|
||||
- Entity-entity pushback is no longer applied in forced movement states like rolling and leaping.
|
||||
@ -18,7 +20,9 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
||||
### Removed
|
||||
|
||||
### Fixed
|
||||
|
||||
- Cases where no audio output could be produced before.
|
||||
- Significantly improved the performance of playing sound effects
|
||||
|
||||
## [0.10.0] - 2021-06-12
|
||||
|
||||
|
@ -835,50 +835,52 @@
|
||||
files: [
|
||||
"voxygen.audio.sfx.utterance.wendigo_angry",
|
||||
],
|
||||
threshold: 4.0,
|
||||
threshold: 0.2,
|
||||
),
|
||||
Utterance(Angry, BipedLarge): (
|
||||
files: [
|
||||
"voxygen.audio.sfx.utterance.ogre_angry",
|
||||
"voxygen.audio.sfx.utterance.ogre_angry2",
|
||||
],
|
||||
threshold: 4.0,
|
||||
threshold: 0.2,
|
||||
),
|
||||
Utterance(Angry, Reptile): (
|
||||
files: [
|
||||
"voxygen.audio.sfx.utterance.saurok_angry",
|
||||
],
|
||||
threshold: 4.0,
|
||||
threshold: 0.2,
|
||||
),
|
||||
Utterance(Angry, Bird): (
|
||||
files: [
|
||||
"voxygen.audio.sfx.utterance.bird_angry",
|
||||
],
|
||||
threshold: 4.0,
|
||||
threshold: 0.2,
|
||||
),
|
||||
Utterance(Calm, Pig): (
|
||||
files: [
|
||||
"voxygen.audio.sfx.utterance.pig_calm",
|
||||
],
|
||||
threshold: 4.0,
|
||||
threshold: 0.2,
|
||||
),
|
||||
Utterance(Calm, Cow): (
|
||||
files: [
|
||||
"voxygen.audio.sfx.utterance.cow_calm",
|
||||
"voxygen.audio.sfx.utterance.cow_calm2",
|
||||
"voxygen.audio.sfx.utterance.cow_calm3",
|
||||
],
|
||||
threshold: 4.0,
|
||||
threshold: 0.2,
|
||||
),
|
||||
Utterance(Calm, Sheep): (
|
||||
files: [
|
||||
"voxygen.audio.sfx.utterance.sheep_calm",
|
||||
],
|
||||
threshold: 4.0,
|
||||
threshold: 0.2,
|
||||
),
|
||||
Utterance(Greeting, HumanMale): (
|
||||
files: [
|
||||
"voxygen.audio.sfx.utterance.humanmale_greeting",
|
||||
],
|
||||
threshold: 4.0,
|
||||
threshold: 0.2,
|
||||
),
|
||||
}
|
||||
)
|
||||
|
BIN
assets/voxygen/audio/sfx/utterance/cow_calm2.ogg
(Stored with Git LFS)
Normal file
BIN
assets/voxygen/audio/sfx/utterance/cow_calm2.ogg
(Stored with Git LFS)
Normal file
Binary file not shown.
BIN
assets/voxygen/audio/sfx/utterance/cow_calm3.ogg
(Stored with Git LFS)
Normal file
BIN
assets/voxygen/audio/sfx/utterance/cow_calm3.ogg
(Stored with Git LFS)
Normal file
Binary file not shown.
@ -28,7 +28,7 @@ use common::{
|
||||
skills::Skill,
|
||||
slot::Slot,
|
||||
ChatMode, ControlAction, ControlEvent, Controller, ControllerInputs, GroupManip, InputKind,
|
||||
InventoryAction, InventoryEvent, InventoryUpdateEvent,
|
||||
InventoryAction, InventoryEvent, InventoryUpdateEvent, UtteranceKind,
|
||||
},
|
||||
event::{EventBus, LocalEvent},
|
||||
grid::Grid,
|
||||
@ -1224,6 +1224,10 @@ impl Client {
|
||||
}
|
||||
}
|
||||
|
||||
pub fn utter(&mut self, kind: UtteranceKind) {
|
||||
self.send_msg(ClientGeneral::ControlEvent(ControlEvent::Utterance(kind)));
|
||||
}
|
||||
|
||||
pub fn toggle_sneak(&mut self) {
|
||||
let is_sneaking = self
|
||||
.state
|
||||
|
@ -404,6 +404,7 @@ pub fn handle_sound(server: &mut Server, sound: &Sound) {
|
||||
.inbox
|
||||
.push_back(AgentEvent::ServerSound(propagated_sound));
|
||||
}
|
||||
}
|
||||
|
||||
// Attempt to turn this sound into an outcome to be received by frontends.
|
||||
if let Some(outcome) = match sound.kind {
|
||||
@ -416,5 +417,4 @@ pub fn handle_sound(server: &mut Server, sound: &Sound) {
|
||||
} {
|
||||
ecs.write_resource::<Vec<Outcome>>().push(outcome);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -106,7 +106,7 @@ use event_mapper::SfxEventMapper;
|
||||
use hashbrown::HashMap;
|
||||
use rand::prelude::*;
|
||||
use serde::Deserialize;
|
||||
use tracing::warn;
|
||||
use tracing::{debug, warn};
|
||||
use vek::*;
|
||||
|
||||
/// We watch the states of nearby entities in order to emit SFX at their
|
||||
@ -186,9 +186,8 @@ pub enum SfxEvent {
|
||||
Utterance(UtteranceKind, VoiceKind),
|
||||
}
|
||||
|
||||
#[derive(Clone, Debug, PartialEq, Deserialize, Hash, Eq)]
|
||||
#[derive(Copy, Clone, Debug, PartialEq, Deserialize, Hash, Eq)]
|
||||
pub enum VoiceKind {
|
||||
Mute,
|
||||
HumanFemale,
|
||||
HumanMale,
|
||||
BipedLarge,
|
||||
@ -203,8 +202,8 @@ pub enum VoiceKind {
|
||||
BigCat,
|
||||
}
|
||||
|
||||
fn body_to_voice(body: &Body) -> VoiceKind {
|
||||
match body {
|
||||
fn body_to_voice(body: &Body) -> Option<VoiceKind> {
|
||||
Some(match body {
|
||||
Body::Humanoid(body) => match &body.body_type {
|
||||
humanoid::BodyType::Female => VoiceKind::HumanFemale,
|
||||
humanoid::BodyType::Male => VoiceKind::HumanMale,
|
||||
@ -232,7 +231,7 @@ fn body_to_voice(body: &Body) -> VoiceKind {
|
||||
| quadruped_medium::Species::Yak
|
||||
| quadruped_medium::Species::Moose
|
||||
| quadruped_medium::Species::Dreadhorn => VoiceKind::Cow,
|
||||
_ => VoiceKind::Mute,
|
||||
_ => return None,
|
||||
},
|
||||
Body::BirdMedium(_) | Body::BirdLarge(_) => VoiceKind::Bird,
|
||||
Body::BipedLarge(body) => match body.species {
|
||||
@ -243,8 +242,8 @@ fn body_to_voice(body: &Body) -> VoiceKind {
|
||||
_ => VoiceKind::BipedLarge,
|
||||
},
|
||||
Body::Theropod(_) | Body::Dragon(_) => VoiceKind::Reptile,
|
||||
_ => VoiceKind::Mute,
|
||||
}
|
||||
_ => return None,
|
||||
})
|
||||
}
|
||||
|
||||
#[derive(Clone, Debug, PartialEq, Deserialize, Hash, Eq)]
|
||||
@ -516,9 +515,18 @@ impl SfxMgr {
|
||||
},
|
||||
},
|
||||
Outcome::Utterance { pos, kind, body } => {
|
||||
if let Some(voice) = body_to_voice(body) {
|
||||
let sfx_trigger_item =
|
||||
triggers.get_key_value(&SfxEvent::Utterance(*kind, body_to_voice(body)));
|
||||
audio.emit_sfx(sfx_trigger_item, *pos, Some(2.5), false);
|
||||
triggers.get_key_value(&SfxEvent::Utterance(*kind, voice));
|
||||
if let Some(sfx_trigger_item) = sfx_trigger_item {
|
||||
audio.emit_sfx(Some(sfx_trigger_item), *pos, Some(2.5), false);
|
||||
} else {
|
||||
debug!(
|
||||
"No utterance sound effect exists for ({:?}, {:?})",
|
||||
kind, voice
|
||||
);
|
||||
}
|
||||
}
|
||||
},
|
||||
Outcome::ExpChange { .. }
|
||||
| Outcome::ComboChange { .. }
|
||||
|
@ -2,7 +2,7 @@
|
||||
//! the need to decode files on each playback
|
||||
use common::assets::{self, Loader};
|
||||
use rodio::{source::Buffered, Decoder, Source};
|
||||
use std::{borrow::Cow, io, sync::Arc};
|
||||
use std::{borrow::Cow, io};
|
||||
use tracing::warn;
|
||||
|
||||
// Implementation of sound taken from this github issue:
|
||||
@ -13,10 +13,6 @@ pub struct SoundLoader;
|
||||
#[derive(Clone)]
|
||||
pub struct OggSound(Buffered<Decoder<io::Cursor<Vec<u8>>>>);
|
||||
|
||||
// impl AsRef<[u8]> for OggSound {
|
||||
// fn as_ref(&self) -> &[u8] { &self.0 }
|
||||
// }
|
||||
|
||||
impl Loader<OggSound> for SoundLoader {
|
||||
fn load(content: Cow<[u8]>, _: &str) -> Result<OggSound, assets::BoxedError> {
|
||||
let source = Decoder::new(io::Cursor::new(content.into_owned()))?.buffered();
|
||||
|
@ -15,7 +15,7 @@ use common::{
|
||||
inventory::slot::{EquipSlot, Slot},
|
||||
invite::InviteKind,
|
||||
item::{tool::ToolKind, ItemDef, ItemDesc},
|
||||
ChatMsg, ChatType, InputKind, InventoryUpdateEvent, Pos, Vel,
|
||||
ChatMsg, ChatType, InputKind, InventoryUpdateEvent, Pos, UtteranceKind, Vel,
|
||||
},
|
||||
consts::{MAX_MOUNT_RANGE, MAX_PICKUP_RANGE},
|
||||
outcome::Outcome,
|
||||
@ -525,6 +525,11 @@ impl PlayState for SessionState {
|
||||
self.client.borrow_mut().toggle_dance();
|
||||
}
|
||||
},
|
||||
GameInput::Greet => {
|
||||
if state {
|
||||
self.client.borrow_mut().utter(UtteranceKind::Greeting);
|
||||
}
|
||||
},
|
||||
GameInput::Sneak => {
|
||||
if state {
|
||||
self.stop_auto_walk();
|
||||
|
@ -123,6 +123,7 @@ impl ControlSettings {
|
||||
GameInput::Jump => KeyMouse::Key(VirtualKeyCode::Space),
|
||||
GameInput::Sit => KeyMouse::Key(VirtualKeyCode::K),
|
||||
GameInput::Dance => KeyMouse::Key(VirtualKeyCode::J),
|
||||
GameInput::Greet => KeyMouse::Key(VirtualKeyCode::H),
|
||||
GameInput::Glide => KeyMouse::Key(VirtualKeyCode::LShift),
|
||||
GameInput::Climb => KeyMouse::Key(VirtualKeyCode::Space),
|
||||
GameInput::ClimbDown => KeyMouse::Key(VirtualKeyCode::LControl),
|
||||
|
@ -39,6 +39,7 @@ pub enum GameInput {
|
||||
Jump,
|
||||
Sit,
|
||||
Dance,
|
||||
Greet,
|
||||
Glide,
|
||||
Climb,
|
||||
ClimbDown,
|
||||
@ -94,6 +95,7 @@ impl GameInput {
|
||||
GameInput::Jump => "gameinput.jump",
|
||||
GameInput::Sit => "gameinput.sit",
|
||||
GameInput::Dance => "gameinput.dance",
|
||||
GameInput::Greet => "gameinput.greet",
|
||||
GameInput::Glide => "gameinput.glide",
|
||||
GameInput::Climb => "gameinput.climb",
|
||||
GameInput::ClimbDown => "gameinput.climbdown",
|
||||
@ -159,6 +161,7 @@ impl GameInput {
|
||||
GameInput::Jump,
|
||||
GameInput::Sit,
|
||||
GameInput::Dance,
|
||||
GameInput::Greet,
|
||||
GameInput::Glide,
|
||||
GameInput::Climb,
|
||||
GameInput::ClimbDown,
|
||||
|
Loading…
Reference in New Issue
Block a user