NEWS
Hue adapter
-
Diese Fehler (Error: ETIMEDOUT) bekomme ich, wenn die Bridge tatsächlich nicht erreicht werden kann. Ich nehme an, dass irgendwas mit der Config nicht stimmt, bei mir waren nach dem entfernen der npm version auch keine Config oder States mehr vorhanden.
1136_heizungslog.txt
1136_objektstruktur_wohnzimmer.json.txt -
Ich glaube langsam an Geister… :twisted:
Wollte gerade schreiben, dass ich die Bridge per Ping vom ioBroker Server erreiche und dass die externen Apps funktionieren. Stimmt, ist alles richtig. Dann noch einmal in den Adaptereinstellungen und siehe da. "Nun" steht da die falsche IP. Ich könnte schwören, dass da gestern noch die IP der Bridge drin stand... :mrgreen: :oops:
War vielleicht zu spät
Beim Start des Adapters wurden alle Lichter übernommen. Die Leerzeichen waren kein Problem. Sie wurde ausgetauscht gegen Unterstriche. Bluefox?
D.h. Unterstriche sehe ich unter Zustände, Leerzeichen bei den Objektnamen.
22 Hue Lichter werden alle 30 Sekunden gepollt. Prima!
Bei den Objekten fehlen die Werte.
Unter Zustände sehe ich Werte, die verändern sich auch (spätestens nach 30 Sekunden über das Polling).
Einschalten kann ich über Zustände eine Lampe allerdings nicht. Ich habe versucht den Datenpunkt "on" über Zustände auf true zu setzen. Kann man, die Lampe geht aber nicht an.
In den Objekten werden keine Werte angezeigt:
In den Zuständen werden Werte angezeigt. Änderungen dort werden aber nicht übernommen:
Wenn ich hier was ändere, werden nach dem Polling wieder die aktuellen Werte der Lampen eingetragen.Ich sehe in den Zuständen auch weniger Datenpunkte als bei den Objekten je Lampe.
Dafür sind die ganzen Warnungen weg, die ich vorher mit dem Adapter hatte
Eine generelle technische frage. Der Adapter pollt all 30 Sekunden. In anderen Apps werden die Werte in beiden Richtungen sofort angezeigt (meine ich zu mindestens). Pollen die in kürzeren Abständen oder wird dort ein anderes verfahren verwendet.
-
Wollte gerade schreiben, dass ich die Bridge per Ping vom ioBroker Server erreiche und dass die externen Apps funktionieren. Stimmt, ist alles richtig. Dann noch einmal in den Adaptereinstellungen und siehe da. "Nun" steht da die falsche IP. Ich könnte schwören, dass da gestern noch die IP der Bridge drin stand… :mrgreen: :oops:
War vielleicht zu spät `
Wenn ich Instanzen oder Adapter lösche lade ich danach die Adminseite einmal komplett neu, sonst sieht man häufiger alte Objekte. Ich nehme an, dass diese irgendwie lokal gecached werden.` > Beim Start des Adapters wurden alle Lichter übernommen. Die Leerzeichen waren kein Problem. Sie wurde ausgetauscht gegen Unterstriche. Bluefox?
D.h. Unterstriche sehe ich unter Zustände, Leerzeichen bei den Objektnamen.
[…] `
Du hast dann doch auch den Fehler mit den Leerzeichen, ich denke der ist auf die Funktionen setObject und setState zurückzuführen. Ersteres ersetzt die Leerzeichen nicht, letzteres schon. Dadurch hast du dann die Objekte mit Leerzeichen und die States mit Unterstrichen. Ich gucke nachher mal ob ich die Leerzeichen präventiv bei der Erstellung der Objekte ersetzen kann.> Eine generelle technische frage. Der Adapter pollt all 30 Sekunden. In anderen Apps werden die Werte in beiden Richtungen sofort angezeigt (meine ich zu mindestens). Pollen die in kürzeren Abständen oder wird dort ein anderes verfahren verwendet.
Sofort auch nicht, das ist mir aufgefallen als ich in ioBroker Farben geändert habe. Es dauert dann etwas bis es in der App ist, bis zu 10 Sekunden denke ich. Ich habe die Hue Api noch nicht durch, aber ich glaube eine andere Möglichkeit als selber abfragen gibt es nicht.EDIT:
für die Sache mit den Unterstrichen brauche ich erstmal den Rat von Bluefox. Einfach alle Leerzeichen zu ersetzen ist nämlich doof, da beim ändern von Werten ja wieder der Originalname benötigt wird, welcher dann aber nicht mehr zweifelsfrei hergestellt werden kann (wenn der Originalname schon Unterstriche verwendet). Wenn es nicht übertrieben viel Arbeit für dich ist würde ich dir raten erstmal die Bridge und die Lampen umzubenennen.
-
Bitte mit:
cd /opt/iobroker npm install https://github.com/ioBroker/ioBroker.hue/tarball/master --production
Testen und berichten ob es geht. 8-) `
Ok.Ok einfach npm install wird natürlich noch nicht die ganze arbeit machen. So sieht dann komplettes Skript aus:cd /opt/iobroker npm install https://github.com/ioBroker/ioBroker.hue/tarball/master --production iobroker restart hue iobroker upload hue
-
Ich habe mal versucht die Sache mit den Leerzeichen anzugehen. Bei mir Funktioniert es jetzt auch mit Leerzeichen bei Bridge und Lampen. Was nicht funktionieren kann: wenn einer Lampe "a_b" heißt und eine zweite "a b". Das würde dann zu zwei ioBroker Objekten mit gleichem Namen "a_b" führen.
-
super! das probiere ich direkt nach dem Frühstück.
Gesendet von iPhone mit Tapatalk
-
Ich bin begeistert!
Endlich kann ich hue nutzen
In den Objekten werden die Werte angezeigt. In den Zuständen kann ich de Werte verändern und sie greifen sofort.
Im Log habe ich den Level auf Debug stehen. Da habe ich vorher bei jeden Poll alle 30 Sekunden über 300 Werte von hue gesehen. Jetzt erscheinen diese (zum Glück nicht mehr). Sonst hätte ich noch einen Wunsch gehabt … im Webadmin ein Flag, mit dem man für den Adapter den Debug-Level ein-, bzw. ausschalten kann.
Klasse Arbeit! Ich danke Dir!
-
wie es aussieht funktioniert es bei mir!
Besteht die Hoffnung das die Gruppenfunktion noch eingefügt wird?
mfg
Arminhh
-
Das hört sich gut an. Kann ich eine neue Version veröffentlichen?
-
-
hue selbst unterstützt direkt Gruppen.
Man kann über hue de Lampen einzeln oder als Gruppe ansteuern.
http://www.developers.meethue.com/docum … e-concepts
Auszug:
Groups
You can also choose to control all your lights at once. For this you need to address the /groups/0 resource (this is a special group that always contains all lights). For groups we have the “action” resource (similar to the state resource for lights but containing the last values sent to the group rather than a state).
You can modify resources in the “action” resource in the same way as the state resource. So the following turns all lights off:
Address http://<bridge ip/address="">/api/<username>/groups/0/action
Body {"on":false}
Method PUT
And this sets them all to full brightness red.
Address http://<bridge ip/address="">/api/<username>/groups/0/action
Body {"on":true,"bri":255,"sat":255,"hue":0}
Method PUT</username></bridge></username></bridge>
-
Das wirft natürlich direkt Fragen auf. Kann man Lampen unterschiedlichen Typs gruppieren, z. B. Hue und Lux? Was passiert wenn man dann eine Farbe ändert? In ioBroker könnte man Gruppen anzeigen wie die einzelnen Lampen, dann allerdings zwingend mit allen Datenpunkten.
-
Das wirft natürlich direkt Fragen auf. Kann man Lampen unterschiedlichen Typs gruppieren, z. B. Hue und Lux? Was passiert wenn man dann eine Farbe ändert? `
Ich habe keine Lux. Ich glaube schon das man die auch mischen kann. Auch wenn es nur bedingt Sinn macht.
Die Lux werden dann nicht bunt.
In ioBroker könnte man Gruppen anzeigen wie die einzelnen Lampen, dann allerdings zwingend mit allen Datenpunkten. `
Wofür alle Datenpunkte? Man braucht doch nur für jede Gruppe die Datenpunkte (hue, sat, …).
Die Datenpunkte müssen auch nur geschrieben werden. Ein Auslesen macht keinen Sinn, da die Werte innerhalb einer Gruppe unterschiedlich sein können.
Mit der Gruppe werden die Werte dann für alle Lampen in der Gruppe angepasst.
-
Mit alle Datenpunkte meinte ich nur die Farben usw., die gibt es bei Lux nämlich sonst nicht.
Mit dem nur schreiben hast du recht. Allerdings kann man dann keine klassischen an/aus buttons nutzen sondern müsste einen Knopf für Gruppe an und einen für Gruppe aus bauen, da ja kein aktueller Status definiert ist.
-
Ich hatte gestern Abend noch gesehen, dass sich beim hue Adapter etwas getan hat Version: 0.3.0
Direkt installiert… Mit der Version habe ich aber leider folgendes Problem:
Ich setze über ein Script die hue Standardwerte, die eine Lampe auch hat, wenn man Sie über einen Schalter einschaltet.
`setState(hueLichter[i] + ".hue", 14922); setState(hueLichter[i] + ".sat", 144); setState(hueLichter[i] + ".effect", "none"); setState(hueLichter[i] + ".alert", "none"); if(isTimeInRange('23:00:00', '05:00:00')) { // Nachts mit verringerter Helligkeit setState(hueLichter[i] + ".bri", 100); } else { setState(hueLichter[i] + ".bri", 254); // Tagsüber mit voller Helligkeit }` Mit der neuen hue Adapter Version 0.3.0 bekommen damit die Lampen nicht Ihre Standardeinschaltfarbe, sondern werden rosa. Im Log sieht das wie folgt aus (Mehrfacheinträge, wg. mehrere Lampen entfernt): `~~[code]~~hue-0 2015-07-26 07:44:00 error error: Api Error: Internal error, 404 hue-0 2015-07-26 07:44:00 error error: Api Error: Internal error, 404 hue-0 2015-07-26 07:44:00 error error: Api Error: Internal error, 404 hue-0 2015-07-26 07:43:59 info final lightState: {"bri":254,"on":true} hue-0 2015-07-26 07:43:59 info final lightState: {"bri":254,"on":true,"alert":"none"} hue-0 2015-07-26 07:43:59 info final lightState: {"bri":254,"on":true,"effect":"none"} hue-0 2015-07-26 07:43:59 info final lightState: {"bri":254,"on":true,"hue":14922,"sat":144,"colormode":"hs"} hue-0 2015-07-26 07:43:59 info final lightState: {"bri":254,"on":true} hm-rpc-0 2015-07-26 07:43:59 info setValue ["GEQ0132484:1","STATE",true] BOOL javascript-0 2015-07-26 07:43:59 info script.js.LOGIK_Gästebad: hue Standard gesetzt [/code]` Info: Dann hatte ich noch die alten Objekte mit den Leerzeichen im Namen. Die wurden bei der Deinstallation des alten Adapters nicht gelöscht. Diese Objekte habe ich dann alle händisch gelöscht. [EDIT]: der 404 kommt nicht bei jeder Änderung. Dann noch ein paar gesammelte Fehlermeldungen aus dem Log, wenn der Adapter ein paar Minuten läuft (Meldungen dazwischen gelöscht): `~~[code]~~hue-0 2015-07-26 08:06:44 error error: Api Error: Internal error, 404 hue-0 2015-07-26 08:05:26 error error: Api Error: invalid/missing parameters in body hue-0 2015-07-26 08:05:25 error error: Api Error: invalid/missing parameters in body hue-0 2015-07-26 08:05:24 error Cannot get result for lightStatus13 hue-0 2015-07-26 08:05:24 error Error: ETIMEDOUT hue-0 2015-07-26 08:05:22 error error: Error: read ECONNRESET hue-0 2015-07-26 08:05:12 error error: Api Error: invalid/missing parameters in body hue-0 2015-07-26 08:05:11 error error: Error: read ECONNRESET [/code]`[/i][/i][/i][/i][/i][/i]
-
gehen die Lampen normalerweise nicht in den ct Modus mit 2700k (ct=369) ? Ich checke das später nochmal.
Dass die alten nicht gelöscht werden ist mir auch aufgefallen, da habe ich noch nichts verändert, das hat aber nichts mit den Leerzeichen zu tun sondern ist ganz allgemein ein Problem bei dem Adapter.
-
Ich habe das so verstanden, dass man drei Möglichkeiten hat die Lampen anzusteuern:
Mit folgenden Standardwerten:
1.) XY: [0.4595,0.4105]
2.) CT: 369
3.) hue: 14922 & sat: 144
Aus der hue API habe ich folgendes entnommen. Es macht immer nur Sinn die Datenpunkte einer der Varianten zu setzen.
Werden mehrere Datenpunkte bei einem Kommando vermischt (was ja in ioBroker nicht funktionieren würde, da diese nacheinander abgearbeitet werden), ist die Priorität:
1.) XY -> 2.) CT -> 3.) hue, sat
Ich hatte mich in meinem Script für Variante 3.) (auch für die Anpassungen im weiterem Verlauf des Scriptes) entschieden, da mir 1.) zu kompliziert ist und 2.) nicht die Farbanpassungen zulässt.
-
Noch ein Nachtrag. Vielleicht hilft es ja.
Vor dem Update stand beim Datenpunkt "colormode" immer "ct". Seit dem Update steht dort "hs".
Ich bin immer noch total begeistert, dass sich bei dem Adapter was tut. Hatte das Thema hue in Verbindung mit ioBroker schon fast aufgegeben gehabt. Danke dafür noch einmal !
[EDIT] Wenn ich einfach mal einen Wunsch platzieren darf. Beim Log wäre es schön, wenn die Lampennummer bei der Info "final lightState:" noch mit angezeigt würde. ich schalte mehrere Lampen auf einmal und habe dann zigmal einen identischen Logeintrag. Schön wäre auch, wenn man die Ausgabe über ein Flag im Webadmin steuern kann. Das Log ist sonst recht schnell mit Statusmeldungen geflutet
-
habe den Fehler gefunden, beim ändern von sat wurde hue auch auf den sat wert geändert.
-
Super!! Danke, danke
Kann ich das über npm updaten?