NEWS
[gelöst] Script "Zählen von Fenstern" zeigt keine offenen Fenster an
-
@Negalein l
ö
sch mal deine aufz
ä
hlung raum und fenster komplett.
Starte den java adapter neu und dann f
ü
g mal nur ein fenster hinzu so wie bei mir und starte dann java nochmal neu.@crunchip sagte in [gel
ö
st] Script "Z
ä
hlen von Fenstern" zeigt keine offenen Fenster an:@Negalein l
ö
sch mal deine aufz
ä
hlung raum und fenster komplett.
Starte den java adapter neu und dann f
ü
g mal nur ein fenster hinzu so wie bei mir und starte dann java nochmal neu.kommt auch wieder nur dieses [object Object]


-
@crunchip sagte in [gel
ö
st] Script "Z
ä
hlen von Fenstern" zeigt keine offenen Fenster an:@Negalein l
ö
sch mal deine aufz
ä
hlung raum und fenster komplett.
Starte den java adapter neu und dann f
ü
g mal nur ein fenster hinzu so wie bei mir und starte dann java nochmal neu.kommt auch wieder nur dieses [object Object]


@Negalein seltsam, mihome eventuell noch neu starten, falls du namen ge
ä
ndert hast. Und dann nochmal java.
Das einzige was bei dir anders ist, ich habe fenster und t
ü
r getrennt in den enums und kleingeschrieben
Hast du auch mal das fenster auf und zu gemacht? -
@Negalein seltsam, mihome eventuell noch neu starten, falls du namen ge
ä
ndert hast. Und dann nochmal java.
Das einzige was bei dir anders ist, ich habe fenster und t
ü
r getrennt in den enums und kleingeschrieben
Hast du auch mal das fenster auf und zu gemacht?@crunchip sagte in [gel
ö
st] Script "Z
ä
hlen von Fenstern" zeigt keine offenen Fenster an:@Negalein seltsam, mihome eventuell noch neu starten, falls du namen ge
ä
ndert hast. Und dann nochmal java.
Das einzige was bei dir anders ist, ich habe fenster und t
ü
r getrennt in den enums und kleingeschriebenhat auch nichts gebracht.
Ich teste morgen mal mit fenster
-
@Negalein dem state selbst fehlt noch die raumzuweisung
Wenn ich nur
ü
bergeordnet den sensor zuweise, funktioniert die Abfrage bei mir zumindest nicht@crunchip sagte in [gel
ö
st] Script "Z
ä
hlen von Fenstern" zeigt keine offenen Fenster an:@Negalein dem state selbst fehlt noch die raumzuweisung
Wenn ich nur
ü
bergeordnet den sensor zuweise, funktioniert die Abfrage bei mir zumindest nichtWas heisst hier genau dem state selber? Machst du die Zuweisungen bei den Aufz
ä
hlungen oder bei den Objekten? M
ü
ssen alle Objekte sowohl Raum als auch Funktion haben oder nur der State? -
@crunchip sagte in [gel
ö
st] Script "Z
ä
hlen von Fenstern" zeigt keine offenen Fenster an:@Negalein dem state selbst fehlt noch die raumzuweisung
Wenn ich nur
ü
bergeordnet den sensor zuweise, funktioniert die Abfrage bei mir zumindest nichtWas heisst hier genau dem state selber? Machst du die Zuweisungen bei den Aufz
ä
hlungen oder bei den Objekten? M
ü
ssen alle Objekte sowohl Raum als auch Funktion haben oder nur der State?@kilasat ich stelle das direkt in den Objekten ein, ist einfacher und
ü
bersichtlicher, denn wenn du es
ü
ber Aufz
ä
hlung machst, verlierst du den
Ü
berblick, welche Sensoren du schon wo drin hast, da ja alles "is opened" heisst
einmal der Sensor selbst, erste Zeile und einmal der state, daher steht das in Raum und Funktion 2mal drin

enum.room.xyz und enum.functions.xyz sind bei mir alles klein geschrieben -
@crunchip sagte in [gel
ö
st] Script "Z
ä
hlen von Fenstern" zeigt keine offenen Fenster an:@Negalein l
ö
sch mal deine aufz
ä
hlung raum und fenster komplett.
Starte den java adapter neu und dann f
ü
g mal nur ein fenster hinzu so wie bei mir und starte dann java nochmal neu.kommt auch wieder nur dieses [object Object]


@Negalein @kilasat hatte heute Morgen auch seltsamerweise nur ein [object Object], als meine Haust
ü
r offen war. Alles andere wurde richtig angezeigt.
Habe mich dann auf die Suche gemacht.
Sensor aus den enums heraus gel
ö
scht, neu hinzugef
ü
gt, ohne Erfolg
Sensor komplett aus dem Mihome-Adapter gel
ö
scht und zugef
ü
gt, ohne Erfolg
Sensor aus dem Gateway gel
ö
scht und neu eingerichtet, ohne ErfolgHabe dann spa
ß
eshalber, den Sensor auf einen anderen Raum gelegt, und siehe da, er wird wieder richtig angezeigt.
Folge dessen, habe ich in meinem Fall dann Raum Flur enum.rooms.flur komplett gel
ö
scht, neu angelegt und Sensoren wieder entsprechend hinzugef
ü
gt, l
ä
uft wieder -
@crunchip sagte in [gel
ö
st] Script "Z
ä
hlen von Fenstern" zeigt keine offenen Fenster an:@Negalein l
ö
sch mal deine aufz
ä
hlung raum und fenster komplett.
Starte den java adapter neu und dann f
ü
g mal nur ein fenster hinzu so wie bei mir und starte dann java nochmal neu.kommt auch wieder nur dieses [object Object]


@Negalein
Die Funktion cacheSelectorState.each() ist so bei Deiner Namensgebung ungeeignet.
Ä
ndere mal incacheSelectorState.each(function(id, i) { // Schleife für jedes gefundenen Element *.state im Gewerk Fenster var status = getState(id).val; // Zustand *.state abfragen (jedes Element) var deviceId = id.substring(0, id.lastIndexOf(".")); var devicename = getObject(deviceId).common.name; var raumname = getObject(id, "rooms").enumNames[0]; // <---- NEU if (logging) { log('---Mi----'); log('Kanal: ' + devicename); log('Status: ' + status); } if (status) { // wenn Zustand = true, dann wird die Anzahl der Fenster hochgezählt ++anzahlLichterAn; textLichterAn.push(devicename); // Zu Array hinzufügen textRaum.push(raumname); // <---- NEU } ++anzahlLichter; // Zählt die Anzahl der vorhandenen Lichter unabhängig vom Status }); -
@Negalein
Die Funktion cacheSelectorState.each() ist so bei Deiner Namensgebung ungeeignet.
Ä
ndere mal incacheSelectorState.each(function(id, i) { // Schleife für jedes gefundenen Element *.state im Gewerk Fenster var status = getState(id).val; // Zustand *.state abfragen (jedes Element) var deviceId = id.substring(0, id.lastIndexOf(".")); var devicename = getObject(deviceId).common.name; var raumname = getObject(id, "rooms").enumNames[0]; // <---- NEU if (logging) { log('---Mi----'); log('Kanal: ' + devicename); log('Status: ' + status); } if (status) { // wenn Zustand = true, dann wird die Anzahl der Fenster hochgezählt ++anzahlLichterAn; textLichterAn.push(devicename); // Zu Array hinzufügen textRaum.push(raumname); // <---- NEU } ++anzahlLichter; // Zählt die Anzahl der vorhandenen Lichter unabhängig vom Status });@paul53 sagte in [gel
ö
st] Script "Z
ä
hlen von Fenstern" zeigt keine offenen Fenster an:@Negalein
Die Funktion cacheSelectorState.each() ist so bei Deiner Namensgebung ungeeignet.
Ä
ndere mal inDanke
Nur jetzt dein Script als eigenst
ä
ndiges Script, oder meins von oben erweitern?cacheSelectorState.each() finde ich in dem von mir alleine nirgends.
Nur mit Inhalt in den Klammern. -
@paul53 sagte in [gel
ö
st] Script "Z
ä
hlen von Fenstern" zeigt keine offenen Fenster an:@Negalein
Die Funktion cacheSelectorState.each() ist so bei Deiner Namensgebung ungeeignet.
Ä
ndere mal inDanke
Nur jetzt dein Script als eigenst
ä
ndiges Script, oder meins von oben erweitern?cacheSelectorState.each() finde ich in dem von mir alleine nirgends.
Nur mit Inhalt in den Klammern. -
@Negalein sagte:
eigenst
ä
ndiges Script, oder meins von oben erweitern?Weder noch. Die komplette Funktion cacheSelectorState.each(function(id, i) austauschen.
@paul53 sagte in [gel
ö
st] Script "Z
ä
hlen von Fenstern" zeigt keine offenen Fenster an:@Negalein sagte:
eigenst
ä
ndiges Script, oder meins von oben erweitern?Weder noch. Die komplette Funktion cacheSelectorState.each(function(id, i) austauschen.
Sorry f
ü
r die Fragen. JS ist ein Buch mit 1000 Siegeln f
ü
r mich.Also,
/* Status Zahl Fenster Homematic var cacheSelectorLevel = $('channel[state.id=*.STATE](functions="Fenster")'); Mi var cacheSelectorState = $('state[id=*.state](functions="Fenster")'); {1} */ var logging = false; var idAnzahlEin = 'javascript.0.Status.Fenster.Anzahl_auf', idAnzahl = 'javascript.0.Status.Fenster.Anzahl', idText = 'javascript.0.Status.Fenster.Text', idRaum = 'javascript.0.Status.Fenster.Raum', // <---- NEU idAnsage = 'javascript.0.Status.Fenster.Ansage';tauschen in
cacheSelectorState.each(function(id, i) { // Schleife für jedes gefundenen Element *.state im Gewerk Fenster var status = getState(id).val; // Zustand *.state abfragen (jedes Element) var deviceId = id.substring(0, id.lastIndexOf(".")); var devicename = getObject(deviceId).common.name; var raumname = getObject(id, "rooms").enumNames[0]; // <---- NEU if (logging) { log('---Mi----'); log('Kanal: ' + devicename); log('Status: ' + status); } if (status) { // wenn Zustand = true, dann wird die Anzahl der Fenster hochgezählt ++anzahlLichterAn; textLichterAn.push(devicename); // Zu Array hinzufügen textRaum.push(raumname); // <---- NEU } ++anzahlLichter; // Zählt die Anzahl der vorhandenen Lichter unabhängig vom Status }); -
@paul53 sagte in [gel
ö
st] Script "Z
ä
hlen von Fenstern" zeigt keine offenen Fenster an:@Negalein sagte:
eigenst
ä
ndiges Script, oder meins von oben erweitern?Weder noch. Die komplette Funktion cacheSelectorState.each(function(id, i) austauschen.
Sorry f
ü
r die Fragen. JS ist ein Buch mit 1000 Siegeln f
ü
r mich.Also,
/* Status Zahl Fenster Homematic var cacheSelectorLevel = $('channel[state.id=*.STATE](functions="Fenster")'); Mi var cacheSelectorState = $('state[id=*.state](functions="Fenster")'); {1} */ var logging = false; var idAnzahlEin = 'javascript.0.Status.Fenster.Anzahl_auf', idAnzahl = 'javascript.0.Status.Fenster.Anzahl', idText = 'javascript.0.Status.Fenster.Text', idRaum = 'javascript.0.Status.Fenster.Raum', // <---- NEU idAnsage = 'javascript.0.Status.Fenster.Ansage';tauschen in
cacheSelectorState.each(function(id, i) { // Schleife für jedes gefundenen Element *.state im Gewerk Fenster var status = getState(id).val; // Zustand *.state abfragen (jedes Element) var deviceId = id.substring(0, id.lastIndexOf(".")); var devicename = getObject(deviceId).common.name; var raumname = getObject(id, "rooms").enumNames[0]; // <---- NEU if (logging) { log('---Mi----'); log('Kanal: ' + devicename); log('Status: ' + status); } if (status) { // wenn Zustand = true, dann wird die Anzahl der Fenster hochgezählt ++anzahlLichterAn; textLichterAn.push(devicename); // Zu Array hinzufügen textRaum.push(raumname); // <---- NEU } ++anzahlLichter; // Zählt die Anzahl der vorhandenen Lichter unabhängig vom Status }); -
-
@Negalein
Wie sieht es aus, wenn das Gewerk "Fenster" und der Raum "Schlafzimmer" nur dem Datenpunkt und nicht auch dem Kanal zugeordnet werden ?@paul53 sagte in [gel
ö
st] Script "Z
ä
hlen von Fenstern" zeigt keine offenen Fenster an:@Negalein
Wie sieht es aus, wenn das Gewerk "Fenster" und der Raum "Schlafzimmer" nur dem Datenpunkt und nicht auch dem Kanal zugeordnet werden ?gleiches Ergebnis
-
@paul53 sagte in [gel
ö
st] Script "Z
ä
hlen von Fenstern" zeigt keine offenen Fenster an:@Negalein
Wie sieht es aus, wenn das Gewerk "Fenster" und der Raum "Schlafzimmer" nur dem Datenpunkt und nicht auch dem Kanal zugeordnet werden ?gleiches Ergebnis
@Negalein probier mal einen anderen Raum, vllt findest so den Fehler, bei mir ging pl
ö
tzlich der Raum Flur nicht mehr
zur Not auch enum.funktions.fenster auch mal l
ö
schen und neu anlegen -
@paul53 sagte in [gel
ö
st] Script "Z
ä
hlen von Fenstern" zeigt keine offenen Fenster an:@Negalein
Wie sieht es aus, wenn das Gewerk "Fenster" und der Raum "Schlafzimmer" nur dem Datenpunkt und nicht auch dem Kanal zugeordnet werden ?gleiches Ergebnis
-
@Negalein
Setze mal logging auf true und tausche die Zeilelog('Kanal: ' + devicename);gegen
log('Raum: ' + raumname);Was kommt im Log ? Version des JS-Adapters ?
@paul53 sagte in [gel
ö
st] Script "Z
ä
hlen von Fenstern" zeigt keine offenen Fenster an:Was kommt im Log ? Version des JS-Adapters ?
JS: 4.1.14
Log:
22:23:07.022 info javascript.0 Stop script script.js.common.Fensterzählen 22:23:07.187 info javascript.0 Start javascript script.js.common.Fensterzählen 22:23:07.187 info javascript.0 script.js.common.Fensterzählen: registered 2 subscriptions and 0 schedules 22:23:09.182 info javascript.0 script.js.common.Fensterzählen: Auslöser Skriptstart 22:23:09.182 info javascript.0 script.js.common.Fensterzählen: ++++++ Fenster Anzahl ++++ 22:23:09.182 info javascript.0 script.js.common.Fensterzählen: #### Mi ##### 22:23:09.182 info javascript.0 script.js.common.Fensterzählen: ---Mi---- 22:23:09.182 info javascript.0 script.js.common.Fensterzählen: Raum: [object Object] 22:23:09.182 info javascript.0 script.js.common.Fensterzählen: Status: false 22:23:09.182 info javascript.0 script.js.common.Fensterzählen: #### DIMMER ##### 22:23:09.182 info javascript.0 script.js.common.Fensterzählen: Text: 22:23:09.182 info javascript.0 script.js.common.Fensterzählen: Anzahl Fenster: 1 # davon Fenster offen: 0 -
@Negalein probier mal einen anderen Raum, vllt findest so den Fehler, bei mir ging pl
ö
tzlich der Raum Flur nicht mehr
zur Not auch enum.funktions.fenster auch mal l
ö
schen und neu anlegen@crunchip sagte in [gel
ö
st] Script "Z
ä
hlen von Fenstern" zeigt keine offenen Fenster an:@Negalein probier mal einen anderen Raum, vllt findest so den Fehler, bei mir ging pl
ö
tzlich der Raum Flur nicht mehr
zur Not auch enum.funktions.fenster auch mal l
ö
schen und neu anlegenhat leider nichts gebracht
-
@paul53 sagte in [gel
ö
st] Script "Z
ä
hlen von Fenstern" zeigt keine offenen Fenster an:Was kommt im Log ? Version des JS-Adapters ?
JS: 4.1.14
Log:
22:23:07.022 info javascript.0 Stop script script.js.common.Fensterzählen 22:23:07.187 info javascript.0 Start javascript script.js.common.Fensterzählen 22:23:07.187 info javascript.0 script.js.common.Fensterzählen: registered 2 subscriptions and 0 schedules 22:23:09.182 info javascript.0 script.js.common.Fensterzählen: Auslöser Skriptstart 22:23:09.182 info javascript.0 script.js.common.Fensterzählen: ++++++ Fenster Anzahl ++++ 22:23:09.182 info javascript.0 script.js.common.Fensterzählen: #### Mi ##### 22:23:09.182 info javascript.0 script.js.common.Fensterzählen: ---Mi---- 22:23:09.182 info javascript.0 script.js.common.Fensterzählen: Raum: [object Object] 22:23:09.182 info javascript.0 script.js.common.Fensterzählen: Status: false 22:23:09.182 info javascript.0 script.js.common.Fensterzählen: #### DIMMER ##### 22:23:09.182 info javascript.0 script.js.common.Fensterzählen: Text: 22:23:09.182 info javascript.0 script.js.common.Fensterzählen: Anzahl Fenster: 1 # davon Fenster offen: 0 -
@Negalein
Dann versuche mal das Log so zu
ä
ndern:log('Raum: ' + JSON.stringify(raumname));@paul53 sagte in [gel
ö
st] Script "Z
ä
hlen von Fenstern" zeigt keine offenen Fenster an:@Negalein
Dann versuche mal das Log so zu
ä
ndern:log('Raum: ' + JSON.stringify(raumname));[object Objekt] bleibt bestehen
Log:
javascript.0 2019-07-17 22:46:30.497 info script.js.common.Fensterzählen: Anzahl Fenster: 1 # davon Fenster offen: 0 javascript.0 2019-07-17 22:46:30.497 info script.js.common.Fensterzählen: Text: javascript.0 2019-07-17 22:46:30.497 info script.js.common.Fensterzählen: #### DIMMER ##### javascript.0 2019-07-17 22:46:30.497 info script.js.common.Fensterzählen: Status: false javascript.0 2019-07-17 22:46:30.497 info script.js.common.Fensterzählen: Raum: {"en":"Sleeping room","de":"Schlafzimmer","ru":"Спальня","pt":"Quarto de dormir","nl":"Slaapkamer","fr":"Chambre à coucher","it":"Camera da letto","es":"Dormitor javascript.0 2019-07-17 22:46:30.497 info script.js.common.Fensterzählen: ---Mi---- javascript.0 2019-07-17 22:46:30.497 info script.js.common.Fensterzählen: #### Mi ##### javascript.0 2019-07-17 22:46:30.496 info script.js.common.Fensterzählen: ++++++ Fenster Anzahl ++++ javascript.0 2019-07-17 22:46:30.496 info script.js.common.Fensterzählen: Auslösender Schalter: mihome.0.devices.magnet_158d0003139ea7.state: false javascript.0 2019-07-17 22:46:25.334 info script.js.common.Fensterzählen: Anzahl Fenster: 1 # davon Fenster offen: 1 javascript.0 2019-07-17 22:46:25.334 info script.js.common.Fensterzählen: Text: Schlafzimmer javascript.0 2019-07-17 22:46:25.334 info script.js.common.Fensterzählen: #### DIMMER ##### javascript.0 2019-07-17 22:46:25.333 info script.js.common.Fensterzählen: Status: true javascript.0 2019-07-17 22:46:25.333 info script.js.common.Fensterzählen: Raum: {"en":"Sleeping room","de":"Schlafzimmer","ru":"Спальня","pt":"Quarto de dormir","nl":"Slaapkamer","fr":"Chambre à coucher","it":"Camera da letto","es":"Dormitor javascript.0 2019-07-17 22:46:25.333 info script.js.common.Fensterzählen: ---Mi---- javascript.0 2019-07-17 22:46:25.333 info script.js.common.Fensterzählen: #### Mi ##### javascript.0 2019-07-17 22:46:25.333 info script.js.common.Fensterzählen: ++++++ Fenster Anzahl ++++ javascript.0 2019-07-17 22:46:25.332 info script.js.common.Fensterzählen: Auslösender Schalter: mihome.0.devices.magnet_158d0003139ea7.state: true
Hey! Du scheinst an dieser Unterhaltung interessiert zu sein, hast aber noch kein Konto.
Hast du es satt, bei jedem Besuch durch die gleichen Beiträge zu scrollen? Wenn du dich für ein Konto anmeldest, kommst du immer genau dorthin zurück, wo du zuvor warst, und kannst dich über neue Antworten benachrichtigen lassen (entweder per E-Mail oder Push-Benachrichtigung). Du kannst auch Lesezeichen speichern und Beiträge positiv bewerten, um anderen Community-Mitgliedern deine Wertschätzung zu zeigen.
Mit deinem Input könnte dieser Beitrag noch besser werden 💗
Registrieren Anmelden





