-
Notifications
You must be signed in to change notification settings - Fork 11
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add temporary workshop documentation
- Loading branch information
1 parent
d2f9376
commit c13d1bb
Showing
3 changed files
with
152 additions
and
8 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,140 @@ | ||
import { type Editor } from "../../main"; | ||
import { makeExampleFactory } from "../../Documentation"; | ||
|
||
export const atelier = (application: Editor): string => { | ||
const makeExample = makeExampleFactory(application); | ||
return ` | ||
# Atelier (06 mars 2024) | ||
## Découverte | ||
<br> | ||
${makeExample( | ||
"Percussions", ` | ||
tempo(120) // Changer le tempo | ||
beat(1)::sound('kick').out() | ||
beat(2)::sound('snare').out() | ||
beat(.5)::sound('hh').out() | ||
`, true,)} | ||
- Qu'est-ce qu'il se passe si je change un nombre ? | ||
- Qu'est-ce qu'il se passe si je change un nom ? | ||
- Essayez par exemple <ic>"sid"</ic> ou <ic>"trump"</ic>. | ||
- Qu'est-ce qu'il se passe si j'enlève <ic>.out()</ic> ? | ||
- Est-il possible de jouer un rythme très rapide ou très lent ? | ||
### Ajout d'une basse | ||
<br> | ||
${makeExample( | ||
"Une basse", ` | ||
// Aucun changement dans le code | ||
beat(1)::sound('kick').out() | ||
beat(2)::sound('snare').out() | ||
beat(.5)::sound('hh').out() | ||
// Une nouvelle partie | ||
beat([0.25,0.5].beat(1))::sound("pluck") | ||
.note([40,45].beat(2)).out() | ||
`, true,)} | ||
- Qu'est-ce que le son <ic>"pluck"</ic> ? | ||
- Que signifie <ic>.note([40,45].beat(2))</ic> ? | ||
- Que se passe-t-il si je change la valeur dans <ic>.beat(2)</ic> ? | ||
- Que se passe-t-il lorsque j'ajoute de nouveaux nombres dans <ic>[40, 45]</ic> ? | ||
### Ajout d'une mélodie | ||
<br> | ||
${makeExample( | ||
"Le morceau complet", ` | ||
// Aucun changement dans le code | ||
beat(1)::sound('kick').out() | ||
beat(2)::sound('snare').out() | ||
beat(.5)::sound('hh').out() | ||
beat([0.25,0.5].beat(1))::sound("pluck") | ||
.note([40,45].beat(2)).out() | ||
// Nouvelle partie mélodique | ||
beat([0.25,0.5].beat())::sound("pluck") | ||
.note([0,7,5,8,2,9,0].scale("Major",60).beat(1)) | ||
.vib(8).vibmod(1/4) | ||
.delay(0.5).room(1.5).size(0.5) | ||
.out() | ||
`, true,)} | ||
Ici, on ajoute une nouvelle mélodie mais il s'agit aussi d'un nouvel instrument. C'est pour cela que le code est plus long. Quand on fait du <em>live coding</em>, on code tout en même temps : notes, rythmes, mélodies, sons. C'est beaucoup de choses ! C'est pour cela que le code est court, on essaie de tout taper très vite en jouant ! | ||
- Que signifie selon vous <ic>vib</ic>, <ic>delay</ic>, <ic>room</ic> ou <ic>size</ic> ? | ||
- Que se passe-t-il si je change les valeurs dans <ic>vib</ic>, <ic>delay</ic>, <ic>room</ic> ou <ic>size</ic> ? | ||
**Exercices :** | ||
- Transformer <ic>vib(8)</ic> en <ic>vib([2,4,8].beat(1))</ic>. | ||
- Transformer <ic>"pluck"</ic> en <ic>["pluck", "clap"].beat(1)</ic>. | ||
Vous pouvez aussi utiliser la fonction <ic>rhythm</ic> pour jouer rapidement des rythmes. | ||
${makeExample( | ||
"Rythmes rythmes rythmes", ` | ||
rhythm(0.5, 3, 8)::sound('bd').out() | ||
rhythm(0.5, 3, 8)::sound('clap').out() | ||
rhythm(0.5, 6, 8)::sound('hat').out() | ||
rhythm(0.25, 6, 8)::sound('hat') | ||
.vel(0.3).speed(2).out() | ||
rhythm(0.5, 2, 8)::sound('sd').out() | ||
`, true)}; | ||
## Créer un instrument | ||
<br> | ||
Nous allons créer un nouvel instrument à partir d'un son de base. Voici un premier son : | ||
${makeExample("Notre son de base", `beat(2)::sound('sine').note(50).ad(0, .5).out()`, true)}; | ||
Ce son est assez ennuyeux. Nous allons ajouter quelques paramètres : | ||
${makeExample("Beaucoup mieux !", `beat(2)::sound('sine').note(50).fmi(2).fmh(2).ad(0, .5).out()`, true)}; | ||
Nous allons aussi ajouter quelques effets intéressants : | ||
${makeExample("Ajout d'un écho", `beat(2)::sound('sine').note(50) | ||
.fmi(2).fmh(2).ad(1/16, 1.5) | ||
.delay(0.5).delayt(0.75).out()`, | ||
true)} | ||
Nous pouvons utiliser plusieurs techniques pour rendre le son plus dynamique : | ||
- générer des valeurs aléatoires pour les paramètres | ||
- utiliser des générateurs de valeurs (comme <ic>usine</ic>) | ||
- utiliser la souris ou un autre contrôleur pour changer les valeurs en temps réel | ||
${makeExample("Plus dynamique encore", ` | ||
beat(2)::sound('sine').note([50,55,57,62,66, 69, 74].mouseX()) | ||
.fmi(usine(1/4)).fmh([1,2,0.5].beat()) | ||
.ad(1/16, 1.5).delay(0.5).delayt(0.75) | ||
.out()`, true)} | ||
Un exemple final, le plus complexe jusqu'à présent : | ||
${makeExample("Un instrument de musique complet", ` | ||
beat(2)::sound('triangle') | ||
.note([50,55,57,62,66, 69, 74].mouseX()) | ||
.fmi(usine(1/4)).fmh([1,2,0.5].beat()) | ||
.ad(1/16, 1.5).delay(0.5).delayt(0.75) | ||
.room(0.5).size(8).lpf(usine(1/3)*4000)`, true)} | ||
` | ||
}; | ||
|
||
|