Buzzer (RTTTL)
Introduction
This is at the moment only available in the "test" build, not in normal build. RTTTL (Ring Tone [Text] Transfer Language) was developed by Nokia to play more "easy on the ear" melodies as ringtones for mobile phones. The tunes over all characteristics are created by using three different commands:
- d - duration
- o - octave
- b - tempo (beat)
After that the actual tune is then created using standard notes (a, b, c, d, e, f, and g), before the note the duration is set, after the note the octave is set:
<duration><note><octave>
To compose a jingle you separate the notes with a comma.
Hardware
You can use a buzzer, a speaker or a piezo element to play tones.
The wiring is pretty simple, for the buzzer:
ESP Buzzer GPIO <--> I/O Power 3.3V <--> VCC GND <--> GND
For speaker and piezo element:
ESP Speaker/piezo GPIO <--> Positive (red) GND <--> Negative (black)
ESP Easy
No device is needed, generally you use rules to activate different notifications, or you send commands to activate them. Below you find more information on how to do this.
Melodies and ringtones
From ESP Easy v2.0.0 its possible to play melodies via RTTTL (don't forget to remove the spaces and replace # with -, this might be fixed in future releases):
http://<ESP IP address>/control?cmd=rtttl,14:d=4,o=5,b=112:8a,8a,a,8a,8a,a,8a,8c6,8f.,16g,2a,8a-,8a-,8a-.,16a-,8a-,8a,8a.,16a,8a,8g,8g,8a,g,c6
This plays a melody on pin 14.
You can also use these from rules. We use it to let our alarm system give feedback to the user via a piezo speaker.
To make a boot-sound on startup, create a rule like this:
On System#Boot do rtttl,14:d=10,o=6,b=180,c,e,g endon
A place to find more tunes, all saved as txt files.
Tones
Besides RTTTL it's also possible to play a single tone on a pin, via a buzzer, speaker or piezo element:
http://<ESP IP address>/control?cmd=tone,14,1300,200
Plays a 1300 hz tone for 200 ms on GPIO-14
Commands
Command | GPIO | Value | Extra information |
---|---|---|---|
tone,<gpio>,<value> | 12...16 | <tone>,<duration> | You should try to use GPIO 12...16 since these generally aren't used. The recommended tone range is 20...13000 but you could try tones outside this range. Duration is set in ms. |
rtttl,<gpio>,<value> | 12...16 | d=<duration>,o=<octave>,b=<tempo>,<notes...> | You should try to use GPIO 12...16 since these generally aren't used. |