Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. ioBroker Allgemein
    4. Sayit MP3 abspielen

    NEWS

    • Wir empfehlen: Node.js 22.x

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker goes Matter ... Matter Adapter in Stable

    Sayit MP3 abspielen

    This topic has been deleted. Only users with topic management privileges can see it.
    • Bluefox
      Bluefox last edited by

      Du hast immer "bulletproof" Lösung. In /opt/iobroker:

      npm install iobroker.sayit --force
      
      
      1 Reply Last reply Reply Quote 0
      • S
        skorpil last edited by

        Ich muss das Thema noch einmal aufleben lassen, weil ich nicht weiterkomme. sonos und sayit Adapter der neuesten Varianten sind installiert. Ruf ich mit:

        var idSayIt = "sayit.0.tts.text"  /*Text to speech*/
        var d = new Date ();
        setState (idSayIt, "Es ist jetzt " + d.getHours() + " Uhr und " + d.getMinutes() + " Minuten.");
        

        das Script auf, läuft es perfekt durch.

        Das Log sagt dazu:

        sonos-0 2015-11-26 12:35:59 info Restore state: volume - 50, mute: false, uri: x-file-cifs://192.168.0.76/musik/Michael%20Bubl%c3%a9/Christmas/02%20Santa%20Claus%20Is%20Coming%20To%20Town.mp3 
        sonos-0 2015-11-26 12:35:54 info Play on sonos[RINCON_000E5825101001400]: http://192.168.0.80:8082/state/sayit.0.tts.mp3, Volume: 70 
        sonos-0 2015-11-26 12:35:54 info try to control id sonos.0.root.192_168_0_32.tts with {"val":"70;http://192.168.0.80:8082/state/sayit.0.tts.mp3","ack":false,"ts":1448537755,"q":0,"from":"system.adapter.sayit.0","lc":1448473161} 
        sayit-0 2015-11-26 12:35:54 info Copied file '/opt/iobroker/node_modules/iobroker.sayit/say.mp3' to '/opt/iobroker/cache/13129ecf1ea8e6d3cbfb680638988419.mp3' 
        sayit-0 2015-11-26 12:35:54 info saying: Es ist jetzt 12 Uhr und 35 Minuten. 
        javascript-0 2015-11-26 12:35:54 info script.js.Datum_Uhrzeit_sayit_0_=_Büro: registered 0 subscriptions and 0 schedules 
        javascript-0 2015-11-26 12:35:54 info Start javascript script.js.Datum_Uhrzeit_sayit_0_=_Büro 
        javascript-0 2015-11-26 12:35:54 info Stop script script.js.Datum_Uhrzeit_sayit_0_=_Büro 
        
        

        Jetzt möchte ich ein mp3 file abspielen. Der Code

        var idSayIt = "sayit.0.tts.mp3"  /*mp3 spielen*/;
        setState(idSayIt, '/opt/iobroker/iobroker-data/files/sayit.0/tts.userfiles/1.mp3');
        
        

        führt zu: NIX, keine Ansage, gar nichts. Und das Log sagt:

        javascript-0 2015-11-26 12:44:34 info script.js.Test_abspielen_mp3: registered 0 subscriptions and 0 schedules 
        javascript-0 2015-11-26 12:44:34 info Start javascript script.js.Test_abspielen_mp3 
        
        

        Irgendwie wird offenbar sayit nicht ausgelöst. Was ist falsch?

        Danke für Euere Hilfe.

        PS: wenn ich mit

        http://192.168.0.80:8082/state/sayit.0.tts.mp3
        

        den Sayit Adapter, wie im github beschrieben, im Brower aufrufe passiert auch nix.

        {"val":"1.mp3","ack":false,"ts":1448536655,"q":0,"from":"system.adapter.javascript.0","lc":1448536241}
        
        

        7666_k-pct.png
        7666_k-state.png

        1 Reply Last reply Reply Quote 0
        • P
          pix last edited by

          Hallo skorpil,
          @skorpil:

          setState(idSayIt, '/opt/iobroker/iobroker-data/files/sayit.0/tts.userfiles/1.mp3');
          ```` `  
          

          vielleicht stimmt dein Verzeichnis nicht.

          Bluefox hat mir mal dieses empfohlen:
          @Bluefox:

          @pix:

          setState("sayit.0.tts.mp3"/*Binary mp3 file*/,'/vis.0/main/img/door-bell.mp3');
          ```` `  `  
          

          Gruß

          Pix

          1 Reply Last reply Reply Quote 0
          • S
            skorpil last edited by

            Pix,

            Danke für die Hilfe. Habe das gerade ausprobiert. Leider keine Besserung. Da muss vermutlich bluefox ran.

            Ich tippe darauf, dass tts.mp3 irgendwie deaktiviert ist..

            1 Reply Last reply Reply Quote 0
            • M
              mc-hollin last edited by

              Wäre es nicht empfehlenswert für die Ausgabe von MP3 einen eigenen Adapter zu entwickeln?

              Ich würde das Feature nicht unter TTS(Text To Speach) erwarten.

              1 Reply Last reply Reply Quote 0
              • S
                skorpil last edited by

                Gute Idee, nur mit welchen Adapter sollte ich das dann tun?
                7666_pct.png
                7666_state.png

                1 Reply Last reply Reply Quote 0
                • Bluefox
                  Bluefox last edited by

                  Ich sehe noch keine Notwendigkeit eigenen mp3 Adapter zu entwickeln.

                  Say it besteht aus 2 Teilen:

                  • text to mp3

                  • mp3 abspielen

                  Für "text to mp3" existieren momentan 3 Engines. Für mp3 abspielen 6. Es kann beliebige Kombination davon sein.

                  Herausforderung ist das Plattformunabhängig zu machen.

                  So weit wie ich es verstehe du willst an Sonos die MP3 Datei abspielen. Mit dem Kommando:

                  setState("sayit.0.tts.mp3"/*Binary mp3 file*/,'/vis.0/main/img/door-bell.mp3');
                  
                  

                  Lädst du die mp3 Datei in Sayit (und das war es). Danach muss unter

                  http://ip:8082/state/sayit.0.tts.mp3

                  die mp3 Datei erreichbar sein. Das kann man mit dem Browser ausprobieren.

                  Und jetzt fehlt nur noch das Kommando an sonos, dass die Datei abgespielt werden muss. Das kann man mit:

                          sendTo('sonos', 'send', 'http://ip:8082/state/sayit.0.tts.mp3');
                  
                  

                  machen.

                  1 Reply Last reply Reply Quote 0
                  • S
                    skorpil last edited by

                    Lieber Bluefox,

                    danke für die Hilfe. Leider höre ich noch immer: NICHTS.

                    Ich hatte das Script entsprechend Deiner Vorschläge angepasst:

                    var idSayIt = "sayit.0.tts.mp3"/*Binary mp3 file*/;
                    setState(idSayIt, '/opt/iobroker/iobroker-data/files/sayit.0/tts.userfiles/gong.mp3');
                    sendTo('sonos', 'send', 'http://XXX.XXX.XXX.XXX:8082/state/sayit.0.tts.mp3');
                    

                    Das Ergebnis ist, daß augenscheinlich irgendetwas an Sonos übertragen wird. Vgl. dazu den Bildschirmausdruck:

                    622_prtscr.jpg

                    Es gibt zwei Probleme:

                    1. die mp3 wird statt nur auf den Kanal "Arbeitszimmer" auf ALLE Sonos Kanäle gesendet (was ich nicht will), und

                    2. meldet Sonos, wie Du ebenfalls aus dem Bildschirmausdruck erkennst, dass die Datei nicht korrekt "codiert" ist.

                    Das log meldet dazu:

                    622_scr2.jpg

                    Das passiert jedoch Nicht, wenn ich mit folgendem Script eine Ansage laufen lasse:

                    var idSayIt = "sayit.0.tts.text"  /*Text to speech*/
                    var d = new Date ();
                    setState (idSayIt, "Es ist jetzt " + d.getHours() + " Uhr und " + d.getMinutes() + " Minuten.");
                    

                    Diese Ansage wird korrekt verarbeitet.

                    Daher noch mal meine Fragen:

                    1. Warum ist die mp3 für Sonos "nicht korrekt codiert"?

                    2. Wie kann ich nicht Alle Sonos Räume, sondern nur einen bestimmten ansteuern?

                    1 Reply Last reply Reply Quote 0
                    • S
                      skorpil last edited by

                      Und noch eine Ergänzung:

                      wenn ich bei Instanzen im Sayit Adapter eine "Ankündigung" mp3 angebe, wird diese korrekt eingespielt. Das zugehörige Log sieht so aus:

                      sonos.0 2015-11-27 18:04:14 info sonos.0 Restore state: volume - 50, mute: false, uri: http://192.168.0.80:8082/state/sayit.0.tts.mp3 
                      sonos.0 2015-11-27 18:04:13 info sonos.0 Play on sonos[RINCON_000E5825101001400]: http://192.168.0.80:8082/state/sayit.0.tts.mp3, Volume: undefined 
                      sonos.0 2015-11-27 18:04:12 info sonos.0 Restore state: volume - 50, mute: false, uri: http://192.168.0.80:8082/state/sayit.0.tts.mp3 
                      sonos.0 2015-11-27 18:03:57 info sonos.0 Queue on sonos[RINCON_000E5825101001400]: http://192.168.0.80:8082/state/sayit.0.tts.mp3, Volume: 70 
                      sonos.0 2015-11-27 18:03:57 info sonos.0 try to control id sonos.0.root.192_168_0_32.tts with {"val":"70;http://192.168.0.80:8082/state/sayit.0.tts.mp3","ack":false,"ts":1448643838,"q":0,"from":"system.adapter.sayit.0","lc":144847316 
                      sayit.0 2015-11-27 18:03:57 info sayit.0 saying:  
                      sonos-0 2015-11-27 18:03:52 info Play on sonos[RINCON_000E5825101001400]: http://192.168.0.80:8082/state/sayit.0.tts.mp3, Volume: 70 
                      sonos-0 2015-11-27 18:03:52 info try to control id sonos.0.root.192_168_0_32.tts with {"val":"70;http://192.168.0.80:8082/state/sayit.0.tts.mp3","ack":false,"ts":1448643832,"q":0,"from":"system.adapter.sayit.0","lc":1448473161} 
                      sayit-0 2015-11-27 18:03:51 info saying: /opt/iobroker/node_modules/iobroker.sayit/2.mp3 
                      javascript-0 2015-11-27 18:03:51 info script.js.Abspielen_nur_mit_ankündigung: registered 0 subscriptions and 0 schedules 
                      javascript-0 2015-11-27 18:03:51 info Start javascript script.js.Abspielen_nur_mit_ankündigung 
                      
                      
                      1 Reply Last reply Reply Quote 0
                      • M
                        mc-hollin last edited by

                        Hallo Bluefox,

                        wäre es möglich in Sayit auch pico2wave (SVOX Pico TTS engine) zu implementieren?

                        Wenn ich das richtig interpretiert habe, gibt es bis jetzt Google, Acapela, Yandex und Amazon

                        Ich hab jetzt auf dem Raspi das TTS pico2wave installiert, damit ich nicht "online" Daten senden muss.

                        Mit lame wandel ich die wav in mp3 um.

                        UPDATE: Oder vielleicht die Möglichkeit der Angabe einer eigenen Engine. Dann würde ich versuchen mein pico2wave über HTTP erreichbar zu machen (wie Google).

                        Hierfür müsste man dem sayit Adapter eine eigene Url der Engine angeben können.

                        Oder wie hier über Node.js https://github.com/luisivan/node-picott … r/index.js

                        1 Reply Last reply Reply Quote 0
                        • S
                          skorpil last edited by

                          Hallo Bluefox,

                          Gibt es an der Sayit Front irgendwas Neues? Mein Problem habe ich hier ausführlich beschrieben, aber augenscheinlich seid ihr mit anderen Dingen beschäftigt?

                          1 Reply Last reply Reply Quote 0
                          • Bluefox
                            Bluefox last edited by

                            Also ich konnte ein mp3 Datei abspielen.

                            Man sollte "sayit.0.tts.text" State beschreiben und nicht mp3
                            48_2015-12-26_00_50_45-iobroker.admin.png
                            Eventuell unter linux braucht man auch neue Version von sayIt.

                            1 Reply Last reply Reply Quote 0
                            • Bluefox
                              Bluefox last edited by

                              Was "nur auf einem Sonos" abzuspielen angeht, kann ich nicht testen, weil ich nur ein Sonos habe,

                              aber wenn du log level auf debug umstellst und dann mir die Logs zeigst.. Wird mir helfen.

                              1 Reply Last reply Reply Quote 0
                              • S
                                skorpil last edited by

                                Lieber Bluefox,

                                Erstmal, danke für die Rückmeldung. Es sind eigentlich drei Probleme, die ich mit den Sayit Adapter habe.

                                1. "lange Texte": meine Idee war anzusagen "Guten Morgen, heute ist Wochentag, der xx.xx.xx. Es ist x Uhr. Die Außentemperatur ist xx. Das Wetter heute ist xx".

                                Das geht aber nicht. Weil augenscheinlich der Text zu lang ist. Mein Workaround, das über mehrere Skripte zu lösen geht auch nicht. Denn der Text im zweiten und weiteren Skripts wird immer leiser. Das dann über Lautstärke Angaben zu lösen klappt auch nicht.

                                2. das Thema "mehrere Sonos" gehen wir an, wenn das grundsätzliche Thema der mp3 Ansage gelöst ist. Vlt. war nur die Fehlermeldung irreführend. Ich berichte, wenn das folgende Thema gelöst ist.

                                3. "mp3 Ansage". Gerade habe, Deinem Vorschlag folgend, das Script von "mp3" auf "text" geändert. Hier das Skript:

                                622_image.jpeg

                                Ansage: nein!

                                Fehlermeldung im Log:

                                622_image.jpeg

                                Die Gong Datei ist aber definitiv da!

                                622_image.jpeg

                                Was tun?

                                1 Reply Last reply Reply Quote 0
                                • S
                                  skorpil last edited by

                                  Huhu, Bluefox,

                                  Hast Du mein Pist von heute Morgen gesehen?

                                  1 Reply Last reply Reply Quote 0
                                  • S
                                    skorpil last edited by

                                    Beim Upgrade auf die 0.3.16 blieb er hier stehen:
                                    622_image.jpeg

                                    Dann versuchte ich

                                    > npm install iobroker.sayit –force

                                    Ergebnis:

                                    622_image.jpeg

                                    Klappt wohl auch nicht! Er findet das Startfile nicht mehr

                                    622_image.png

                                    Fazit: nach dem Upgrade funktioniert der Sayit Adapter NICHT mehr!

                                    1 Reply Last reply Reply Quote 0
                                    • S
                                      skorpil last edited by

                                      Jetzt habe ich meine beiden Sayit Instanzen gelöscht.

                                      Dann mit````
                                      npm install iobroker.sayit --force

                                      
                                      Ergebnis: es scheint, als wäre der Adapter jetzt auf dem neuesten Stand:
                                       ![622_image.jpeg](/assets/uploads/files/622_image.jpeg) 
                                      
                                      Aber, er lässt sich nicht installieren. Die Installation bricht ab:
                                      
                                       ![622_image.jpeg](/assets/uploads/files/622_image.jpeg) 
                                      
                                      Da müssten also die Fachleute noch einmal ran…
                                      1 Reply Last reply Reply Quote 0
                                      • Bluefox
                                        Bluefox last edited by

                                        @skorpil:

                                        Jetzt habe ich meine beiden Sayit Instanzen gelöscht.

                                        Dann mit````
                                        npm install iobroker.sayit --force

                                        
                                        Ergebnis: es scheint, als wäre der Adapter jetzt auf dem neuesten Stand:
                                         filename="image.jpeg" index="1">~~
                                        
                                        Aber, er lässt sich nicht installieren. Die Installation bricht ab:
                                        
                                         filename="image.jpeg" index="0">~~
                                        
                                        Da müssten also die Fachleute noch einmal ran… `  
                                        

                                        Bitte folgendes machen:

                                        cd /opt/iobroker/node_modules/iobroker.sayit
                                        sudo rm * -R
                                        cd /opt/iobroker
                                        sudo npm install iobroker.sayit
                                        sudo chmod 777 * -R
                                        iobroker add sayit
                                        
                                        
                                        1 Reply Last reply Reply Quote 0
                                        • S
                                          skorpil last edited by

                                          Lieber Bluefox,

                                          Danke fur Deine Hilfe. Jetzt läuft wieder alles.

                                          Ich komme aber nocheinmal zurück auf meine Punkte:

                                          ` > 1. "lange Texte": meine Idee war anzusagen "Guten Morgen, heute ist Wochentag, der xx.xx.xx. Es ist x Uhr. Die Außentemperatur ist xx. Das Wetter heute ist xx".

                                          Das geht aber nicht. Weil augenscheinlich der Text zu lang ist. Mein Workaround, das über mehrere Skripte zu lösen geht auch nicht. Denn der Text im zweiten und weiteren Skripts wird immer leiser. Das dann über Lautstärke Angaben zu lösen klappt auch nicht.

                                          2. das Thema "mehrere Sonos" gehen wir an, wenn das grundsätzliche Thema der mp3 Ansage gelöst ist. Vlt. war nur die Fehlermeldung irreführend. Ich berichte, wenn das folgende Thema gelöst ist.

                                          3. "mp3 Ansage". Gerade habe, Deinem Vorschlag folgend, das Script von "mp3" auf "text" geändert. `

                                          Punkt 3 mit der Änderung auf "text" statt "mp3" funktioniert jetzt!" Klasse.

                                          Punkt 2 ist auch erledigt. Das dürfte tatsächlich eine irreführende Fehlermeldung gewesen sein.

                                          Bleibt Punkt 1: Wie kriege ich es hin, mit dem Adapter "lange Texte" auszugeben? Zum Beispiel: "Guten Morgen, heute ist Wochentag, der xx.xx.xx. Es ist x Uhr. Die Außentemperatur ist xx. Das Wetter heute ist xx" Das funktioniert nicht (siehe oben)

                                          1 Reply Last reply Reply Quote 0
                                          • Bluefox
                                            Bluefox last edited by

                                            @skorpil:

                                            Lieber Bluefox,

                                            Danke fur Deine Hilfe. Jetzt läuft wieder alles.

                                            Ich komme aber nocheinmal zurück auf meine Punkte:

                                            ` > 1. "lange Texte": meine Idee war anzusagen "Guten Morgen, heute ist Wochentag, der xx.xx.xx. Es ist x Uhr. Die Außentemperatur ist xx. Das Wetter heute ist xx".

                                            Das geht aber nicht. Weil augenscheinlich der Text zu lang ist. Mein Workaround, das über mehrere Skripte zu lösen geht auch nicht. Denn der Text im zweiten und weiteren Skripts wird immer leiser. Das dann über Lautstärke Angaben zu lösen klappt auch nicht.

                                            2. das Thema "mehrere Sonos" gehen wir an, wenn das grundsätzliche Thema der mp3 Ansage gelöst ist. Vlt. war nur die Fehlermeldung irreführend. Ich berichte, wenn das folgende Thema gelöst ist.

                                            3. "mp3 Ansage". Gerade habe, Deinem Vorschlag folgend, das Script von "mp3" auf "text" geändert. `

                                            Punkt 3 mit der Änderung auf "text" statt "mp3" funktioniert jetzt!" Klasse.

                                            Punkt 2 ist auch erledigt. Das dürfte tatsächlich eine irreführende Fehlermeldung gewesen sein.

                                            Bleibt Punkt 1: Wie kriege ich es hin, mit dem Adapter "lange Texte" auszugeben? Zum Beispiel: "Guten Morgen, heute ist Wochentag, der xx.xx.xx. Es ist x Uhr. Die Außentemperatur ist xx. Das Wetter heute ist xx" Das funktioniert nicht (siehe oben) `
                                            Wie ich mich erinnern kann, wird schon automatisch bei 70 Symbolen (Google API) der Text geschnitten.

                                            https://github.com/ioBroker/ioBroker.sa … in.js#L246

                                            Was für einen API verwendest du?

                                            Mit Lautstärke.. Wird dann SONOS leiser und leiser?

                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate
                                            FAQ Cloud / IOT
                                            HowTo: Node.js-Update
                                            HowTo: Backup/Restore
                                            Downloads
                                            BLOG

                                            803
                                            Online

                                            32.0k
                                            Users

                                            80.4k
                                            Topics

                                            1.3m
                                            Posts

                                            14
                                            98
                                            18301
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo