issue124:python
Différences
Ci-dessous, les différences entre deux révisions de la page.
Les deux révisions précédentesRévision précédenteProchaine révision | Révision précédente | ||
issue124:python [2017/08/28 18:37] – d52fr | issue124:python [2017/08/30 11:42] (Version actuelle) – auntiee | ||
---|---|---|---|
Ligne 3: | Ligne 3: | ||
Michael’s project includes a case, amplifier and speaker, but I’m not going to deal with those, since this is a discussion on using the RPi. I’ll leave those items to you to figure out. I’m using the HDMI audio out and it works just fine, with the exception of being tethered to the monitor by the HDMI cable.** | Michael’s project includes a case, amplifier and speaker, but I’m not going to deal with those, since this is a discussion on using the RPi. I’ll leave those items to you to figure out. I’m using the HDMI audio out and it works just fine, with the exception of being tethered to the monitor by the HDMI cable.** | ||
- | Le mois dernier, je vous ai donné des informations de base sur la bibliothèque GPIOZERO en préparation du programme de boîte à musique qui utilise le RPi, le MCP3008 du mois dernier, trois potentiomètres et un certain nombre d' | + | Le mois dernier, je vous ai donné des informations de base sur la bibliothèque GPIOZERO en préparation du programme de boîte à musique qui utilise le RPi, le MCP3008 du mois dernier, trois potentiomètres et un certain nombre d' |
- | Le projet de Michaël comprend un boîtier, un amplificateur et un haut-parleur, | + | Le projet de Michaël comprend un boîtier, un amplificateur et un haut-parleur, |
**The first thing you need to do is install Fluidsynth from the Add/Remove program on the RPi. Next, you need to add the pyfluidsynth python library. | **The first thing you need to do is install Fluidsynth from the Add/Remove program on the RPi. Next, you need to add the pyfluidsynth python library. | ||
Ligne 15: | Ligne 15: | ||
Hopefully, you still have the MCP3008 Analogue to Digital converter wired up from last month’s potentiometer project. | Hopefully, you still have the MCP3008 Analogue to Digital converter wired up from last month’s potentiometer project. | ||
- | La première chose que vous devez faire est d' | + | La première chose à faire est d' |
pip install pyfluidsynth | pip install pyfluidsynth | ||
Ligne 42: | Ligne 42: | ||
Pour ce projet, vous avez besoin : | Pour ce projet, vous avez besoin : | ||
- | • du Raspberry Pi | + | • du Raspberry Pi, |
- | • d'une plaque d' | + | • d'une plaque d' |
- | • de cavaliers | + | • de cavaliers, |
- | • du MCP3008 | + | • du MCP3008, |
- | • d'une LED | + | • d'une LED, |
- | • d'une résistance de 220 Ω | + | • d'une résistance de 220 Ω, |
- | • de 3 potentiomètres de 10 kΩ | + | • de 3 potentiomètres de 10 kΩ, |
- | • de 9 boutons-poussoirs | + | • de 9 boutons-poussoirs. |
- | Les potentiomètres ont tous une patte reliée à la masse, une au 3,3 Vdc et le curseur connecté aux bornes 1, 2, 3 du MCP3008. Les poussoirs ont tous une sortie branchée à la masse, et les autres connectées aux picots 5, 23, 13, 6, 12, 16, 19, 20 et 21 du GPIO | + | Les potentiomètres ont tous une patte reliée à la masse, une au 3,3 vDC et le curseur connecté aux bornes 1, 2, 3 du MCP3008. Les poussoirs ont tous une sortie branchée à la masse, et les autres connectées aux picots 5, 23, 13, 6, 12, 16, 19, 20 et 21 du GPIO (bornes physiques 29, 16, 33, 31, 32, 36, 35, 38 et 40). La cathode de la LED est connectée à la masse et l' |
- | (bornes physiques 29, 16, 33, 31, 32, 36, 35, 38 et 40) . La cathode de la LED est connectée à la masse et l' | + | |
**The Code | **The Code | ||
Ligne 73: | Ligne 72: | ||
Le code | Le code | ||
- | Le code est assez long ; aussi, je ne vais pas l'inclure ici. Cependant, | + | Le code est assez long ; aussi, je ne vais pas tout inclure ici. Cependant, |
- | Bien sûr, la première chose que fait Michaël, ce sont les imports | + | Bien sûr, la première chose que fait Michaël, ce sont les imports |
from __future__ import division | from __future__ import division | ||
- | from gpiozero import Button, | + | from gpiozero import Button, MCP3008, LED |
- | MCP3008, LED | + | |
import glob | import glob | ||
Ligne 88: | Ligne 86: | ||
import fluidsynth | import fluidsynth | ||
- | La seule bibliothèque qui pourrait ne pas vous être connue est celle de « glob ». Cette bibliothèque vous permet de faire correspondre les noms de fichiers à un modèle. C'est simple mais très puissant. | + | La seule bibliothèque qui pourrait ne pas vous être connue est « glob ». Cette bibliothèque vous permet de faire correspondre les noms de fichiers à un modèle. C'est simple mais très puissant. |
**Next he loads up FluidSynth. | **Next he loads up FluidSynth. | ||
Ligne 123: | Ligne 121: | ||
fs.start(driver=' | fs.start(driver=' | ||
- | Maintenant, voici la section de définition | + | Maintenant, voici la section de définition |
# Paramétrage des poussoirs pour la remise à zéro et l' | # Paramétrage des poussoirs pour la remise à zéro et l' | ||
Ligne 156: | Ligne 154: | ||
# Définition des potentiomètres | # Définition des potentiomètres | ||
- | pot0 = MCP3008(channel=2) # | + | pot0 = MCP3008(channel=2) # Contrôle du volume. |
- | Contrôle du volume | + | |
- | pot1 = MCP3008(channel=1) # | + | pot1 = MCP3008(channel=1) # Sélection de l' |
- | Sélection de l' | + | |
- | pot2 = MCP3008(channel=0) # | + | pot2 = MCP3008(channel=0) # Changement d' |
- | Changement d' | + | |
- | La routine load_soundfonts() (en haut à droite) va traverser | + | La routine load_soundfonts() (en haut à droite) va parcourir |
- | La routine suivante (page précédente, | + | La routine suivante (page précédente, |
- | Voici là où Michaël paramètre les actions pour chacun des poussoirs musicaux. De base, il y a les actions « when-pressed | + | C'est ici que Michaël paramètre les actions pour chacun des poussoirs musicaux. De base, il y a les actions « when_pressed |
**# Assign actions to when_pressed for each button | **# Assign actions to when_pressed for each button | ||
Ligne 206: | Ligne 201: | ||
pinky_finger.when_released = pinky_finger_stop | pinky_finger.when_released = pinky_finger_stop | ||
- | En examinant ce que fait la routine d' | + | En examinant ce que fait la routine d' |
**The way things work on a synth is that when a note key is pressed a noteon event is called and when it is released, a noteoff event is then called. | **The way things work on a synth is that when a note key is pressed a noteon event is called and when it is released, a noteoff event is then called. | ||
Ligne 212: | Ligne 207: | ||
In the following lines, Michael sets the note definitions for each button.** | In the following lines, Michael sets the note definitions for each button.** | ||
- | La façon dont les choses fonctionnent sur un synthétiseur est que, quand une touche | + | La façon dont les choses fonctionnent sur un synthétiseur est que, quand on appuie sur une touche, un événement noteon est appelé et quand elle est relâchée, un événement noteoff est appelé. (C'est pourquoi, parfois, quand vous écoutez un fichier midi sur un ordinateur, vous avez des notes qui semblent être accidentellement en appui permanent, les laissant jouer sans fin. L' |
Dans les lignes suivantes, Michaël définit la note de chaque poussoir. | Dans les lignes suivantes, Michaël définit la note de chaque poussoir. | ||
Ligne 239: | Ligne 234: | ||
- | Je pense que ceci vous donne une compréhension de base de ce que fais le code ; aussi, vous pouvez poursuivre et jouer avec le projet. | + | Je pense que ceci vous donne une compréhension de base de ce que fait le code ; aussi, vous pouvez poursuivre et jouer avec le projet. |
- | + | ||
- | Une fois encore, merci à Michaël pour ce projet. | + | |
- | + | ||
- | Jusqu' | + | |
- | + | ||
- | Python dans le monde réel | + | |
- | + | ||
- | Le mois dernier, je vous ai donné des informations de base sur la bibliothèque GPIOZERO en préparation du programme de boîte à musique qui utilise le RPi, le MCP3008 du mois dernier, trois potentiomètres et un certain nombre d' | + | |
- | + | ||
- | + | ||
- | Le projet de Michaël comprend un boîtier, un amplificateur et un haut-parleur, | + | |
- | + | ||
- | La première chose que vous devez faire est d' | + | |
- | + | ||
- | pip install pyfluidsynth | + | |
- | + | ||
- | Je pars du principe que vous avez installé la bibliothèque GPIOZERO le mois dernier. | + | |
- | + | ||
- | J' | + | |
- | + | ||
- | Liste de pièces | + | |
- | + | ||
- | Pour ce projet, vous avez besoin : | + | |
- | + | ||
- | • du Raspberry Pi | + | |
- | • d'une plaque d' | + | |
- | • de cavaliers | + | |
- | • du MCP3008 | + | |
- | • d'une LED | + | |
- | • d'une résistance de 220 Ω | + | |
- | • de 3 potentiomètres de 10 kΩ | + | |
- | • de 9 boutons-poussoirs | + | |
- | + | ||
- | Les potentiomètres ont tous une patte reliée à la masse, une au 3,3 Vdc et le curseur connecté aux bornes 1, 2, 3 du MCP3008. Les poussoirs ont tous une sortie branchée à la masse, et les autres connectées aux picots 5, 23, 13, 6, 12, 16, 19, 20 et 21 du GPIO | + | |
- | | + | |
- | + | ||
- | Le code | + | |
- | + | ||
- | Le code est assez long ; aussi, je ne vais pas l' | + | |
- | + | ||
- | Bien sûr, la première chose que fait Michaël, ce sont les imports ... | + | |
- | + | ||
- | from __future__ import division | + | |
- | + | ||
- | from gpiozero import Button, | + | |
- | MCP3008, LED | + | |
- | + | ||
- | import glob | + | |
- | import os | + | |
- | import re | + | |
- | import time | + | |
- | import fluidsynth | + | |
- | + | ||
- | La seule bibliothèque qui pourrait ne pas vous être connue est celle de « glob ». Cette bibliothèque vous permet de faire correspondre les noms de fichiers à un modèle. C'est simple mais très puissant. | + | |
- | + | ||
- | Ensuite, il charge FluidSynth. | + | |
- | + | ||
- | # Démarrage de Synth et chargement de la police sonore | + | |
- | + | ||
- | fs = fluidsynth.Synth() | + | |
- | fs.start(driver=' | + | |
- | + | ||
- | Maintenant, voici la section de définition du poussoir. | + | |
- | Souvenez-vous que les numéros de picots correspondent aux picots du GPIO, et pas aux numéros des picots physiques. | + | |
- | + | ||
- | # Paramétrage des poussoirs pour la remise à zéro et l' | + | |
- | + | ||
- | button_reset = Button(5) | + | |
- | button_shutdown = Button(23) | + | |
- | + | ||
- | # Paramétrage des poussoirs du clavier | + | |
- | + | ||
- | thumb_bottom = Button(13) | + | |
- | thumb_top = Button(6) | + | |
- | thumb_right = Button(12) | + | |
- | index_finger = Button(16) | + | |
- | middle_finger = Button(19) | + | |
- | ring_finger = Button(20) | + | |
- | pinky_finger = Button(21) | + | |
- | + | ||
- | Maintenant, il définit quel potentiomètre est actif sur quel canal du MCP3008. (J'ai ajouté les commentaires de cette partie.) | + | |
- | + | ||
- | # Définition des potentiomètres | + | |
- | + | ||
- | pot0 = MCP3008(channel=2) # | + | |
- | Contrôle du volume | + | |
- | + | ||
- | pot1 = MCP3008(channel=1) # | + | |
- | Sélection de l' | + | |
- | + | ||
- | pot2 = MCP3008(channel=0) # | + | |
- | Changement d' | + | |
- | + | ||
- | La routine load_soundfonts() (en haut à droite) va traverser la bibliothèque soundfonts, en récupérant les noms des fichiers de polices sonores dans un liste utilisable. Les fichiers source de Michaël comprennent 15 échantillons de polices sonores. | + | |
- | + | ||
- | La routine suivante (page précédente, | + | |
- | + | ||
- | Voici là où Michaël paramètre les actions pour chacun des poussoirs musicaux. De base, il y a les actions « when-pressed » (si appuyé) et « when-released » (si relâché) qui appellent une routine quand l' | + | |
- | + | ||
- | # Assignation des actions quand un des poussoirs est appuyé | + | |
- | + | ||
- | thumb_bottom.when_pressed = thumb_bottom_start | + | |
- | thumb_bottom.when_released = thumb_bottom_stop | + | |
- | thumb_right.when_pressed = thumb_right_start | + | |
- | thumb_right.when_released = thumb_right_stop | + | |
- | thumb_top.when_pressed = thumb_top_start | + | |
- | thumb_top.when_released = thumb_top_stop | + | |
- | index_finger.when_pressed = index_finger_start | + | |
- | index_finger.when_released = index_finger_stop | + | |
- | middle_finger.when_pressed = middle_finger_start | + | |
- | middle_finger.when_released = middle_finger_stop | + | |
- | ring_finger.when_pressed = ring_finger_start | + | |
- | ring_finger.when_released =ring_finger_stop | + | |
- | pinky_finger.when_pressed = pinky_finger_start | + | |
- | pinky_finger.when_released = pinky_finger_stop | + | |
- | + | ||
- | En examinant ce que fait la routine d' | + | |
- | + | ||
- | La façon dont les choses fonctionnent sur un synthétiseur est que, quand une touche est appuyée, un événement noteon est appelé et quand elle est relâchée, un événement noteoff est appelé. (c'est pourquoi, parfois, quand vous écoutez un fichier midi sur un ordinateur, vous avez des notes qui semblent être accidentellement en appui permanent, les laissant | + | |
- | + | ||
- | Dans les lignes suivantes, Michaël définit la note de chaque poussoir. | + | |
- | + | ||
- | thumb_bottom_note = 54 | + | |
- | thumb_right_note = 56 | + | |
- | thumb_top_note = 58 | + | |
- | index_finger_note = 60 | + | |
- | middle_finger_note = 62 | + | |
- | ring_finger_note = 64 | + | |
- | pinky_finger_note = 66 | + | |
- | + | ||
- | + | ||
- | Je pense que ceci vous donne une compréhension de base de ce que fais le code ; aussi, vous pouvez poursuivre et jouer avec le projet. | + | |
- | Une fois encore, merci à Michaël pour ce projet. | + | Une fois encore, |
Jusqu' | Jusqu' |
issue124/python.1503938238.txt.gz · Dernière modification : 2017/08/28 18:37 de d52fr