The following procedure uses the Media Control Interface to play the first track on an audio CD.
TO PLAY.TRACK.1 IGNORE MCI [open cdaudio] MCI [set cdaudio time format tmsf] MCI [play cdaudio from 1 to 2] WAIT 3600 MCI [stop cdaudio] MCI [close cdaudio] END
Let's take a closer look at each instruction in the example above.
The procedure first opens the "cdaudio" device by issuing an
This "open" has nothing to do with physically opening the CD tray, it is required before the cdaudio device will accept any other commands.
Unlike most other commands, the
open command outputs a value on success.
Since Logo programs must do something with every value that is output, we simply IGNORE it.
set command is used to specify the time format as "tmsf", which stands for "track:minute:second:frame".
play command is used to start playing from one time to another.
The track plays asynchornously, which means that FMSLogo doesn't wait for the track to finish playing before running the next instruction.
If you wanted to wait until the track was done before moving on to the next instruction, you could add the
wait flag to the end of the MCI instruction, as in:
MCI [play cdaudio from 1 to 2 wait]
Since we're using TMFS format, the
from numbers are taken to be in tracks.
TMFS values are given in tt:mm:ss:ff format, so if we wanted to play the first fifteen seconds of track 1, we could do that with the following instruction.
MCI [play cdaudio from 1 to 1:00:15]
Also note that it is not necessary to specify an end time for the
If you wanted to play the entire CD, you could do so with:
MCI [play cdaudio from 1]
The WAIT instruction just waits for 60 seconds. This has nothing to do with MCI, it just gives you some time to listen to the CD.
stop command is used to stop the CD from playing.
close command is used to tell the Media Control Interface that you are done with the cdaudio device.