AdaFruit Wave Shield Exemples
Erreur de dépassement de pile?
Vous avez une erreur "Stack overflow"?
Tous les exemples ont été testés (et fonctionnent) avec la version 13 (et suivantes).
Si vous rencontrez des problèmes, essayez cette version là (si possible)
Avoir plus de RAM et de Flash!
Note MCHobby: Les plateformes Arduino sont maintenant distribuée avec un ATmega328.
Cette section n'est vraiment pertinente que si vous ne possédez pas d'ATmega328.
Avant d'essayer de jouer de l'audio, vous aurez besoin de faire un peu de place
la mémoire RAM d'Arduino, cela évitera que cela se termine en vilain
dépassement de pile (stack-overflow). Manquer de mémoire RAM est difficile à déboguer et frustrant, d'autant plus si vous disposez d'un ATMega168
Suivez ces instructions (anglais) pour savoir comment avoir plus
de RAM en réduisant la taille de la mémoire tampon de la librairie série (Serial library).
Vous n'aurez pas besoin de faire cela si vous avez un ATmega328.
Notez que la librairie est vraiment grosse (approximativement 10K). Si vous voulez faire beaucoup plus avec Arduino, il est vivement conseillé de faire un Upgrade vers un ATmega328. Ce shield a été développé en prévoyant la disponibilité d'un ATmega328.
Générer de la parole
Si vous désirez une voix humaine dans vos projets, vous povez utiliser le générateur gratuit AT&T Text-to-Speech demo page (Il sais aussi parler en français :-) )
Ce générateur créera des fichier audios 16KHz en 16-bit, ce qui permet de les utiliser directement.
Bibliothèque d'échantillons sonores
Par là, vous trouverez une gigantesque collection d'échantillon sonore sous la licence C.C. Attribution! Beaucoup d'entre eux sont déjà au format mono, 16 ou 22KHz
Lecteur Audio Numérique
Aussi appelé DAP pour Digital audio player.
C'est l'exemple le plus simple. Il joue en boucle chacun des fichiers audio trouvé sur la carte SD. Ce sketch inclus également la librairie.
- Le Sketch (pour la librairie originale AF_Wave)
- Le Sketch (pour la nouvelle librairie waveHC. Vérifiez aussi le zip de la librairie WaveHC au cas où une version plus récente serait disponible).
6 buttons, 6 sounds, multiple possibilities!
Here is a collection of different playback techniques with 6 buttons (connected to analog 0-5)
You can change the # of buttons and what they're wired to easily. This isn't an exhaustive list but will give you some ideas about how you can do a lot with the WaveHC library. Note that all the changes occur in loop(). The button checking and everything else is the same.
- Play the wave file all the way through, and only once
- Play one wave file all the way through, in a loop
- Play all the pressed wave files all the way through, in a loop
- Play the wave file only when the button is held down and only once (kind of like a musical keyboard)
- Play the wave file only when the button is held down and loop it (kind of like a sampler keyboard)
- Play the wave file all the way through and loop it, but allow other buttons to interrupt
- Play the wave file all the way through once, but allow other buttons to interrupt
Playing sound based on input
This example plays 6 different files depending on whether buttons connected to the 6 analog input pins are pressed. (for AF_wave)
This similar example plays 6 different files but its for WaveHC library (theres a walkthrough here)
This one plays 4 different files depending on serial characters, good if you have say an xbee you want to use
Changing the playback rate
By messing with the playback interrupt, [you can change the speed of playback for an interesting effect].
[Here is the sketch], connect the potentiometer to analog pin 0 (or change the code)
Halloween pumpkin
An example of using a sensor to trigger sounds, as well as animating LEDs based on the volume
Volume control via software
By changing the #define DVOLUME 1 in wave.cpp and recompiling you can do rudimentary software volume control as in this sketch