NEWS
Bose Soundtouch steuern
-
createState('BoseVolume', 10); createState('Bose_Preset_1', {type: 'boolean'}); createState('Bose_Preset_2', {type: 'boolean'}); createState('Bose_Preset_3', {type: 'boolean'}); function VolumeSetzen(pWert) { var BodyString = '<volume>' + pWert + '</volume>'; var request = require('request'); request.post({ url: 'http://192.168.100.90:8090/volume', body: BodyString }, function(error, response, body) { if (error) log(error, 'error'); }); } function PresetSetzen(pWert) { var BodyString = '<key state="release" sender="1LIVE">' + pWert + '</key>'; var request = require('request'); request.post({ url: 'http://192.168.100.90:8090/key', //body: '<volume>20</volume>' body: BodyString }, function(error, response, body) { if (error) log(error, 'error'); }); } function isTimeInRange(strLower, strUpper) { var now = new Date(); var lower = addTime(strLower); var upper = addTime(strUpper); var inRange = false; if (upper > lower) { // opens and closes in same day inRange = (now >= lower && now <= upper) ? true : false; } else { // closes in the following day inRange = (now >= upper && now <= lower) ? false : true; } return inRange; } function addTime(strTime) { var time = strTime.split(':'); var d = currentDate(); d.setHours(time[0]); d.setMinutes(time[1]); d.setSeconds(time[2]); return d; } function currentDate() { var d = new Date(); return new Date(d.getFullYear(), d.getMonth(), d.getDate()); } 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: "hm-rpc.0.MEQ0665905.1.STATE", val: true}, function(obj) { var lVon = "19:00:00"; var lBis = "22:00:00"; if (isTimeInRange(lVon, lBis)) { PresetSetzen('PRESET_1'); VolumeSetzen(25); } });
-
aha, der Teil ist falsch…
function PresetSetzen(pWert) { var BodyString = '<key state="release" sender="1LIVE">' + pWert + '</key>'; var request = require('request'); request.post({ url: 'http://192.168.100.90:8090/key', //body: '<volume>20</volume>' body: BodyString }, function(error, response, body) { if (error) log(error, 'error'); }); }
das 1LIVE darf da nicht stehen. Die Zeile muss so aussehen
var BodyString = '<key state="release" sender="Gabbo">' + pWert + '</key>';
sender="Gabbo" muss stehen bleiben
-
Sehr geil, läuft!
Top Arbeit von Dir! Danke tausend mal!
305_schlafzimmer_profilparameter-3profiles.txt -
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: -