Abstract
LISPBUILDER-SDL-MIXER provides a Common Lisp binding to the SDL_mixer library. The library mixes multiple samples into one or more audio output channels. Lisp callbacks provide the capability to implement custom mixing algorithms and custom audio effects over and above the distance attenuation, panning and reverse stereo effects provided by the SDL_mixer library. WAVE, MOD, MIDI, OGG, AIFF, RIFF and VOC formats are supported.
LISPBUILDER-SDL-MIXER has a dependency on LISPBUILDER-SDL.
The code comes with a MIT-style license so you can basically do with it whatever you want.
Download shortcut: http://www.balooga.com/lispbuilder/lispbuilder-sdl-mixer.tgz.
;; Load an mp3 music file and play the file continuously. (sdl:with-init (sdl:sdl-init-video sdl:sdl-init-audio) (sdl:window 50 10) (sdl-mixer:OPEN-AUDIO) (let ((music (sdl-mixer:load-music "sample.mp3"))) (sdl-mixer:play-music music :loop t) (sdl:with-events () (:quit-event () (sdl-mixer:Halt-Music) (sdl-mixer:free music) (sdl-mixer:close-audio) t) (:idle () (sdl:update-display)))))
+channel-post+
+channels+
+default-channels+
+default-format+
+default-frequency+
+default-sample-buffer+
+max-volume+
allocate-channels
audio-channels-p
audio-format-p
audio-frequency-p
audio-opened-p
channel-volume
chunk
close-audio
free
halt-music
halt-sample
linked-version
load-music
load-sample
music
music-fading-p
music-paused-p
music-playing-p
music-position
music-type-of
music-type-p
music-volume
open-audio
pause-music
play-music
play-sample
register-music-finished
register-music-mixer
register-sample-finished
rewind-music
sample-fading-p
sample-from-channel
sample-paused-p
sample-playing-p
sample-volume
sdl-mixer-version
unregister-music-finished
unregister-music-mixer
unregister-sample-finished
Current Version: The latest stable version of LISPBUILDER-SDL-MIXER, together with this documentation can be downloaded from http://www.balooga.com/lispbuilder/lispbuilder-sdl-mixer.tgz. The current version is 0.2.0.
Development: The latest developement version is available via anonymous SVN:
svn co https://lispbuilder.svn.sourceforge.net/svnroot/lispbuilder lispbuilder-sdl-mixer
(asdf:operate 'asdf:load-op :lispbuilder-sdl-mixer)
(asdf:operate 'asdf:load-op :lispbuilder-sdl-mixer-examples)
(SDL-MIXER-EXAMPLES:MIXER)
[Constant]
+channel-post+
Default channel of
-2
used for post-processing.
[Constant]
+channels+
Default number of
8
mixer channels.
[Constant]
+default-channels+
Default number of
2
sound channels for Stereo output.
[Constant]
+default-format+
Default SDL audio format; little-endian is
SDL:AUDIO-S16LSB
, big-endian isSDL:AUDIO-S16MSB
. Audio formats are defined inSDL_audio.h
;
SDL:AUDIO-U8
: Unsigned 8-bit samplesSDL:AUDIO-S8
: Signed 8-bit samplesSDL:AUDIO-U16LSB
: Unsigned 16-bit samples, in little-endian byte orderSDL:AUDIO-S16LSB
: Signed 16-bit samples, in little-endian byte orderSDL:AUDIO-U16MSB
: Unsigned 16-bit samples, in big-endian byte orderSDL:AUDIO-S16MSB
: Signed 16-bit samples, in big-endian byte orderSDL:AUDIO-U16
: same asSDL:AUDIO-U16LSB
(for backwards compatability probably)SDL:AUDIO-S16
: same asSDL:AUDIO-S16LSB
(for backwards compatability probably)SDL:AUDIO-U16SYS
: Unsigned 16-bit samples, in system byte orderSDL:AUDIO-S16SYS
: Signed 16-bit samples, in system byte order
[Constant]
+default-frequency+
Default sampling frequency of
22,050hz
[Constant]
+default-sample-buffer+
Default size of the sample output buffer is
4096
bytes
[Constant]
+max-volume+
Default volume of
128
for CHUNK, output channels and mix channels.
[Function]
allocate-channels num-channels => result
Allocates
NUM-CHANNELS
to be used for mixing samples. Frees all allocated channnels whenNUM-CHANNELS
isNIL
or0
. A negative value forNUM-CHANNELS
is ignored. Returns the number of channels currently allocated. Can be called multiple times even if samples are currently playing. If the current allocation of channels is greater thanNUM-CHANNELS
, then channels greater thanNUM-CHANNELS
will be stopped and these resources freed. The callback set by REGISTER-SAMPLE-FINISHED is called for each channel halted. NOTE: Samples will continue playing whenNUM-CHANNELS
is0
.
[Function]
audio-channels-p => result
Returns the number of output channels used by the audio device, e.g.
2
for stereo and1
for mono. Does not return the number of mixing channels allocated.
[Function]
audio-format-p => result
Returns the current audio format of the audio device.
[Function]
audio-frequency-p => result
Returns the current audio frequency of the audio device.
[Function]
audio-opened-p => result
Returns the number of times the audio device has been opened by OPEN-AUDIO, or
NIL
if the audio device is closed.
[Accessor]
channel-volume channel => result
(setf (channel-volume channel) volume)
Returns the volume of
CHANNEL
, as anINTEGER
. Volume can be from 0 to +MAX-VOLUME+. IfCHANNEL
is NIL then the average volume over all channels is returned.
[Standard class]
chunk
[Function]
close-audio &optional all => result
Attempts to close the audio device. The audio device can be opened multiple times by OPEN-AUDIO and to properly close the audio device, CLOSE-AUDIO should be called the same number of times. Optionally
ALL
whenT
will forcibly close the audio device, no matter how many times the device was opened.
[Generic function]
free chunk => result
[Method]
free (chunk music) => result
Frees the music in MUSIC. Stops MUSIC if currently playing. Will block until any current fade effect completes. Do not reuse MUSIC once freed.
[Method]
free (chunk chunk) => result
Frees the sample in CHUNK. Do not reuse a CHUNK once freed. Do not attempt to free a CHUNK that is still being played.
[Function]
halt-music &optional fade => result
Stops playing music. The callback set by REGISTER-MUSIC-FINISHED is called when the music stops.
Parameters
FADE
is the number of milliseconds to perform the fade-out effect. Will block until any current fade effect completes. Has no effect on paused or halted music. WhenFADE
is NIL the music is stopped and all fade effects are immediately cancelled. The default is NIL.Returns
- T on success and NIL on failure.
[Function]
halt-sample channel &key fade ticks => result
Stops playing the sample on
CHANNEL
. The callback set by REGISTER-SAMPLE-FINISHED is called when the channel stops.Parameters
CHANNEL
specifies the channel to stop playing. WhenT
, will stop playback samples on all channels. Ignores channels not currently playing out samples.FADE
is the number of milliseconds to perform the fade-out effect. The sample is stopped when fade effect completes. WhenFADE
isNIL
or0
the sample is stopped immediately. Default isNIL
.TICKS
is the number of milliseconds until the sample is stopped. WhenNIL
or0
, the sample is stopped immediately. Default isNIL
.Returns
- Returns the number of samples fading out, when
FADE
is set.- Returns the number of samples halted, when
TICKS
is set.- Otherwise, returns T on success and NIL on failure.
[Function]
linked-version => result
Returns the version number of the SDL_mixer dynamic library in use as #(
MAJOR
MINOR
PATCH
).
[Function]
load-music filepath => result
Loads the music file at location
FILEPATH
. Must be aWAVE
,MOD
,MIDI
,OGG
orMP3
file. Returns music as a new MUSIC object, or NIL on error.
[Function]
load-sample filepath => result
Loads the sample file at location
FILEPATH
. Must be aWAVE
,AIFF
,RIFF
,OGG
, orVOC
file. Returns the sample as a new CHUNK object, or NIL on error.
[Standard class]
music
[Function]
music-fading-p => result
Returns the current fade effect on music regardless of the current play or pause state. Returns
:FADING-OUT
if a fade-out is in effect,:FADING-IN
if a fade-in is in effect, orNIL
if no fade is in effect.
[Function]
music-paused-p => result
Returns T if music is currently paused or was previously paused prior to a halt, or NIL otherwise.
[Function]
music-playing-p => result
Returns
T
if music is currently playing or is paused, orNIL
if music is halted.
[Function]
music-position position => result
Sets the play
POSITION
of the currently playing music. ReturnsT
on success andNIL
on failure. Applicable only toMOD
,OGG
andMP3
music formats as described below.
MOD
, jumps to the pattern number in the module identified byPOSITION
.0
will rewind the module to the beginning.OGG
, jumps toPOSITION
seconds from the beginning of the song.MP3
, jumps forwardsPOSITION
seconds from the current play position. Negative values are ignored. To rewind, use REWIND-MUSIC to jump to the start of the song, then jump forwardPOSITION
seconds using MUSIC-POSITION.
[Function]
music-type-of music type => result
Returns
T
if MUSIC is ofTYPE
, returnsNIL
otherwise.TYPE
may be one ofWAV
,MOD
,MID
,OGG
,MP3
,MP3-MAD
,FLAC
orCMD
. If MUSIC isNIL
returns the type of the currently playing music. ReturnsNIL
is no music is playing.
[Function]
music-type-p music => result
Returns the format type of MUSIC as one of
WAV
,MOD
,MID
,OGG
,MP3
,MP3-MAD
,FLAC
orCMD
. Returns the format type of the currently playing music when MUSIC isNIL
. ReturnsNIL
is no music is playing.
[Accessor]
music-volume => result
(setf (music-volume ) volume)
Returns current music volume as an
INTEGER
from 0 to +MAX-VOLUME+.
[Function]
open-audio &key frequency format channels chunksize => result
Initializes the mixer. SDL must be initialized with SDL-INIT-AUDIO prior to this call. OPEN-AUDIO can be called multiple times, however
FORMAT
is set on the first call and will not changed on subsequent calls. The audio device must be closed and re-opened for any change toFORMAT
to take effect. CLOSE-AUDIO must be called the same number of time to close the audio device. Use ALLOCATE-CHANNELS to set the number of mixing channels. OPEN-AUDIO will allocate +MIX-CHANNELS+ by default.Parameters
FREQUENCY
is the output sampling frequency in samples per second (Hz). Default is +DEFAULT-FREQUENCY+. Most games use aFREQUENCY
of +DEFAULT-FREQUENCY+. The higher theFREQUENCY
the greater the CPU resource requirements. (A value of 44100 is the CD audio rate).FORMAT
is the output sample format. Default is +DEFAULT-FORMAT+.CHANNELS
sets the number of sound channels in the output. Default is +DEFAULT-CHANNELS+. This is not the same as ALLOCATE-CHANNELS which sets the number of mixing channels.CHUNKSIZE
is the size in bytes of each mixed sample buffer. Default is +DEFAULT-SAMPLE-BUFFER+ bytes. The smaller theCHUNKSIZE
, the more frequenctly the mixer hooks are called. IncreaseCHUNKSIZE
to decrease CPU resources, if sound skips or if playing music. DecreaseCHUNKSIZE
to decrease sound lag.Returns
T
on success andNIL
on failure.
[Function]
pause-music => result
Pause music. Music can only be paused if it is actively playing. You may halt paused music.
[Function]
play-music music &key loop fade position => result
Starts playing MUSIC from
POSITION
. The music can be faded-in over the number of milliseconds inFADE
. Automatically repeats the music when finished the number of time specified inLOOP
. Any previous music will be halted. Will block until any current fade effect completes.Parameters
MUSIC
is the MUSIC to play.LOOP
is the number of times to play the music. T continuously loops the music. Plays once whenNIL
, or0
. Default isNIL
.FADE
is the number of milliseconds to perform the fade-in effect. Default isNIL
, no fade effect. Only applies to the first loop.POSITION
is the position in the music to begin playing from. Default is to start playout from the beginning.Returns
- T on success and NIL on failure.
[Function]
play-sample chunk &key channel loop fade ticks => result
Plays the sample in CHUNK for
TICKS
milliseconds, repeatedLOOP
times. The sample is repeated the number of times specified inLOOP
, or untilTICKS
. The sample will fade-in overFADE
milliseconds. The callback set by REGISTER-SAMPLE-FINISHED is called when the sample stops playing.Parameters
CHUNK
is the sample CHUNK.CHANNEL
specifies the channel to play the sample. WhenNIL
, will play on the first free unreserved channel. Default isNIL
.LOOP
is the number of times to loop the sample. Loops continuously whenT
. Plays once whenNIL
, or0
. Default inNIL
.FADE
is the number of milliseconds to perform the fade-in effect. Default isNIL
, no fade effect. Only applies to the first loop.TICKS
is the number of milliseconds to play the sample. WhenT
will play the sample from start to finish. Default isT
.Returns
- The channel the sample is playing on, or
NIL
on failure.
[Function]
register-music-finished func => result
Sets the callback that is executed when MUSIC finishes playback or is halted.
FUNC
is of the format#(lambda ())
Example
(REGISTER-MUSIC-FINISHED (lambda () (FORMAT T "MUSIC FINISHED")))
[Function]
register-music-mixer func => result
Sets the callback that is executed to fill the music audio output buffer.
FUNC
is of the format#(lambda (user-data stream len))
Example
(REGISTER-MUSIC-MIXER (lambda (user stream len) 'FILL-THE-AUDIO-OUTPUT-BUFFER))
[Function]
register-sample-finished func => result
Sets the callback that is executed when a sample CHUNK finishes playback or is halted.
FUNC
is of the format#(lambda (channel))
Example
(REGISTER-SAMPLE-FINISHED (lambda (channel) (FORMAT T "SAMPLE FINISHED ON CHANNEL: ~A" channel)))
[Function]
rewind-music => result
Rewind to the start of music. Safe to use on halted, paused, and currently playing music. It is not necessary to rewind the music immediately after starting playback, as it starts at the beginning by default. Only the following streams support rewind:
MOD
,OGG
,MP3
,Native MIDI
.
[Function]
sample-fading-p channel => result
Returns
T
if a fade is in effect for the sample onCHANNEL
, regardless of the current play or pause state of the sample. Returns:FADING-OUT
if a fade-out is in effect,:FADING-IN
if a fade-in is in effect, orNIL
if no fade is in effect.
[Function]
sample-from-channel channel => result
Returns currently playing or most recently played sample on
CHANNEL
as a new CHUNK object, orNIL
ifCHANNEL
is not allocated orCHANNEL
has not yet played out any samples. NOTE: The sample may already have been freed and therefore the pointer to the foreign object in CHUNK may not be valid.
[Function]
sample-paused-p channel => result
Returns
T
if the sample onCHANNEL
is currently paused or was previously paused prior to a halt, orNIL
otherwise. Returns the number of paused samples whenCHANNEL
isT
orNIL
.
[Function]
sample-playing-p channel => result
Returns
T
if a sample is currently playing or is paused onCHANNEL
, orNIL
if the sample is halted. Returns the number of samples playing or paused whenCHANNEL
isT
orNIL
.
[Accessor]
sample-volume chunk => result
(setf (sample-volume chunk) volume)
Returns the volume of the sample in CHUNK, as an
INTEGER
from 0 to +MAX-VOLUME+.
[Function]
sdl-mixer-version sdl-version => result
Sets the
SDL-VERSION
structure with the version of the library..
[Function]
unregister-music-finished => result
Removes the callback function set by set by REGISTER-MUSIC-FINISHED.
[Function]
unregister-music-mixer => result
Removes any callback function set by REGISTER-MUSIC-MIXER.
[Function]
unregister-sample-finished => result
Removes the callback function set by REGISTER-SAMPLE-FINISHED.