2023-07-19 17:21:17 +04:00
|
|
|
---
|
|
|
|
-- `openmw.ambient` controls background sounds, specific to given player (2D-sounds).
|
2024-01-08 21:14:44 +01:00
|
|
|
-- Can be used only by menu scripts and local scripts, that are attached to a player.
|
2023-07-19 17:21:17 +04:00
|
|
|
-- @module ambient
|
|
|
|
-- @usage local ambient = require('openmw.ambient')
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
---
|
|
|
|
-- Play a 2D sound
|
|
|
|
-- @function [parent=#ambient] playSound
|
|
|
|
-- @param #string soundId ID of Sound record to play
|
|
|
|
-- @param #table options An optional table with additional optional arguments. Can contain:
|
|
|
|
--
|
2024-01-13 15:42:17 +04:00
|
|
|
-- * `timeOffset` - a floating point number >= 0, to skip some time (in seconds) from beginning of sound file (default: 0);
|
2023-07-19 17:21:17 +04:00
|
|
|
-- * `volume` - a floating point number >= 0, to set a sound volume (default: 1);
|
|
|
|
-- * `pitch` - a floating point number >= 0, to set a sound pitch (default: 1);
|
|
|
|
-- * `scale` - a boolean, to set if sound pitch should be scaled by simulation time scaling (default: true);
|
|
|
|
-- * `loop` - a boolean, to set if sound should be repeated when it ends (default: false);
|
|
|
|
-- @usage local params = {
|
|
|
|
-- timeOffset=0.1
|
|
|
|
-- volume=0.3,
|
|
|
|
-- scale=false,
|
|
|
|
-- pitch=1.0,
|
|
|
|
-- loop=true
|
|
|
|
-- };
|
|
|
|
-- ambient.playSound("shock bolt", params)
|
|
|
|
|
|
|
|
---
|
|
|
|
-- Play a 2D sound file
|
|
|
|
-- @function [parent=#ambient] playSoundFile
|
|
|
|
-- @param #string fileName Path to sound file in VFS
|
|
|
|
-- @param #table options An optional table with additional optional arguments. Can contain:
|
|
|
|
--
|
2024-01-13 15:42:17 +04:00
|
|
|
-- * `timeOffset` - a floating point number >= 0, to skip some time (in seconds) from beginning of sound file (default: 0);
|
2023-07-19 17:21:17 +04:00
|
|
|
-- * `volume` - a floating point number >= 0, to set a sound volume (default: 1);
|
|
|
|
-- * `pitch` - a floating point number >= 0, to set a sound pitch (default: 1);
|
|
|
|
-- * `scale` - a boolean, to set if sound pitch should be scaled by simulation time scaling (default: true);
|
|
|
|
-- * `loop` - a boolean, to set if sound should be repeated when it ends (default: false);
|
|
|
|
-- @usage local params = {
|
|
|
|
-- timeOffset=0.1
|
|
|
|
-- volume=0.3,
|
|
|
|
-- scale=false,
|
|
|
|
-- pitch=1.0,
|
|
|
|
-- loop=true
|
|
|
|
-- };
|
|
|
|
-- ambient.playSoundFile("Sound\\test.mp3", params)
|
|
|
|
|
|
|
|
---
|
|
|
|
-- Stop a sound
|
|
|
|
-- @function [parent=#ambient] stopSound
|
|
|
|
-- @param #string soundId ID of Sound record to stop
|
|
|
|
-- @usage ambient.stopSound("shock bolt");
|
|
|
|
|
|
|
|
---
|
|
|
|
-- Stop a sound file
|
|
|
|
-- @function [parent=#ambient] stopSoundFile
|
|
|
|
-- @param #string fileName Path to sound file in VFS
|
|
|
|
-- @usage ambient.stopSoundFile("Sound\\test.mp3");
|
|
|
|
|
|
|
|
---
|
|
|
|
-- Check if sound is playing
|
|
|
|
-- @function [parent=#ambient] isSoundPlaying
|
|
|
|
-- @param #string soundId ID of Sound record to check
|
|
|
|
-- @return #boolean
|
|
|
|
-- @usage local isPlaying = ambient.isSoundPlaying("shock bolt");
|
|
|
|
|
|
|
|
---
|
|
|
|
-- Check if sound file is playing
|
|
|
|
-- @function [parent=#ambient] isSoundFilePlaying
|
|
|
|
-- @param #string fileName Path to sound file in VFS
|
|
|
|
-- @return #boolean
|
|
|
|
-- @usage local isPlaying = ambient.isSoundFilePlaying("Sound\\test.mp3");
|
|
|
|
|
2023-09-12 14:30:24 +04:00
|
|
|
---
|
|
|
|
-- Play a sound file as a music track
|
|
|
|
-- @function [parent=#ambient] streamMusic
|
|
|
|
-- @param #string fileName Path to file in VFS
|
2024-01-13 15:42:17 +04:00
|
|
|
-- @param #table options An optional table with additional optional arguments. Can contain:
|
|
|
|
--
|
|
|
|
-- * `fadeOut` - a floating point number >= 0, time (in seconds) to fade out current track before playing this one (default 1.0);
|
|
|
|
-- @usage local params = {
|
|
|
|
-- fadeOut=2.0
|
|
|
|
-- };
|
|
|
|
-- ambient.streamMusic("Music\\Test\\Test.mp3", params)
|
2023-09-12 14:30:24 +04:00
|
|
|
|
|
|
|
---
|
|
|
|
-- Stop to play current music
|
|
|
|
-- @function [parent=#ambient] stopMusic
|
|
|
|
-- @usage ambient.stopMusic();
|
|
|
|
|
2023-09-13 17:48:49 +04:00
|
|
|
---
|
|
|
|
-- Check if music is playing
|
|
|
|
-- @function [parent=#ambient] isMusicPlaying
|
|
|
|
-- @return #boolean
|
|
|
|
-- @usage local isPlaying = ambient.isMusicPlaying();
|
|
|
|
|
2024-03-15 18:19:44 +04:00
|
|
|
---
|
|
|
|
-- Play an ambient voiceover.
|
|
|
|
-- @function [parent=#ambient] say
|
|
|
|
-- @param #string fileName Path to sound file in VFS
|
|
|
|
-- @param #string text Subtitle text (optional)
|
|
|
|
-- @usage -- play voiceover and print messagebox
|
|
|
|
-- ambient.say("Sound\\Vo\\Misc\\voice.mp3", "Subtitle text")
|
|
|
|
-- @usage -- play voiceover, without messagebox
|
|
|
|
-- ambient.say("Sound\\Vo\\Misc\\voice.mp3")
|
|
|
|
|
|
|
|
---
|
|
|
|
-- Stop an ambient voiceover
|
|
|
|
-- @function [parent=#ambient] stopSay
|
|
|
|
-- @param #string fileName Path to sound file in VFS
|
|
|
|
-- @usage ambient.stopSay();
|
|
|
|
|
|
|
|
---
|
|
|
|
-- Check if an ambient voiceover is playing
|
|
|
|
-- @function [parent=#Sound] isSayActive
|
|
|
|
-- @return #boolean
|
|
|
|
-- @usage local isActive = isSayActive();
|
|
|
|
|
2023-07-19 17:21:17 +04:00
|
|
|
return nil
|