NEWS
Test Adapter Energiefluss v3.6.x GitHub/Latest
-
Hallo
Erstmal ein Lob zu dem Adapter.
Komme soweit damit klar, ist alles selbsterklärend.
Bei einer Sache bin ich zu doof
Ich nutze in der VIS die Schriftart "Jura-DemiBold" aus den google-fonts.Wie kann ich die einbinden bzw. wie ist der relative Pfad dazu?
Gruß
HappyUser20 -
@happyuser20 du müsstest den genauen Speicherort der eigentlichen Datei ermitteln und dann im Adapter eintragen.
Ich nutze die - selbst hochgeladene - SchriftartOxanium
und dann sieht das so aus:Hochladen über den VIS-Dateimanager!
Ggf. lädst du die Schrift einfach zusätzlich hoch, ist es diese hier: https://fonts2u.com/download/jura-demi-bold.font ?
Runterladen, entpacken, die .ttf darin per VIS in (d)einem Projekt hochladen und im Adapter angeben -
@skb ich fummel grad ein bißchen mit den farben rum.
wagen, oder auto...?- wenn ich versuche element4 zu verwenden, dann wirds nicht nach unten angezeigt...
-
@da_woody Danke für den Hinweis. Schaue ich mir an.
Damit die Elemente angezeigt werden, müssen sie auch entsprechende Datenpunkte haben und auch Platz in dem Frame -
@skb ist mir schon klar, aber im readme wird was unter verbrauch angezeigt.
darum dachte ich, wenn ich "benutzerdefiniertes Element 4:" nehme, daß dann da auch erscheint.
nach nochmaligem belinsen, das ist für die karre reserviert! 2-4 sind dann weiter rechts.
wollte mir dort eventuell die autarkie anzeigen lassen, mag aber nicht. egal, kann ich anders lösen... -
@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ß