Update: The reader Andreas Schröder has changed the project a little and supplemented some functions. You can find the text and sketch at the end of the post.
Many radio stations can be heard as a MP3 stream over the Internet. Since the microcontroller ESP32 has WLAN skills on the one hand and, on the other hand, can convert the digital data stream into an analog signal with two built-in digital/analog converters, it offers itself as an ideal solution. In addition, a battery power supply, an audio amplifier, two speakers, a display for the transmitter display and an input device for the transmitter setting is required. The whole thing is rounded off with a housing from the 3D printer.
Required hardware
Number | Component | annotation |
---|---|---|
1 |
|
|
1 |
|
|
1 |
|
|
2 |
Resistance 4.7 KOHM |
|
2 |
Resistance 22 KOHM |
|
1 |
Resistance 10 kohm |
|
1 |
Elko 1000UF / 10V |
|
1 |
|
|
1 |
|
|
1 |
|
|
1 |
|
|
1 |
|
|
1 |
|
|
2 |
Spring strips 19-pin |
|
1 |
Park bar 3-pin |
|
1 |
Park bar 4-pin |
|
1 |
Pin bar 5-pin |
|
2 |
Turntons for 6mm axis |
|
Several |
Jumper cable female too female |
|
1 |
|
|
1 |
|
|
1 |
|
|
various |
|
circuit
Important!
If the Rotary Encoder is not used, the PIN 34 of the ESP32 must still be connected to the 10 co-cock resistance with 3.3V.
The ESP32 is built up on a 50x70 mm hole grid plate with the resistances and pen strips for the periphery.
The figure shows the assembly and wiring on the underside
wiring
First of all, the loader's battery connection is connected to the input of the DC-DC Step Up converter. Note the polarity! The battery is also soldered via a suitable connector with the battery input of the loader. Now the output voltage of the converter with the blue potentiometer should be set to approx. 5.2 V. To do this, either a battery must be connected or the loader's USB input must be connected to a USB network.
If the voltage is set, the output of the converter can be connected to the supply receipt of the audio amplifier. There are two soldering points on the back of the amplifier, the plus connection is switched over the switch of the volume potentiometer.
This connection is used to supply the ESP32 and the display so that the device can be switched off completely via the potentiometer.
Now the connections to the control board can be made on the hole grid plate. It is best to use jumper wires with two female plugs. You need a 3-pin connection from the audio output to the amplifier, a 4-pin to the display and a 5-pin to the Rotary Encoder.
Important NOTE!
The loudspeakers should not be attached or staked out when switched on, since inductive tension peaks could destroy the amplifier outputs.
If the housing presented in the blog post is used, battery, loader, DC/DC converter and the control board come to the baking tarpaulin. The speakers, the amplifier, the Rotary Encoder and the display come to the front tarpaulin. The lid is used to secure the battery.
software
In order for the sketch to be compiled, the Arduino IDE must be prepared accordingly. By default, Arduino IDE supports a large number of boards with different microcontrollers, but not the ESP32. So that you can create and upload programs for these controllers, a software package for the support must therefore be installed.
First you have to communicate the Arduino IDE where you can find the additional data required. To do this, open the Preferences in the File menu. In the preset window there is the input field called "Additional board administrator URLS". If you click on the icon to the right of the input field, a window in which you can open the URL https://dl.espressif.com/dl/package_esp32_index.json for the ESP32 can enter. Version 2.0.0 or higher of the ESP32 package should not be used for this project, since these versions have problems related to the ESP8266audio library!
Now choose the board management in the Arduino IDE under tool → board.
A window opens in which all available packages are listed. In order to narrow down the list, you enter "ESP32" in the search field. Then you only get an entry in the list. Install the "ESP32" package.
For the display you need a library that can be installed via the Arduino library management. This is the library "Liquidcrystal I2C".
Another library is required for the Rotary Encoder. Her name is "Aiesp32rotary Coder".
The core of this project is the library "ESP8266audio".
This library enables various digital input currents to be read, decoding and reproducing them using various output channels. As an entrance, the program memory, the internal RAM can be used by an SD card, an HTTP stream or an ICY stream. The icy stream is typically used by internet radios.
WAV, MOD, MIDI, Flac, AAC and MP3 files can be decoded. MP3 is required for the web radio. The output can finally be made in memory, files or I2S. There is a special feature for the ESP32. The I2S Output can be output on the internal digital analog converter. An analog stereo signal is then available at the output pins of the DAW (PIN 25 and PIN 26). This feature is used in the present project.
If all libraries are installed, the sketch can be compiled and uploaded to the hardware.
The sketch
#include <Wifi.H> // Includes from ESP8266audio #include "AudioFileesourceiSstream.h" // input stream #include "AudioFileesourcebuffer.h" // input buffer #include "Audiogeneratormp3.h" //decoder #include "AudioOutPuti2s.h" // output stream // Library for LCD display #include <Liquidcrystal_i2c.H> // Library for Rotary Encoder #include "AiesP32rotaryScoder.h" // ESP32 Library to Save Preferences in Flash #include <Preferences.H> // WLAN Access Fill with your credentials #define SSID "************" #define PSK "*************" // Used pins for Rotary Encoder #define Rotary_encoder_a_pin 33 #define Rotary_encoder_b_pin 32 #define Rotary_encoder_Button_pin 34 #define Rotary_encoder_vcc_pin -1 /* 27 PUT -1 of Rotary Encoder VCC IS Connected Directly to 3.3V; Else you can use declared output pin for powering rotary encoder */ // Depending on Your Encoder - Try 1.2 OR 4 TO GET Expected Behavior //#define rotary_encoder_steps 1 //#define rotary_encoder_steps 2 #define Rotary_encoder_steps 4 // Structure for Station List type struct { char * url; // stream url char * Surname; // station name } station; #define Ward 24 // Number of Stations in Tzhe List // Station List Can Easily Be Modified to Support Other Stations station wardlist[Ward] Progmem = { {"http://icecast.ndr.de/ndr/ndr2/niedersachsen/mp3/128/stream.mp3","NDR2 Lower Saxony"}, {"http://icecast.ndr.de/ndr/ndr1niedersachsen/hannover/mp3/128/stream.mp3","NDR1 Hannover"}, {"http://wdr-1live-live.iceCast.wdr.de/wdr/1live/live/mp3/128/stream.mp3","WDR1"}, {"http://wdr-cosmo-live.iceCast.wdr.de/wdr/cosmo/live/mp3/128/stream.mp3","WDR Cosmo"}, {"http://radiohagen.cast.addradio.de/radiohagen/simulcast/high/stream.mp3","Radio Hagen"}, {"http://st01.sslstream.dlf.de/dlf/01/128/mp3/stream.mp3","Deutschlandfunk"}, {"http://dispatcher.rndfnk.com/br/br1/franken/mp3/low","Bayern1"}, {"http://dispatcher.rndfnk.com/br3/live/mp3/low","Bayern 3"}, {"http://dispatcher.rndfnk.com/hr/hr3/live/mp3/48/stream.mp3","Hessen3"}, {"http://stream.antentne.de/antne","Antenne Bayern"}, {"http://stream.1a-webradio.de/saw-deutsch/","Radio 1a German hits"}, {"http://stream.1a-weibradio.de/saw-rock/","Radio 1a Rock"}, {"http://streams.80s80s.de/ndw/mp3-192/streams.80S80S.de/","Neue Deutsche Welle"}, {"http://dispatcher.rndfnk.com/br/brklassik/live/mp3/low","Bavaria Classic"}, {"http://mdr-284280-1.Cast.mdr.de/MDR/284280/1/mp3/low/Stream.mp3","MDR"}, {"http://icecast.ndr.de/ndr/njoy/live/mp3/128/stream.mp3","N-Joy"}, {"http://dispatcher.rndfnk.com/rbb/rbb888/live/mp3/mid","RBB"}, {"http://dispatcher.rndfnk.com/rbb/antnebrandenburg/live/mp3/mid","Antenne Brandenburg"}, {"http://wdr3-live.iceCasttssl.wdr.de/wdr/wdr3/live/mp3/128/stream.mp3","WDR3"}, {"http://wdr2-aachenundregion.iceCasttssl.wdr.de/wdr2/aachenundregion/mp3/128/stream.mp3","WDR 2"}, {"http://rnrw.cast.addradio.de/rnrw-0182/deinschlager/low/Stream.mp3","NRW Schlagerradio"}, {"http://rnrw.cast.addradio.de/rnrw-0182/deinrock/low/stream.mp3","NRW Rockradio"}, {"http://rnrw.cast.addradio.de/rnrw-0182/dein90er/low/stream.mp3","NRW 90s"}, {"http://mp3.hitradiort1.c.nmdn.net/rt1rockwl/livestream.mp3","RT1 Rock"}}; // Buffer size for stream buffering const intimately Preallocatebuffersize = 80*1024; const intimately PreallocateCodecsize = 29192; // MP3 Codec Max Mem Needed // pointer to preallocated memory void *Preallocatebuffer = ZERO; void *PreallocateCodec = ZERO; // Instance of Preferences Preferences Pref; // Instance for Rotary Encoder AISP32Rotary code rotary = AISP32Rotary code(Rotary_encoder_a_pin, Rotary_encoder_b_pin, Rotary_encoder_Button_pin, Rotary_encoder_vcc_pin, Rotary_encoder_steps); // Instance for LCD display Liquidcrystal_i2c LCD(0x27,16,2); // Set the lcd address to 0x27 for a 16 chars and 2 line display // Instance for Audio Components Audio *decoder = ZERO; Audio filesourceistream *file = ZERO; Audio filesource buffer *buff = ZERO; Audiooutputi2s *out; // Special character to Show a Speaker Icon for Current Station uint8_t speaker[8] = {0x3,0x5,0x19,0x11,0x19,0x5,0x3}; // global variables uint8_t curing = 0; // Index for current selected station in station list uint8_t act = 0; // Index for current station in station list used for streaming uint32_t liability = 0; // Time of Last Selection Change // Callback function wants to be called If Meta Data Were Found in Input Stream void MDCallback(void *cbdata, const char *type, Bool isunicode, const char *string) { const char *PTR = Reinterpret_Cast<const char *>(cbdata); (void) isunicode; // Punt this ball for Now // note that the type and string may be in progmem, so copy them to ram for printf char S1[32], s2[64]; strncpy_p(S1, type, Sizeof(S1)); S1[Sizeof(S1)-1]=0; strncpy_p(s2, string, Sizeof(s2)); s2[Sizeof(s2)-1]=0; Serial.printf("Metadata (%s) '%s' = '%s' \ n", PTR, S1, s2); Serial.flush(); } // stop playing the input stream release memory, delete instantences void stop playing() { IF (decoder) { decoder->Stop(); delete decoder; decoder = ZERO; } IF (buff) { buff->close(); delete buff; buff = ZERO; } IF (file) { file->close(); delete file; file = ZERO; } } //start playing a stream from current active station void startUrl() { stopPlaying(); //first close existing streams //open input file for selected url Serial.printf("Active station %s\n",stationlist[actStation].url); file = new AudioFileSourceICYStream(stationlist[actStation].url); //register callback for meta data file->RegisterMetadataCB(MDCallback, NULL); //create a new buffer which uses the preallocated memory buff = new AudioFileSourceBuffer(file, preallocateBuffer, preallocateBufferSize); Serial.printf_P(PSTR("sourcebuffer created - Free mem=%d\n"), ESP.getFreeHeap()); //create and start a new decoder decoder = (AudioGenerator*) new AudioGeneratorMP3(preallocateCodec, preallocateCodecSize); Serial.printf_P(PSTR("created decoder\n")); Serial.printf_P("Decoder start...\n"); decoder->begin(buff, out); } //show name of current station on LCD display //show the speaker symbol in front if current station = active station void showStation() { lcd.clear(); if (curStation == actStation) { lcd.home(); lcd.print(char(1)); } lcd.setCursor(2,0); String name = String(stationlist[curStation].name); if (name.length() < 15) lcd.print(name); else { uint8_t p = name.lastIndexOf(" ",15); //if name does not fit, split line on space lcd.print(name.substring(0,p)); lcd.setCursor(0,1); lcd.print(name.substring(p+1,p+17)); } } //handle events from rotary encoder void rotary_loop() { //dont do anything unless value changed if (rotaryEncoder.encoderChanged()) { uint16_t v = rotaryEncoder.readEncoder(); Serial.printf("Station: %i\n",v); //set new currtent station and show its name if (v < STATIONS) { curStation = v; showStation(); lastchange = millis(); } } //if no change happened within 10s set active station as current station if ((lastchange > 0) && ((millis()-lastchange) > 10000)){ curStation = actStation; lastchange = 0; showStation(); } //react on rotary encoder switch if (rotaryEncoder.isEncoderButtonClicked()) { //set current station as active station and start streaming actStation = curStation; Serial.printf("Active station %s\n",stationlist[actStation].name); pref.putUShort("station",curStation); startUrl(); //call show station to display the speaker symbol showStation(); } } //interrupt handling for rotary encoder void IRAM_ATTR readEncoderISR() { rotaryEncoder.readEncoder_ISR(); } //setup void setup() { Serial.begin(115200); delay(1000); //reserve buffer für for decoder and stream preallocateBuffer = malloc(preallocateBufferSize); // Stream-file-buffer preallocateCodec = malloc(preallocateCodecSize); // Decoder- buffer if (!preallocateBuffer || !preallocateCodec) { Serial.printf_P(PSTR("FATAL ERROR: Unable to preallocate %d bytes for app\n"), preallocateBufferSize+preallocateCodecSize); while(1){ yield(); // Infinite halt } } //start rotary encoder instance rotaryEncoder.begin(); rotaryEncoder.setup(readEncoderISR); rotaryEncoder.setBoundaries(0, STATIONS, true); //minValue, maxValue, circleValues true|false (when max go to min and vice versa) rotaryEncoder.disableAcceleration(); //init WiFi Serial.println("Connecting to WiFi"); WiFi.disconnect(); WiFi.softAPdisconnect(true); WiFi.mode(WIFI_STA); WiFi.begin(SSID, PSK); // Try forever while (WiFi.status() != WL_CONNECTED) { Serial.println("...Connecting to WiFi"); delay(1000); } Serial.println("Connected"); //create I2S output do use with decoder //the second parameter 1 means use the internal DAC out = new AudioOutputI2S(0,1); //init the LCD display lcd.init(); lcd.backlight(); lcd.createChar(1, speaker); //set current station to 0 curStation = 0; //start preferences instance pref.begin("radio", false); // Set Current Station to Saved Value IF Available IF (Pref.Iskey("station")) curing = Pref.gut("station"); IF (curing >= Ward) curing = 0; // Set Active Station to Current Station // Show on display and start streaming act = curing; show station(); starturl(); } void loop() { // check if stream has ended Normally not on icy streams IF (decoder->Isrunning()) { IF (!decoder->loop()) { decoder->Stop(); } } Else { Serial.printf("MP3 Done \ n"); // Restart ESP when streaming is done or errored delay(10000); ESP.remaining start(); } // Read events from Rotary Encoder rotary_loop(); }
Before compiling, the SSID and the password must be set for the WLAN. At the beginning of the sketch is a list of 24 German radio stations. You can edit or expand them as you like to hear your desired program. A maximum of 100 stations can be defined.
After uploading, the program can be started. The channel list can be scrolled with the Rotary Encoder. If you press the button of the Rotary Encoder, the station that has just been displayed is set as active. This selection is saved in the flash, so that after a power break, the program is started again with the selected transmitter. The station that has just been reproduced is displayed on the display by a preceding loudspeaker symbol.
Have fun with the internet radio
Update from our reader Andreas Schröder
(thanks at this point)
With a cut black film on white housing, it looks really good.
Because this is not tingling and screwing up, I expanded the code to include the following:
1. An automatic AP mode with a lack of WLAN connection, which then queries the access data via web server.
2. In normal operation, the transmitter list can be maintained via a web front end. Would like to have provided the code, screenshots and the plotter file for the film here.
The WLAN configuration is held in the internal flash memory. This can be configured using the web interface. The configuration process is as follows:
-
Charge the saved login data
-
Attempt to make connections (display shows "WLAN")
-
If that is not possible
-
Change to AP mode and create the WLAN "WebRadio"
-
Expect the data entry under http://192.168.4.1
-
Restart with new data
-
==> The whole thing is repeated until a connection is possible
Transmitter list
The list of stored transmitters can above http: // be adjusted.
296 commentaires
EhrwuerdigerJorge
Halli,
esp32 1.0.6 Boardverwalter esp8266audio 1.9.5 Bibliotheken verwaltengerade aufgebaut und funktioniert mit Schroeders neuem Code. Im Text ist wenn auch kurz beschrieben, dass die esp8266audio Bibliothek sehr wählerisch und empfindlich ist.
Bei mir lief nach wenigen Versuchen:
LiquidCrystal sollte nur eine Warnung generieren, aber keine Fehler (in der aktuellsten Version).
Der ständige Neustart ist imho meist ein Softwareproblem mit esp8266audio
LG
J
Karl-Heinz Schumacher
Auch ich habe ständiges rebooten nach dem ich im Webserver die richtige WLAnverbindung eingetragen habe.
hier der ErrorCOde
19:29:24.251 → Rebooting…
19:29:24.251 → ets Jun 8 2016 00:22:57
19:29:24.251 →
19:29:24.251 → rst:0xc (SW_CPU_RESET),boot:0×13 (SPI_FAST_FLASH_BOOT)
19:29:24.251 → configsip: 0, SPIWP:0xee
19:29:24.251 → clk_drv:0×00,q_drv:0×00,d_drv:0×00,cs0_drv:0×00,hd_drv:0×00,wp_drv:0×00
19:29:24.251 → mode:DIO, clock div:1
19:29:24.251 → load:0×3fff0030,len:1184
19:29:24.251 → load:0×40078000,len:13260
19:29:24.251 → load:0×40080400,len:3028
19:29:24.251 → entry 0×400805e4
19:29:26.764 → Connecting to WiFi
19:29:27.004 → ESP-Webradio
19:29:27.004 → meinWlan
19:29:27.164 → Verbinde mit WiFi …..IP-Adresse per DHCP ist meine IP
19:29:30.164 → Connected
19:29:30.164 → Webserver ist gestartet
19:29:30.204 → Active station http://icecast.ndr.de/ndr/ndr2/niedersachsen/mp3/128/stream.mp3
19:29:30.324 → sourcebuffer created – Free mem=67528
19:29:30.364 → created decoder
19:29:30.364 → Decoder start…
19:29:31.084 → Guru Meditation Error: Core 1 panic’ed (LoadProhibited). Exception was unhandled.
19:29:31.084 →
19:29:31.084 → Core 1 register dump:
19:29:31.084 → PC : 0×4008ae4d PS : 0×00060b30 A0 : 0×80157dec A1 : 0×3ffcbb70
19:29:31.084 → A2 : 0×00000000 A3 : 0xfffffffc A4 : 0×000000ff A5 : 0×0000ff00
19:29:31.124 → A6 : 0×00ff0000 A7 : 0xff000000 A8 : 0×00000000 A9 : 0×3ffcbf70
19:29:31.124 → A10 : 0×3ffc55dc A11 : 0×0000059c A12 : 0×0000001c A13 : 0×00000002
19:29:31.124 → A14 : 0×00000000 A15 : 0×00000000 SAR : 0×00000018 EXCCAUSE: 0×0000001c
19:29:31.124 → EXCVADDR: 0×00000000 LBEG : 0×4008ae4d LEND : 0×4008ae5d LCOUNT : 0xffffffff
19:29:31.124 →
19:29:31.124 →
19:29:31.124 → Backtrace: 0×4008ae4a:0×3ffcbb70 0×40157de9:0×3ffcbb80 0×4015c982:0×3ffcbe90 0×4015c9be:0×3ffcbf20 0×400e7e62:0×3ffcbf60 0×400d48c3:0×3ffcc000 0×400d5604:0×3ffcc090 0×400d4e5e:0×3ffcc1e0 0×400d4d65:0×3ffcc200 0×40165306:0×3ffcc220 0×400d5c6a:0×3ffcc240 0×400d3603:0×3ffcc260 0×400d3897:0×3ffcc280 0×400e8f15:0×3ffcc2a0
19:29:31.164 →
19:29:31.164 →
19:29:31.164 →
19:29:31.164 →
19:29:31.164 → ELF file SHA256: a531a13bebf1dadf
Hat da jemand ne Lösung?
Gerald Lechner
@Michael-S: Mit folgenden URLs funktionieren SWR1 und SWR3
http://liveradio.swr.de/sw282p3/swr1rp/
https://liveradio.swr.de/sw282p3/swr3/
Reimund
Läuft das bei einem ? Bekomme diesen Mist nicht ans laufen.
Habe extra alle Sachen neu gekauft.
Comapli und hochgeladen.
Keine Ausgabe auf dem LCD…. Seriell Monitor nur Fehlermeldungen.
u.a.
psram: PSRAM ID read error: 0xffffffff
Michael
… hab noch ein wenig rumprobiert. Der Code hat leider einige Einschränkungen.
- .m3u Playlisten funktionieren nicht
- https:// funktioniert (scheinbar) nicht. Kann man oft durch http:// ersetzen.
- der erste Eintrag in der Stationsliste wird sofort beim Einschalten abgespielt, bzw. der letzte gespeicherte Sender. Wenn der nicht funktioniert, dann crasht das Programm.
Nachdem ich die obigen Punkte beherzigt habe, läuft das Programm nun sehr gut.
Reimund
Habe das Update installiert.
Ap Modus. Gebe dann SSID und Passwort ein.
Er bekommt von der Fritzbox eine IP Adresse.
Laut ser. Monitor wird die Verbindung aufgebaut. Station wird gefunden. Danach Disconnect und wieder neu.
Verbindung bleibt nie stabil.
Wie kann man das verhindern ?
Gerhard Kündig
Das Geschäftsmodell von az-Delivery finde ich sehr gut. Hier werden sehr tolle Projekte vorgestellt und auch dokumentiert. Wenn man aber zeitlich später etwas realisieren will, funktioniert bei einigen Projekten offenbar das kompilieren der Sketch’s nicht mehr immer, da verschiedene Libraries oder Board-Dateien nicht mehr kompatibel sind. Man sollte sich bei az-Delivery überlegen, ab man nicht fertige .bin-Dateien in einem Archiv anbieten will, so dass man das auch ein- zwei Jahre später noch aufbauen kann. Ansonsten staut sich beim Erbauer nach stundenlangem pröbeln einen erheblichen Frust auf, was für euch sicher nicht vorteilhaft ist.
Gerhard
Christian Zirlewagen
Bei mir funktioniert es mit esp32 Espressif Systems Version 2.0.11
Zunächst war es ein Hardwareproblem mit dem 10kOhm Widerstand zwischen 3,3V und Pin 34 des Rotary – einfach eine Lötbrücke vergessen. 3D Druck hat gut funktioniert dank der stl Dateien.
Vielen Dank für das schöne Projekt – wird nun in der Jugendgruppe nachgebaut!
Michael
Hallo zsuammen.
habe auch ein paar Stunden gekämpft, bis es auf einem ESP32 Lyrat4.3 einigermaßen lief. Ich denke, der RAM-Bereich für den Codec ist zu klein. Seit ich den vergrößert habe läuft es viel besser (auch, insbesondere AAC).
Habe
“const int preallocateCodecSize = 29192;”
geändert in
“const int preallocateCodecSize = 85332; // AAC+SBR codec max mem needed”
Siehe https://github.com/earlephilhower/ESP8266Audio/issues/622
Viele Grüße
Martin van Doorn
Danke für dieses Projekt, sieht sehr schön aus und ich würde es gerne nachbauen.
Aber zuerst habe ich versucht, den Code zu kompilieren.
Dabei bin ich auf mehrere Probleme gestoßen.
Type benennt keinen Typ
Station benennt keinen Typ
WEBradio_ESP32_AZ_Dilevry:29:3: Fehler: ‘type’ benennt keinen Typ
type struct {char * url;
^
WEBradio_ESP32_AZ_Dilevry:31:17: error: ‘station’ benennt keinen Typ
} station;
^
WEBradio_ESP32_AZ_Dilevry:36:1: Fehler: ‘station’ benennt keinen Typ
station wardlist[Ward] Progmem = {
^
Exit-Status 1
‘type’ benennt keinen Typ
Kann mir jemand weiterhelfen?
Vielen Dank im Voraus
Übersetzt mit DeepL.com (kostenlose Version)
Martin van Doorn
Hello, Very nice project and love to build, but first I tried the code:
Run in multiple problem.
Somebody to help?
WEBradio_ESP32_AZ_Dilevry:29:3: error: ‘type’ does not name a type
type struct {char * url;
^
WEBradio_ESP32_AZ_Dilevry:31:17: error: ‘station’ does not name a type
} station;
^
WEBradio_ESP32_AZ_Dilevry:36:1: error: ‘station’ does not name a type
station wardlist[Ward] Progmem = {
^
Multiple libraries were found for “AudioFileSource.h”
Used: C:\Users\cme\Documents\Arduino\libraries\ESP8266Audio-master
Not used: C:\Program Files (x86)\Arduino\libraries\ESP8266Audio
Multiple libraries were found for “WiFi.h”
Used: C:\Users\cme\AppData\Local\Arduino15\packages\esp32\hardware\esp32\1.0.6\libraries\WiFi
Not used: C:\Program Files (x86)\Arduino\libraries\WiFi
Multiple libraries were found for “SD.h”
Used: C:\Users\cme\AppData\Local\Arduino15\packages\esp32\hardware\esp32\1.0.6\libraries\SD
Not used: C:\Program Files (x86)\Arduino\libraries\SD
exit status 1
‘type’ does not name a type
Reimund
Kann man auch statt des 2 zeiligen Display ein 4 stelliges einbinden ? Da hat man ja mehr Informationen. Es gibt zwar ein Projekt welches mit einem 4 stelligen arbeitet, aber dort werden zwei Mono Verstärker gebraucht.
Bart Crimson
Problems booting, what’s happening?
Rebooting…
ets Jul 29 2019 12:21:46
rst:0xc (SW_CPU_RESET),boot:0×13 (SPI_FAST_FLASH_BOOT)
configsip: 0, SPIWP:0xee
clk_drv:0×00,q_drv:0×00,d_drv:0×00,cs0_drv:0×00,hd_drv:0×00,wp_drv:0×00
mode:DIO, clock div:1
load:0×3fff0030,len:1184
load:0×40078000,len:13260
load:0×40080400,len:3028
entry 0×400805e4
Connecting to WiFi
…Connecting to WiFi
…Connecting to WiFi
Connected
Gespeicherte Station 0 von 25
Active station http://icecast.vrtcdn.be/stubru-high.mp3
sourcebuffer created – Free mem=97520
created decoder
Decoder start…
Guru Meditation Error: Core 1 panic’ed (LoadProhibited). Exception was unhandled.
Reimund
Bekomme am Schluss immer die Fehlermeldung
Compilation error: ‘class LiquidCrystal_I2C’ has no member named ‘init’
Und das bei der Version von Update von unserem Leser Andreas Schröder
Kann mir da bitte jemand helfen ?
Reimund
Hallo die normale Version bekomme ich compal.
aber die
Update von unserem Leser Andreas Schröder
bewkomme ich am Schluss immer eine Fehlermeldung
Mark
Das Radio finde ich super! Allerdings kämpfe ich mit der Einrichtung verschiedener Radiosender. Mir ist beispielsweise bei SWR3 aufgefallen, dass die Anfrage mit einem Returncode 401 (Not authorized) abgewiesen wird. Wenn man die URL im Browser öffnet sieht man erst einen 302 (Redirect) und es werden dann diverse Tokens an die URL angehängt. Damit kommt die Funktion startUrl() bzw. die Methode AudioFileSourceICYStream wohl nicht klar. Das Radio startet dann nach einigen Sekunden neu.
Nehme ich nun aber beispielsweise die URL von Radio BOB! dann wird diese im Browser unverändert aufgerufen und abgespielt. Hier der Consolen Output. Ich verstehe nicht, warum hier ein Code -9 zurückkommt und das Radio anschließend neu startet.
Active station http://regiocast.streamabc.net/regc-radioboblive-mp3-192-3829599
[D][HTTPClient.cpp:293] beginInternal(): protocol: http, host: regiocast.streamabc.net port: 80 url: /regc-radioboblive-mp3-192-3829599
[D][HTTPClient.cpp:579] sendRequest(): request type: ‘GET’ redirCount: 0
] connect(): connected to regiocast.streamabc.net:80
[D][HTTPClient.cpp:1257] handleHeaderResponse(): code: 200
[D][HTTPClient.cpp:1264] handleHeaderResponse(): Transfer-Encoding: identity
[D][HTTPClient.cpp:603] sendRequest(): sendRequest code=-9
] returnError(): error(-9): Transfer-Encoding not supported
[D][HTTPClient.cpp:1419] returnError(): tcp stop
[D][HTTPClient.cpp:400] disconnect(): tcp is closed
Sebastian Eichner
Hatte auch Probleme.
sobald MDCallback auskommentiert ist läuft das ganze auch mit den aktuellen Libs.
Reinhard
@Eckmar Schmitz
Das Gehäuse ist problemlos druckbar. Habe es mit dem Ultimaker Cura bearbeitet, natürlich muss man den Deckel “auf den Kopf” drehen.
Michael-S
@Rene
also ich hab auch erst Probleme mit den diversen Bibliotheksversionen gehabt. Am Ende habe ich exakt die Versionen wie in den Screenshots oben verwendet;
meine Arduino IDE: 1.8.16
Voreinstellungen → zusätzliche Boardverwalter URL’s:
http://arduino.esp8266.com/stable/package_esp8266com_index.json
https://raw.githubusercontent.com/espressif/arduino-esp32/gh-pages/package_esp32_index.json
Audio-Bibliothek: ESP8266Audio Version 1.9.5
ESP 32 Board: esp32 Version 1.0.6
Damit läuft es im Prinzip, zumindest mit den Streams aus dem Beispiel, allerdings nicht mit den Streams der SWR Sender.
Bernd
Hallo,
ich habe mir auch diesen Radiowecker nachgebaut. Tolles Projekt.
Leider funktioniert bei mir, wie bei Michaels Post, die Titelanzeige des Senders nicht.
Hat jemand eine Tipp an was das liegen könnte????
Dankeee
Didi
Ich kann mich dem Kommentar von Rene vollumfänglich anschließen. Ich habe Unmengen von Bibliotheksversionen, IDEs und Borddefinitionen ausprobiert, bei einigen Versionen wird nicht einmal kompiliert. Übrigens sowohl bei der alten als auch der neuen Variante der Webradio Firmware. Immer wenn der Stream beginnt, startet der MC neu.
So ist der komplette Aufbau nur Elektronikschrott…
Eckmar Schmitz
Für alle die das Problem mit dem laufenden Restart des Microcontrollers haben – bitte alle 3 GND Anschlüsse miteinander verbinden. Wird dies nicht gemacht, ist die Spannung am +5V Pin zu klein wenn über den USB Anschluß eingespeist wird. Durch das Display bricht die Spannung zusammen und er Controller macht einen Reset.
Ich hoffe ich konnte helfen – hatte das gleiche Problem. Jetzt nicht mehr und alles funktioniert.
Rene
Leider funktioniert der Code nicht mehr. Vor ca. 2 Jahren konnte ich alles erfolgreich aufbauen. Mit der aktuellen IDE und den aktuellen Lib’s muss es aber ein Problem geben. WLAN lädt, der Sender wird gefunden und im Moment des Abspielens startet der ESP neu.
Kann jemand mal bitte die Releases der Lib’s und IDE nennen, mit denen es funktioniert?
Reinhard
@Alberto Borsetta:
Just take a look at the parts list….near the bottom
Gerhard Kündig
Hallo Gerald
Auch ich habe Probleme mit dem Code. Beide Arduino.ide Versionen (1.8.12 und 2.2.1)kompilieren mir den Sketch, er wird auch hochgeladen, dann aber rebootet das Modul dauernd nach der Zeile «Decoder Start». Nun habe ich die Zeile * (file→RegisterMetadataCB(MDCallback, NULL); )* auskommentiert, was bei mir nicht viel brachte. Mit etwas Glück hört man für ein bis zwei Sekunden den Ton korrekt, dann kratzt es nur noch. Nach all den Kommentaren bin ich auch der Überzeugung, dass die Bibliothek «ESP8266Audio» sich mit dem Board nicht verträgt. Übrigens in der Boardverwaltung findet man die Version esp32-2.0.9 nicht mehr. Also habe ich die beiden höheren Versionen ausprobiert.
Vielleicht stellt jemand im Forum eine funktionierende .bin Datei zur Verfügung, das wäre auch sehr nett. Das Problem zeigt sich bei mehreren ESP32 Node MCU-Modulen identisch.
Gerhard Kündig
Eckmar Schmitz
Leider ist die STL Datei für den Deckel nicht zu gebrauchen. Sie ist nicht druckbar. Beim Schaltbild fehlen einige Verbindungen. Auch das ist so unbrauchbar. Wenn möglich korrigieren.
Rene
Geht leider nicht :(
20:23:37.335 → Connecting to WiFi
20:23:37.433 → …Connecting to WiFi
20:23:38.456 → Connected
20:23:39.542 → Gespeicherte Station 8 von 25
20:23:39.542 → Active station http://dispatcher.rndfnk.com/br/br3/live/mp3/low
20:23:39.805 → sourcebuffer created – Free mem=126696
20:23:39.805 → created decoder
20:23:39.805 → Decoder start…
20:23:40.331 → Guru Meditation Error: Core 1 panic’ed (LoadProhibited). Exception was unhandled.
Jörg Braun
Sehr schön, vielen Dank.
Einziges Problem, die Plotter-Datei im Silhouette-Format. Silhouette gibt es auch nur für Windows. www.online-convert.com mochte die Datei bei mir nicht, dafür http://www.ideas-r-us-software.uk/FileConverters/SilhouetteStudioConverter.aspx.
Mit SVG kommt man dann weiter.
Alberto Borsetta
Is it also possible to share 3D models (.stl or other) for printing of the enclosure? Thanks, Alberto
Michael-S
tolles Projekt, kommt für mich gerade zur rechten Zeit. Wohne in schlechter Empfangslage und hatte bisher analoge Radiosender über Kabel. Jetzt hat Vodafone die analogen Kanäle abgeschaltet und da wäre das ESP32 Webradio – ohne alle externen Komponenten – genau das Richtige (Audio direkt über den Aux Eingang in den AV Receiver).
Leider funktioniert das Decodieren meiner lokalen Sender SWR1 und SWR3 nicht.
Beispiel: liveradio.swr.de/sw282p3/swr1bw/play.mp3 bzw. liveradio.swr.de/sw282p3/swr3/play.mp3
Wenn ich die Adresse im Browser eingebe, wird dieser weitergeleitet:
http://d121.rndfnk.com/ard/swr/swr3/live/mp3/128/stream.mp3?aggregator=web&cid=01FC1X5J7PN2N3YQPZYT8YDM9M&sid=2bRYvGg48qLoJX6kXZ8h821Ooqu&token=b9TBNhKWbE9D53Q7zcaQUtrBvp3_FyBQbG0GHq0BD5Q&tvf=Vv0VhPCkrRdkMTIxLnJuZGZuay5jb20
Mit dem Browser, vlc oder mpv funktioniert das problemlos, aber nicht mit dem ESP32.
Ich hab mal versucht, das mittels ffmpeg “umzuleiten”:
ffmpeg -re -i https://liveradio.swr.de/sw282p3/swr1bw/play.mp3 -vcodec none -acodec copy -ac 2 -b:a 128k -content_type audio/mpeg -f mp3 -listen 1 http://192.168.1.24:8888/stream.mp3
damit entfällt die Umleitung mit den aggregator und cid Paramter, funktioniert mit dem ESP32 aber trotzdem nicht.
Hat jemand eine Idee, wie ich das zum laufen bekomme?
Vielen Dank und Grüße
Michael
Siegfried
@Jörg: Bei SSID dort kommt der WLan Name und PSK ist Dein WLan Passwort und beides in die Anführungszeichen setzen …
Jörg
Habe mich soweit durchgekämpft, die ARDUINO Oberfläche meldet Übertragung zu 100% abgeschlossen. Es ist jedoch nur Rauschen zu hören. Im Display erscheint nur die untere Zeile jedoch ist auch diese leer. Bei define PSK weiß ich nicht was ich da eintragen soll, ist das Phase Shift Keying? Was wäre da passend? Für die Bibliothek „LiquidCrystal I2C“ finde ich einige Einträge, ich habe scheinbar nicht die Passende gewählt. Gibt es da eine Empfehlung? Überhaupt stehen manche Versionsnummern gar nicht mehr zur Auswahl.
Wäre sehr froh über Hilfe.
Holger
Hallo zusammen,
ich finde das Projekt echt gelungen. Noch besser wäre es, wenn eine Sprachsteuerung integriert wäre (ohne irgend eine Cloud-Anwendung zu nutzen). Also keine Alexa o. ä.
Kennt jemand so ein Projekt ?
Gruß Holger
Aust, Jan
Ich würde es begrüßen, wenn die passiven Bauteile beim Bausatz dabei wären, zu mindestens die Widerstände und der Kondensator, die man direkt für die Funktion des Ganzen benötigt.
W.Müller
Hallo ihr ESP Radio Programmierer,
ich habe das Projekt auch bei mir umgesetzt und bin total begeistert. Vilen Dank allen, die daran beteiligt waren und sind. Ich habe allerdings ein Problem. Ich möchte neben den reinen Internetradiosender gern auch von meiner Synology (NAS) MP3 streamen. Leider bekomme ich das so nicht hin. Wenn ich z.B statt eines Internetsenders folgenden Eintrag einstelle: “http://192.168.×.x:80/Gruppe – Titel.mp3” funktioniert es einwandfrei. Gebe aich allerdings eine M3U Playlist an, stützt das Programm ab und der ESP startet neu.
Frage:
Wie kann ich auf meinem NAS eine Playlist abspielen?
Herzlichen Dank für Tipps
Wigbert
Alf W.
Gibt es zu diesem Problem noch eine weitere Lösung? —> Ich hatte auch das Problem, dass der Prozessor offenbar immer neu startete. Ich habe den Aufruf (file→RegisterMetadataCB(MDCallback, NULL); ) auch auskommentiert. Damit started der Prozessor nicht immer wieder. Der aktuelle Sender wird abgespielt, ich kann andere Sender wählen – diese werden aber nicht abgespielt – nach ein paar Sekunden wird wieder der erste Sender abgespielt.
Werner Boellmann
P.S. warum den Quelltext auf dem “Schrott” Google-Drive veröffentlichen. Ich lehne es ab mich dort zu registrieren – und ohne Registrierung komt man die Dateien nicht ran.
Ich weiß – die wollen nur unser Bestes. Aber das bekommen die nicht!
Werner Boellmann
|Klaus P.
: MDCallback()
Ich vermute, daß
1. es im MDCallback() zu einem Stack-Overflow kommt,
2. oder/und der Callback im Kontext einer ISR aufgerufen wird.
Zum Testen:
1. Im Callback " char s132, s264;" als static deklarieren. Dann wird der Speicher fest reserviert und nicht auf dem Stack.
2. den Callback als “void IRAM_ATTR” deklarieren.
Klaus P.
@Gerald Lechner
Ich hatte auch das Problem, dass der Prozessor offenbar immer neu startete. Bei mir hat es geholfen die MDCallback-Funktion und den Aufruf (file→RegisterMetadataCB(MDCallback, NULL); ) zu löschen bzw. auszukommentieren. Vielleicht findet ja jemand die Ursache?
Gerald Lechner
Hallo Manfred
das programm stürzt ab, wenn der MP3 dekoder gestartet wird. Es könnte sein, dass die Versionen von ESP8266Audio und dem ESP32 Package nicht zusammenpassen. Definitiv funktioniert ESP8266Audio Version 1.9.7 zusammen mit dem ESP32 Package Version 2.0.9
Eine weitere Ursache könnte sein, dass der ESP32 zu viel Strom zieht und die Stromversorgung zu schwach ist. Diese Ursache halte ich aber für sehr unwahrscheinlich.
Lampl Manfred
Hallo Gerald
Hier die Ausgabe von seriellen Monitor:
Verbinde mit WiFi ….IP-Adresse per DHCP ist 192.168.0.32
Connected
Webserver ist gestartet
Active station http://icecast.ndr.de/ndr/ndr2/niedersachsen/mp3/128/stream.mp3
sourcebuffer created – Free mem=67928
created decoder
Decoder start…
Guru Meditation Error: Core 1 panic’ed (LoadProhibited). Exception was unhandled.
Core 1 register dump:
PC : 0×4008ae4d PS : 0×00060d30 A0 : 0×80157dfc A1 : 0×3ffcbb50
A2 : 0×00000000 A3 : 0xfffffffc A4 : 0×000000ff A5 : 0×0000ff00
A6 : 0×00ff0000 A7 : 0xff000000 A8 : 0×00000000 A9 : 0×3ffcbf50
A10 : 0×3ffc55e4 A11 : 0×00000588 A12 : 0×0000001c A13 : 0×00000002
A14 : 0×00000000 A15 : 0×00000000 SAR : 0×00000018 EXCCAUSE: 0×0000001c
EXCVADDR: 0×00000000 LBEG : 0×4008ae4d LEND : 0×4008ae5d LCOUNT : 0xffffffff
Gerald Lechner
@Pit: Sie haben im Prinzip recht. Da beide Signalleitungen vom ESP32 als Ausgang betrieben werden ist es aber nicht ganz so kritisch. Ich hatte noch keine Probleme damit.
Die Pullup Widerstände sind 4,7kOhm. wenn man beide Leitungen über 10kOhm mit Masse
verbindet ändert sich die Leerlaufspannung von 5V auf 3.4 V. Spannungsteiler 5 / (4.7 + 10) * 4.7 = 3.4
@Manfred Lampl: Um helfen zu können benötige ich mehr Informationen. Zumindest die Ausgabe vom seriellen Monitor.
Manfred Lampl
Hallo
Habe mit Erfolg den ESP32 geflasht, leider wechselt die Anzeige ständig zwischen WLAN und den 1. Sender in Sekunden Takt hin und her. dh. der ESP bootet ständig …
was kann das sein.
Bitte um Hilfe.
bedanke mich im vorraus für die Unterstützung.
Manfred
Pit
Hi,
ich finde die Anschaltung des Display es etwas “gefaehrlich” fuer den ESP32,
denn so wie dargestellt wird der I2C ueber die PullUps auf der Display-Interfaceplatine
auf 5V gezogen, der ESP32 mag aber , soweit mir bekannt , keine 5V am GPIO.
Deswegen wuerde ich vorschlagen entweder das Display auf 3V3 oder die PullUps
von der Interfaceplatine entfernen und 2 neue gegen 3V3 in die Schaltung zu integrieren.
Thomas
Hallo,
habe das Radio gebaut – läuft mit den meisten der vorbereiteten Sender.
Suche nach einem funktionierenden URL für “Radio SwissClassic”.
Hat den jemand in seiner Liste?
Herzlichen Dank für das tolle Projekt und einen hoffentlich bald spielenden Lieblingssender!
Thomas
Siegfried
@ Waldi65: bei mir gibt es solch Reaktion, wenn der 10 k Widerstand am GPIO 35 zum 3,3 V Anschluss fehlt (Encoder Sender SW muss ja nicht unbedingt angeschlossen sein)
Waldi65
ich bekomme das ding nicht zum laufen. Audio 1.9.5 esp 1.0.6. es wird in einer Schleife rebootet mit folgendem output:
17:52:42.392 → load:0×40080400,len:3600
17:52:42.392 → entry 0×400805f0
17:52:43.770 → Connecting to WiFi
17:52:43.890 → …Connecting to WiFi
17:52:44.880 → Connected
17:52:46.035 → End Serup!
17:52:46.035 → Guru Meditation Error: Core 1 panic’ed (LoadProhibited). Exception was unhandled.
17:52:46.035 →
17:52:46.035 → Core 1 register dump:
17:52:46.035 → PC : 0×400d2fe4 PS : 0×00060b30 A0 : 0×800e22b4 A1 : 0×3ffb2270
17:52:46.035 → A2 : 0×3ffc451c A3 : 0×3ffc4788 A4 : 0×00000000 A5 : 0×00000017
17:52:46.035 → A6 : 0×3ffb8188 A7 : 0×80000001 A8 : 0×800d2fc8 A9 : 0×3ffb2240
17:52:46.068 → A10 : 0×00000000 A11 : 0×0000000a A12 : 0×3ffc4bd4 A13 : 0×00000000
17:52:46.068 → A14 : 0×00000000 A15 : 0×00000001 SAR : 0×0000001f EXCCAUSE: 0×0000001c
17:52:46.068 → EXCVADDR: 0×00000000 LBEG : 0×4008ad31 LEND : 0×4008ad41 LCOUNT : 0xfffffffd
17:52:46.068 →
17:52:46.068 →
17:52:46.068 → Backtrace: 0×400d2fe1:0×3ffb2270 0×400e22b1:0×3ffb2290
17:52:46.068 →
17:52:46.068 →
17:52:46.068 →
17:52:46.068 →
17:52:46.068 → ELF file SHA256: ecf99bcd61080b16
17:52:46.103 →
17:52:46.135 → Rebooting…
17:52:46.135 → ets Jul 29 2019 12:21:46
Oliver Mittelstedt
wann gibt es das set wieder zum kaufen
Günter R.
Nachtrag: Zur nur einkanaligen und verzerrten Ausgabe finde ich nun folgende Fehlermeldung im seriellen Monitor:
Station: 5
Active station Deutschlandfunk
Active station http://st01.sslstream.dlf.de/dlf/01/128/mp3/stream.mp3
sourcebuffer created – Free mem=87248
created decoder
Decoder start…
E (228122) I2S: register I2S object to platform failed
Nachrichten, Deutschlandfunk-Nachrichtenredaktion
Nun verwende ich den ESP-32 Wroom… könnte es Konflikte im Soundmodul der Plattformen geben? Alle anderen Features funktionieren einwandfrei, keine Compiler-Warnungen etc. Die ESP32Audio-Lib funktioniert dabei nur in der Version 1.9.7, alle anderen Versionen versagen.
Vielen Dank für alle Hilfe-Ideen im Voraus
Günter
GuidoJ
Hallo Geradl und Andreas,
ich habe das Radio seit heute am funktionieren. Ich verwende den update von Andreas. Vielen Dank auf diesem weg für dieses Projekt.
Wo ich am meisten kämpfen musste war, die richtigen Versionen der Boards und LIBs zu finden, das war echt ne Challenge
In der Arduino Umgebung ist es auch schwer nachzuvollziehen, welche LIB am Ende verwendet wird.
Nochmals Danke :-)