Home icon
Home

PLAY Statement

Purpose:

To play music by embedding a music macro language into the string data type.

Syntax:

PLAY string expression

Comments:

The single-character commands in PLAY are as follows:

A-G [#,+,-]

A-G are notes. # or + following a note produces a sharp; - produces a flat.

Any note followed by #,+,or - must refer to a black key on a piano.

L(n)

Sets the length of each note. L4 is a quarter note, L1 is a whole note, and so on. n may be from 1 to 64.

Length may also follow the note to change the length for that note only. A16 is equivalent to L16A.

MF Music foreground. PLAY and SOUND statements are to run in foreground. That is, each subsequent note or sound is not started until the previous note or sound is finished. This is the initial default.
MBMusic background. PLAY and SOUND statements are to run in background. That is, each note or sound is placed in a buffer allowing the BASIC program to continue execution while music plays in the background. As many as 32 notes (or rests) can be played in background at one time.
MNMusic normal. Each note plays seven-eighths of the time determined by L (length).
MLMusic legato. Each note plays the full period set by L.
MSMusic staccato. Each note plays three-quarters of the time determined by L.
N(n)Play note n. n may range from 0 to 84. In the 7 possible octaves, there are 84 notes. n set to 0 indicates a rest.
O(n)Octave 0 sets the current octave. There are 7 octaves (0 through 6). Default is 4. Middle C is at the beginning of octave 3.
P(n)Pause. P may range from 1-64.
T(n)Tempo. T sets the number of L4s in a minute. n may range from 32-255. Default is 120.
. (period)

A period after a note increases the playing time of the note by 3/2 times the period determined by L (length of note) times T (tempo). Multiple periods can appear after  a note, and the playing time is scaled accordingly. For example, A. will cause the note A to play one and half times the playing time determined by L (length of the note) times T (the tempo); two periods placed after A (A..) will cause the note to be played at 9/4 times its ascribed value; an A with three periods (A...) at 27/8, etc.

Periods may also appear after a P (pause), and increase the pause length as described above.

Xstring;

Executes a substring, where string is a variable assigned to a string of PLAY commands.

Because of the slow clock interrupt rate, some notes do not play at higher tempos; for example, 1.64 at T255. These note/tempo combinations must be determined through experimentation.

>nA greater-than symbol preceding the note n plays the note in the next higher octave.
<nA less-than symbol preceding the note n plays the note in the next lower octave.


Note

Numeric arguments follow the same syntax described under the DRAW  statement.


n as an argument can be a constant, or it can be a variable with = in front of it (= variable). A semicolon is required after the variable and also after the variable in Xstring.