NEWS
Test Adapter Energiefluss v3.6.x GitHub/Latest
-
@skb jetzt hab ich doch noch ein problem. das ding aktualisiert sich nicht.
wenn sich ein heizkörper aufdreht, bleibt der DP am selben stand von vorher.
zu ahnungslos wie ich das ding zeitnah zum aktualisieren bringe...
objektdaten:{ "common": { "name": "Heizen", "desc": "Manuell erzeugt", "role": "state", "type": "number", "read": true, "write": true, "def": 0 }, "type": "state", "native": {}, "from": "system.adapter.admin.0", "user": "system.user.admin", "ts": 1667044796614, "_id": "0_userdata.0.Heizen.Heizen", "acl": { "object": 1636, "state": 1636, "owner": "system.user.admin", "ownerGroup": "system.group.administrator" } }
-
@da_woody https://www.kreyenborg.koeln/wissensdatenbank/datenpunkt-auf-aenderung-ueberwachen/
Dieses musst Du dann um das Skript herum bauen.
In der nächsten Version wird es mehr Verbraucher geben - so kommen auch neue Elemente neben dem Auto unten und oben
Sorry, dies muss für die Heiz Datenpunkte sein ... nicht für den addieren.
-
@skb
Erstmal ein dickes Lob, der Adapter ist echt super.
Ich hätte da aber noch 2 - 3 Wünsche bei der Erweiterung. Da ich den Adapter zur optischen Anzeige meiner Balkonanlage nehme hätte ich bei den 4 freien Anzeigen gerne die möglichkeit- Überall auch noch % Werte einblenden ( wie bei Anzeige 1 für PKW2 vorgesehen ist)
- Bei allen 4 zusätzlich zur Anzeige W & kW über eine Unit2 Wh & kWh einzubinden.
- Wäre es nice wenn man bei den 4 Anzeigen über Datenpunkte die Animation steuern könnte.
So sollte es ungefähr hinterher aussehen. Nochmal Danke
-
@skb sorry, ich blick da bei JS nicht durch.
on({id: '0_userdata.0.Heizen.Heizen', change: 'any'}, function(obj) { // Hier die Aufgabe, was passiert, wenn sich der Datenpunkt ändert });
wird ja so nicht funktionieren, denk ich mal. muss ich das für jeden der 10 alias einbauen? z.b.
alias.0.Drassburg.Erdgeschoss.Waschküche.Heizung.Infra.Power
wie und wo muss ich das in das script einbauen? wär das nicht einfacher das script alle 10s durchlaufen lassen? wenn ja, wie?
-
Danke
-
@da_woody Du könntest ein Array erstellen.
let dps = ["hier", "kommen", "alle", "datenpunkte", "rein"];
Pro " ein Datenpunkt. Dann das Array in den "on" Kontext. Also worauf getriggert wird. Dann im on die function.
Ich schaue gegen Mittag mal, das ich einen Rechner in der Nähe habe
-
@da_woody So, ich habe zur Mittagszeit ein Rechner gefunden
Hier das Skript, welches Funktionieren sollte:
function listeWerte() { // Liste let werte = getObject("enum.functions.power_consumption").common.members; // Startwert 0 let wert = 0; // Schleife, um die Werte abzufragen for (var i = 0; i < werte.length; i++) { wert += getState(werte[i]).val; } setState("0_userdata.Heizen.Heizen", wert); } // Funktionsaufruf fuer das Abonnieren der Datenpunkte $('state(functions=power_consumption)').on(function (obj) { listeWerte(); });
-
@muppibaer Danke für deine Rückmeldung.
Diese Möglichkeiten sind aktuell nicht Plan des Adapters. Der Adapter zeigt live Werte der Verbraucher und Erzeuger an.
Werte, die über Wh oder kWh laufen, sind "historisch" (über den Tag oder Wochen/Jahre gesammelt). Das wäre wiederum eine Einheit, die sich mit "live"-Anzeige beisst.Wo man drüber nachdenken kann, ist, das die Tagesanzeige unterhalb des Elements erscheinen kann, wie es bei der Batterie der Fall ist. Der Adapter steuer sich selber und zeigt die Animationen an. Eine Steuerung über eigene Datenpunkte wäre zwar möglich, macht aber in meinen Augen keinen Sinn.
-
@skb senkfuss! mach dir keinen stress! funzen tuts tropsdem nüscht...
13:46:09.925 info javascript.0 (478) Start javascript script.js.common.Heizen.Heizen 13:46:10.142 info javascript.0 (478) script.js.common.Heizen.Heizen: registered 10 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions 13:47:10.863 warn javascript.0 (478) at listeWerte (script.js.common.Heizen.Heizen:13:5) 13:47:10.867 warn javascript.0 (478) at Object.<anonymous> (script.js.common.Heizen.Heizen:17:5) 13:47:25.766 warn javascript.0 (478) at listeWerte (script.js.common.Heizen.Heizen:13:5) 13:47:25.766 warn javascript.0 (478) at Object.<anonymous> (script.js.common.Heizen.Heizen:17:5) 13:47:40.765 warn javascript.0 (478) at listeWerte (script.js.common.Heizen.Heizen:13:5) 13:47:40.765 warn javascript.0 (478) at Object.<anonymous> (script.js.common.Heizen.Heizen:17:5) 13:47:55.760 warn javascript.0 (478) at listeWerte (script.js.common.Heizen.Heizen:13:5) 13:47:55.760 warn javascript.0 (478) at Object.<anonymous> (script.js.common.Heizen.Heizen:17:5)
-
function listeWerte() { // Liste let werte = getObject("enum.functions.power_consumption").common.members; // Startwert 0 let wert = 0; // Schleife, um die Werte abzufragen for (var i = 0; i < werte.length; i++) { wert += getState(werte[i]).val; } setState("0_userdata.0.Heizen.Heizen", wert); } // Funktionsaufruf fuer das Abonnieren der Datenpunkte $('state(functions=power_consumption)').on(function (obj) { listeWerte(); });
War ja klar, das da wieder die lästige Null fehlte
-
@skb
5x durchgelesen das script. -
@da_woody klappt es nun?
-
@skb na klar!
super, genau jetzt kommt auch ein update der shelly FW rein... -
@da_woody Prima, dann gönn' Dir
-
Huhu
Ich hätte gerne die Schrift und das Symbol in weiß, habe ich auch so eingestellt.
In der VIS wird das aber überlagert, da ist mehr gräulich.
Ist da was an den Einstellungen falsch oder ein Bug?
Gruß
-
@happyuser20 Ist kein Bug. Es ist eine generelle Einstellung im Adapter, die alle Elemente auf 70% durchsichtig schiebt.
Wird sich in der nächsten Version ändern lassen.
-
@skb hat er!
gibts ne möglichkeit auch die strichelängen zwischen den dingern zu definieren? gibt ja nur bei der dicke.
würds gern bißchen komprimieren...
-
@da_woody Du meinst, das die Elemente enger beieinander sind?
In der nächsten Version kommen da noch Elemente zwischen.Dann kannst du den rechts außen z.B. zwischen Produktion und Element 1 setzen.
-
@skb jap, ich wart schon auf die neue version. tropsdem wärs schön, wenn man die
in der länge definieren könnte.
so könnte man sich die aufteilung der elemente selbst basteln.
bin kein progger/dev, wird sicher nicht einfach sein... -
@da_woody Du wirst sehen, wie es später aussieht