Difference between revisions of "Sound.play"

From MiniScript Wiki
Jump to navigation Jump to search
(added example from CBC#8)
Line 24: Line 24:
 
<ms>s = file.loadSound("/sys/sounds/bonus.wav")
 
<ms>s = file.loadSound("/sys/sounds/bonus.wav")
 
s.play</ms>
 
s.play</ms>
 +
 +
The next example loads some background music from a file, set it to loop, and then play it at volume 0.2.  (Note: to actually run this example, you would need to have a ''background_loop.wav'' file on your user disk in a ''/usr/sound'' directory.)
 +
<ms>
 +
background_loop_track = file.loadSound("/usr/sound/background_loop.wav")
 +
background_loop_track.loop = 1
 +
background_loop_track.play 0.2
 +
</ms>
 +
  
 
The following example (taken from [https://youtu.be/EPMGMsSbT3g this video]) shows how to adjust the stereo pan of a sound based on the X position of a mouse click.
 
The following example (taken from [https://youtu.be/EPMGMsSbT3g this video]) shows how to adjust the stereo pan of a sound based on the X position of a mouse click.

Revision as of 21:44, 28 April 2023

Sound.play plays a sound. Call this on a Sound object initialized either Sound.init, or loaded via file.loadSound.

Arguments

Parameter Name Type Default Value Meaning
volume number 1 volume (0-1) of the sound
pan number 0 left (-1) to right (1) stereo pan of the sound
speed number 1 speed multiplier (1 == standard speed)

Usage Notes

The sound will automatically stop if .loop is false, but will repeat until explicitly stopped if .loop is true. Note that speed will change both the duration and pitch of the sound, due to changing the speed of the waveforms being played.

Example

Here is a simple example of loading and playing a sound.

s = file.loadSound("/sys/sounds/bonus.wav")
s.play

The next example loads some background music from a file, set it to loop, and then play it at volume 0.2. (Note: to actually run this example, you would need to have a background_loop.wav file on your user disk in a /usr/sound directory.)

background_loop_track = file.loadSound("/usr/sound/background_loop.wav")
background_loop_track.loop = 1
background_loop_track.play 0.2


The following example (taken from this video) shows how to adjust the stereo pan of a sound based on the X position of a mouse click.

clear
snd = file.loadSound("/sys/sounds/bongo.wav")

while true  // repeat forever (press Control-C to exit)
    if mouse.button then
        // play a sound, panning left/right according to mouse X position
        pan = mouse.x / 480 - 1
        snd.play 1, pan
        
        // wait for the mouse button to be released
        while mouse.button; yield; end while
    end if
    yield
end while