NEWS
Bose Soundtouch steuern
-
An htrecksler danke das war echt super, funktioniert bei mir auch perfekt.
Ich habe mir das API Dokument angeschaut, weil ich die Soundtouch Anlage auch über iobroker ausschalten will.
Habe aber leider nicht gefunden.
Hast du eine Idee wie man es über die API's ausschalten kann?
-
Mit diesen beiden Befehlen sollte es funktionieren.
'<key state="press" sender="Gabbo">POWER</key>'
'<key state="release" sender="Gabbo">POWER</key>'
Im Prinzip sagt man damit der Soundtouch:
1. Drücke den Power Button
2. Lasse ihn wieder los.
Ich komme heute leider nicht dazu den kompletten Code zu testen, falls du damit so nicht klar kommst gib mir eine kurze Info, dann mache ich morgen ein komplettes Beispiel….
Gruss Hermann
-
Hi
habe folgenden Code geschrieben.
Kann das Objekt auch in iobroker vis sehen und benutzen.
Leider geht die Soundtouch Anlage nicht an.
Ist der Code eigentlich OK.
createState('Bose_Power', {type: 'boolean'}); function PowerSetzen() { var BodyString = '<key state="press" sender="Gabbo">POWER</key>'; var request = require('request'); request.post({ url: 'http://192.168.178.43:8090/key', body: BodyString }, function(error, response, body) { if (error) log(error, 'error'); }); } function PowerClear() { var BodyString = '<key state="release" sender="Gabbo">POWER</key>'; var request = require('request'); request.post({ url: 'http://192.168.178.43:8090/key', body: BodyString }, function(error, response, body) { if (error) log(error, 'error'); }); } on ({id: "javascript.0.Bose_Power", val: true}, function () { PowerSetzen; PowerClear; setState("javascript.0.Bose_Power", false); });
-
Hallo,
das steuern der Soundtouch bekomme ich schon hin.
Hat es einer von euch schon geschafft auch etwas auszulesen:
z.B. was wird gerade gestream
oder ob die Soundtouch gerade an oder aus ist.
Ich habe in einem neuem Thema auch noch mal die Frage gestellt, ob eine Sprachausgabe wie bei Sonos möglich ist http://forum.iobroker.net/viewtopic.php … hilit=Bose
Evtl. hat ja einer von euch eine Idee.
Mann könnte sich zwar auch Sonos kaufen, aber die Preset Tasten von Bose sind schon cool 8-)
Gruß
Phantomio
-
gibt es schon einen fertigen Adapter für Bose?
-
Das würde mich auch interessieren.
Gesendet von meinem HUAWEI NXT-L29 mit Tapatalk
-
Das würde mich auch interessieren. `
Mich auch , ich habe eigentlich FHEM nur noch wegen diesem Adapter laufen.
Ich mache alle Sprachausgaben von ioBroker über FHEM. Das FHEM dazu einen Minidlna Server benötigt gefällt mir auch nicht wirklich.
Aber bei der Programierung bin ich raus, da kann ich nicht helfen.
-
So ein Adapter steht auf meiner Todo-Liste … aber anderes steht vorher da
Um einen "Mini-DLNA-Server" (auch wenn er wenn dann in ioBroker läuft) kommt man wohl auch nicht drum rum
-
Wie würde denn der Teil für Power aussehen?
Also quasi das Skript so erweitert das man bei VIS einen Power On/Off Widget hätte?
Könnte man auch beim Einschalten / Preset schalten alle Soundtouch Lautsprecher verbinden?
Grüße
Oliver
-
Also den Power Button habe ich jetzt auch hinbekommen.
createState('BoseVolume', 10); createState('Bose_Power', {type: 'boolean'}); createState('Bose_Preset_1', {type: 'boolean'}); createState('Bose_Preset_2', {type: 'boolean'}); createState('Bose_Preset_3', {type: 'boolean'}); createState('Bose_Preset_4', {type: 'boolean'}); createState('Bose_Preset_5', {type: 'boolean'}); createState('Bose_Preset_6', {type: 'boolean'}); function PowerSetzen() { var BodyString = '<key state="press" sender="Gabbo">POWER</key>'; var request = require('request'); request.post({ url: 'http://Bose IP:8090/key', body: BodyString }, function(error, response, body) { if (error) log(error, 'error'); }); } function PowerClear() { var BodyString = '<key state="release" sender="Gabbo">POWER</key>'; var request = require('request'); request.post({ url: 'http://Bose IP:8090/key', body: BodyString }, function(error, response, body) { if (error) log(error, 'error'); }); } function PresetSetzen(pWert) { var BodyString = '<key state="release" sender="Gabbo">' + pWert + '</key>'; var request = require('request'); request.post({ url: 'http://Bose IP:8090/key', //body: '<volume>20</volume>' body: BodyString }, function(error, response, body) { if (error) log(error, 'error'); }); } function VolumeSetzen(pWert) { var BodyString = '<volume>' + pWert + '</volume>'; var request = require('request'); request.post({ url: 'http://Bose IP:8090/volume', //body: '<volume>20</volume>' body: BodyString }, function(error, response, body) { if (error) log(error, 'error'); }); } on ({id: "javascript.0.Bose_Power", val: true}, function () { PowerSetzen('Power'); setState("javascript.0.Bose_Power", false); }); on ({id: "javascript.0.BoseVolume", change: "ne"}, function () { lVolume = getState("javascript.0.BoseVolume"); VolumeSetzen(lVolume.val); }); on ({id: "javascript.0.Bose_Preset_1", val: true}, function () { PresetSetzen('PRESET_1'); setState("javascript.0.Bose_Preset_1", false); }); on ({id: "javascript.0.Bose_Preset_2", val: true}, function () { PresetSetzen('PRESET_2'); setState("javascript.0.Bose_Preset_2", false); }); on ({id: "javascript.0.Bose_Preset_3", val: true}, function () { PresetSetzen('PRESET_3'); setState("javascript.0.Bose_Preset_3", false); }); on ({id: "javascript.0.Bose_Preset_4", val: true}, function () { PresetSetzen('PRESET_4'); setState("javascript.0.Bose_Preset_4", false); }); on ({id: "javascript.0.Bose_Preset_5", val: true}, function () { PresetSetzen('PRESET_5'); setState("javascript.0.Bose_Preset_5", false); }); on ({id: "javascript.0.Bose_Preset_6", val: true}, function () { PresetSetzen('PRESET_6'); setState("javascript.0.Bose_Preset_6", false); });
Leider kenne ich mich mit Javascript nicht aus und die Implementierung von /set_Zone überfordert mich.
Vielleicht hat das schon jemand erfolgreich laufen?
Gruß Oliver
-
-
Ich kam noch zu nichts …
-
Hallo Leute,
ich bin seit ein paar Tagen dran, für die Bose SoundTouch einen Adapter zu basteln. Per JavaScript hab ich schon den code soweit beisammen, dass ich keys (z.B. 'POWER') per HTTP-push senden kann.
Statusabfragen per HTTP-get (z.B. http://bosesoundtouch-ip:8090/volume) funktionieren auch und auch ein websocket, der Statusänderungen der soundbar mitbekommt und entsprechend parsed (aktuell volume, now_playing und presets) läuft.
Jetzt starte ich, das ganze zu einem Adapter umzubauen, werke gerade am Aufbau einer debug-Umgebung mit VS Code. Mehr als ein leeres Adapter-Template von GitHub hab ich aber noch nicht am Laufen. Wird also noch eine Weile dauern.
JavaScript hab ich erst mit diesem Projekt 'erlernt', war bisher rein auf C/C++/C# unterwegs. Brauche also für alles entsprechend Einarbeitungszeit.
bis bald…
-
Super, und danke für die Zwischeninfo. Würde dir gern dabei helfen aber ich kenne mich leider null damit aus. Danke das du dich der Sache annimmst.
Gesendet von meinem HUAWEI NXT-L29 mit Tapatalk
-
Du hast gesehen das es auf npm bereits Projekte gibt die das grundsätzlich machen ?! Oder baust du die ganze Kommunikation gerade selbst?
-
Du hast gesehen das es auf npm bereits Projekte gibt die das grundsätzlich machen ? ` Welche npm-Projekte gäbe es da?
Das Grundgerüst für meinen Code stammt von https://github.com/ChrisScheffler/node-soundtouch. Ich musste hier aber einige Änderungen vornehmen, hauptsächlich beim Parsen der empfangenen Pakete. Hier dürfte sich an der API von Bose inzwischen einiges geändert haben.
Ich verwende folgende npm-pakete:
-
request - sendet auf Port 8090 Befehle (push - Lautstärke setzen, POWER-key…) und Statusanforderungen (get - aktuelle Lautstärke, Now playing...)
-
ws - WebSocket, der auf port 8080 auf Updates der SoundTouch hört (Lautstärkeänderungen, Now playing…)
-
xml2js - parsen der empfangenen Daten
-
es6-promise - hab ich einfach so übernommen
Hab gestern noch den ioBroker samt meinem Adapter-Template und VS-Code debug Umgebung auf meinem Windows PC grob zum Laufen gebracht. Jetzt muss ich noch meinen Script-code einpflegen. Sobald ich in den nächsten Tagen eine erste Version am Laufen hab, kann ich ihn zu Testzwecken bereitstellen. Auch hier muss ich mich erst Schlau machen, wie man da vorgeht.
Bis demnächst.
-
-
Du hast gesehen das es auf npm bereits Projekte gibt die das grundsätzlich machen ? ` Welche npm-Projekte gäbe es da?
Das Grundgerüst für meinen Code stammt von https://github.com/ChrisScheffler/node-soundtouch. Ich musste hier aber einige Änderungen vornehmen, hauptsächlich beim Parsen der empfangenen Pakete. Hier dürfte sich an der API von Bose inzwischen einiges geändert haben.
Ich verwende folgende npm-pakete:
-
request - sendet auf Port 8090 Befehle (push - Lautstärke setzen, POWER-key…) und Statusanforderungen (get - aktuelle Lautstärke, Now playing...)
-
ws - WebSocket, der auf port 8080 auf Updates der SoundTouch hört (Lautstärkeänderungen, Now playing…)
-
xml2js - parsen der empfangenen Daten
-
es6-promise - hab ich einfach so übernommen
Hab gestern noch den ioBroker samt meinem Adapter-Template und VS-Code debug Umgebung auf meinem Windows PC grob zum Laufen gebracht. Jetzt muss ich noch meinen Script-code einpflegen. Sobald ich in den nächsten Tagen eine erste Version am Laufen hab, kann ich ihn zu Testzwecken bereitstellen. Auch hier muss ich mich erst Schlau machen, wie man da vorgeht.
Bis demnächst. `
Interessant währe auch noch discovery zu implementieren: -
-
Du hast gesehen das es auf npm bereits Projekte gibt die das grundsätzlich machen ?
Welche npm-Projekte gäbe es da?
Erst einmal willkommen unter den Adapter-Entwicklern
Im Trello unter https://trello.com/c/BBntjcUq gibts auch schon eine Karte dafür.
Wäre cool wenn Du dich zu Trello anmeldest (und mir deinen Namen schickst, dann schalte ich dich frei). Dann kannst Du die Karte übernehmen.
Dort hatte ich auch mal Links gesammelt. Zusätzlich noch aus meiner privaten Sammlung:
https://github.com/CONNCTED/SoundTouch-NodeJS
https://github.com/CONNCTED/homebridge- … r/index.js
https://www.npmjs.com/package/homebridge-soundtouch
http://www.nikolaus-lueneburg.de/2017/0 ... ay-teil-2/
Wenn natürlich node-Libs vom npm nicht mehr aktualisiert werden ist das blöd. Neben einem Fork ginge aber mit dem Entwickler zu schreiben ob der es nicht auch aktualisieren will oder Pull-Requests einzureichen ... hilft dann allen
Wenn Du Fragen hast bitte Bescheid geben
-
Eine erste Version werde ich voraussichtlich am Mittwoch zur Verfügung stellen können.
Bin aktuell unterwegs und muss mich dann noch schlau machen, wie so ein pre-release funktioniert. GitHub?
Gesendet von meinem A0001 mit Tapatalk
-
Super. Vielen Dank. [emoji106]
Gesendet von meinem HUAWEI NXT-L29 mit Tapatalk