Tutorial 1: Playing Notesđź”—
In FoxDot, all two-character variable names are reserved for player objects, such as p1
Creating a Player Object with no arguments will play a single note on middle C, by default, repeatedly until stopped.
Use >> to give one of these to a player object like so:
To stop an individual player object, simply execute
Besides the 2-character variables that are pre-reserved, you can create your own with your own names
The >> in Python is usually reserved for a type of operation, like + or -, but it is not the case in FoxDot.
If a user re-executes the code, FoxDot will update p1 instead of creating a PlayerObject,
which means you can make changes to your music using just one line of code.
If you now give your player object some arguments, you can change the notes being played back. The first argument should be the degree of the note to be played (default is the lowest note of octave 5 of the major scale) and does not need to be specified by name.
Python, like most programming languages, using zero-indexing when accessing values in an array, which means that 0 refers to the first note of the scale. Give your player object instructions to make music with their Synth. The first argument is the note of the scale to play. The following code plays the first three notes of the default scale (major) on repeat.
For a single note:
Or a list of notes:
But you’ll need to specify whatever else you want to change...
Such as note durations, or the length of each note:
Or amplitude, the "volume" of each note:
If the second list, the amp in this example, is too long, then the first list (the degree) just loops, and are matched with the remaining elements from the second list (the amplitude).
More generally, all the lists are traversed regardless of their length.
Arguments can be integers, floating points, fractions, lists, tuples, or a mix:
p1 >> pluck([0,0,0], dur=2)
p1 >> pluck([0,0,0], dur=1.743)
p1 >> pluck([0,0,0], dur=[0.25,0.5,0.75])
p1 >> pluck([0,0,0], dur=[1/4,1/2,3/4])
p1 >> pluck([0,0,0], dur=[1/4,0.25,3])
Lists of values are iterated over as the Player plays notes
The following duration equates to: 1,2,3,1,4,3
If you don't understand this yet, don't worry, more about patterns in the pattern tutorial
Values in tuples are used simultaneously i.e. p1 will play 3 individual notes, then a chord of 3 together at the same time.
You can also assign values to the attributes of player objects directly
To see all the names of player attributes, just execute
More about those later in the player attributes tutorial
You could store several player instances and assign them at different times:
proxy_1 = pads([0,1,2,3], dur=1/2)
proxy_2 = pads([4,5,6,7], dur=1)
p1 >> proxy_1 # Assign the first to p1
p1 >> proxy_2 # This replaces the instructions being followed by p1
To play multiple sequences at once, just do the same things with another Player object:
Play only this player, muting others:
And turn the solo off:
Stop (not just mute) the other players
Use Ctrl+. to clear everything for the scheduling clock or run: