NEWS
Sayit MP3 abspielen
-
Hallo,
ich möchte mit dem Sayit Adapter eine MP3 abspielen (SONOS Adapter korrekt installiert und konfiguriert, Sprachausgabe funktioniert).
Der Aufruf
setState("sayit.0.tts.mp3"/*Binary mp3 file*/,'/vis.0/main/img/door-bell.mp3');
bringt keine Ausgabe.
Was ist falsch?
Gruß,
Pix
-
@pix:Hallo,
ich möchte mit dem Sayit Adapter eine MP3 abspielen (SONOS Adapter korrekt installiert und konfiguriert, Sprachausgabe funktioniert).
Der Aufruf
setState("sayit.0.tts.mp3"/*Binary mp3 file*/,'/vis.0/main/img/door-bell.mp3');
bringt keine Ausgabe.
Was ist falsch?
Gruß,
Pix `
Nix ist falsch. Ist nicht implementiert. Heute Abend aber, wird es soweit. -
Muss jetzt gehen.
-
Hallo,
ist leider bei, Update stehengeblieben:
Deshalb hat das Abspielen nicht geklappt. Versuche es morgen nochmal. Danke für die Hilfe.Gruß.
Pix
-
Du hast immer "bulletproof" Lösung. In /opt/iobroker:
npm install iobroker.sayit --force
-
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}
-
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
-
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..
-
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.
-
Gute Idee, nur mit welchen Adapter sollte ich das dann tun?
7666_pct.png
7666_state.png -
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.
-
-
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:
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:
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?
-
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
-
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
-
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?
-
Also ich konnte ein mp3 Datei abspielen.
Man sollte "sayit.0.tts.text" State beschreiben und nicht mp3
Eventuell unter linux braucht man auch neue Version von sayIt. -
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.
-
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:
Ansage: nein!
Fehlermeldung im Log:
Die Gong Datei ist aber definitiv da!
Was tun?
-
Huhu, Bluefox,
Hast Du mein Pist von heute Morgen gesehen?
-
Beim Upgrade auf die 0.3.16 blieb er hier stehen:
Dann versuchte ich
> npm install iobroker.sayit –force
Ergebnis:
Klappt wohl auch nicht! Er findet das Startfile nicht mehr
Fazit: nach dem Upgrade funktioniert der Sayit Adapter NICHT mehr!