Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Hardware
    4. SONOFF NSPanel mit Lovelace UI

    NEWS

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    SONOFF NSPanel mit Lovelace UI

    This topic has been deleted. Only users with topic management privileges can see it.
    • T
      TT-Tom @icebear last edited by

      @icebear sagte in SONOFF NSPanel mit Lovelace UI:

      { id: 'alias.0.NSPanel.GuestWifi.SWITCH'},

      der kann weg. den Switch sucht er sich alleine.

      icebear 1 Reply Last reply Reply Quote 2
      • icebear
        icebear @TT-Tom last edited by

        @tt-tom said in SONOFF NSPanel mit Lovelace UI:

        @icebear sagte in SONOFF NSPanel mit Lovelace UI:

        { id: 'alias.0.NSPanel.GuestWifi.SWITCH'},

        der kann weg. den Switch sucht er sich alleine.

        Ich danke dir, das wars.

        1 Reply Last reply Reply Quote 0
        • Rene55
          Rene55 @ticaki last edited by

          @ticaki Jepp, det funzt. Ich muss mich noch schwer in TS reinfuchsen. Danke.

          1 Reply Last reply Reply Quote 3
          • Rene55
            Rene55 @Armilar last edited by

            @armilar Gibt es für cardChart auch ein Script für die Aufbereitung der Daten? Ich wollte auch so etwas umsetzen wie 'ChartsDemo' für Gas oder 'Stromzähler L1+L2+L3'.

            Armilar T 2 Replies Last reply Reply Quote 0
            • Armilar
              Armilar Most Active Forum Testing @Rene55 last edited by Armilar

              @rene55

              https://github.com/joBr99/nspanel-lovelace-ui/wiki/ioBroker-Card-Definitionen-(Seiten)#cardchart-ab-ts-script-v370

              etwas unterhalb ist ein abgebildetes Blockly für influxDB2

              darunter der Link zum Blockly

              yAxisTicks sind im Gegensatz zur cardLChart nicht automatisiert und müssen definiert werden.

              Der Daten-String ist anders aufgebaut, da er keine Koordinaten, sondern Werte zum Zeitpunkt X enthält...

              theknut 1 Reply Last reply Reply Quote 1
              • T
                TT-Tom @Rene55 last edited by

                @rene55
                offiziell im Wiki für Influx nur als Blockly. BalkenChart oder auf meinem git als TypeScript.

                Rene55 1 Reply Last reply Reply Quote 1
                • Rene55
                  Rene55 @TT-Tom last edited by

                  @tt-tom Oh, sehr gut - schau ich mir sofort an.

                  1 Reply Last reply Reply Quote 0
                  • theknut
                    theknut @Armilar last edited by theknut

                    @armilar said in SONOFF NSPanel mit Lovelace UI:

                    @rene55

                    https://github.com/joBr99/nspanel-lovelace-ui/wiki/ioBroker-Card-Definitionen-(Seiten)#cardchart-ab-ts-script-v370

                    etwas unterhalb ist ein abgebildetes Blockly für influxDB2

                    darunter der Link zum Blockly

                    yAxisTicks sind im Gegensatz zur cardLChart nicht automatisiert und müssen definiert werden.

                    Der Daten-String ist anders aufgebaut, da er keine Koordinaten, sondern Werte zum Zeitpunkt X enthält...

                    gäbe es einen Grund, dass man/ich das nicht noch so umschreiben könnte, dass es auch berechnet wird?

                    Rene55 T 2 Replies Last reply Reply Quote 0
                    • Rene55
                      Rene55 @theknut last edited by

                      @theknut Das würde ich auch gerne in Anspruch nehmen. Meine aktuell generierten Balken zeigen alle ins Minus! 🤕 . Vielleicht hab ich auch noch nicht gerafft, welchen Datenpunkt ich nehmen muss.

                      T 1 Reply Last reply Reply Quote 0
                      • T
                        TT-Tom @Rene55 last edited by

                        @rene55
                        das kann auch der Bug bei der Card sein.

                        https://github.com/joBr99/nspanel-lovelace-ui/issues/934

                        SurfGargano created this issue in joBr99/nspanel-lovelace-ui

                        open [BUG] cardChart wird nicht richtig angezeigt wenn die Werte größer als 196 sind #934

                        Rene55 1 Reply Last reply Reply Quote 0
                        • T
                          TT-Tom @theknut last edited by

                          @theknut

                          kannst du gerne machen.

                          1 Reply Last reply Reply Quote 0
                          • Rene55
                            Rene55 @TT-Tom last edited by

                            @tt-tom Ich glaube, ich stell meine Balken erstmal zurück. Hab mir das Issue mal angesehen, sagt mir aber nix. Die Werte, die ich gerade zum Panel schicke sehen so aus:
                            Werte: 4304^3~9475~5080~7928~5684~5661~5531~5711^3~5511~5372~5647~5263~4955~4901~4862^4~4991~4812~4809~4860~4931~5912~9183^4~5116~9032~5595~
                            Scale: [0,2369,4738,7107,9476]

                            Armilar T 3 Replies Last reply Reply Quote 0
                            • Armilar
                              Armilar Most Active Forum Testing @Rene55 last edited by

                              @rene55

                              Rechne die Werte in kW um - dann sollte es passen... Die Skala schafft da keine W

                              Rene55 1 Reply Last reply Reply Quote 0
                              • Rene55
                                Rene55 @Armilar last edited by

                                @armilar Nochmals die (dumme) Frage: welche Daten muss ich da nehmen. Ziel ist, dass ich den Verbrauch vom Haus im Stundenraster sehe, damit ich erkennen kann, zu welcher Stunde die meiste Energie verbraten wird.

                                Armilar 1 Reply Last reply Reply Quote 0
                                • Armilar
                                  Armilar Most Active Forum Testing @Rene55 last edited by Armilar

                                  @rene55

                                  Das kommt darauf an, was du für DP's hast...

                                  Beispiel String:
                                  28^14:00~27~31~28~28^18:00~34~31~26~24^22:00~22~14~6~5^2:00~5~5~5~5^6:00~16~14~43~29^10:00~21~23~41

                                  Da die HMI keine Fließkommazahl verträgt, ist die Umrechnung nicht "/1000", sondern "/100"

                                  32f9986e-f777-4414-b947-d4c53bdefb15-image.png

                                  28 bedeutet dann 2,8
                                  27 bedeutet dann 2,7
                                  etc...

                                  Das ganze sieht dann so aus:

                                  6ed91ebb-bbac-47ff-b95a-4903e8f7faf4-image.png

                                  Nur im tausender Bereich kannst du keine Werte übermitteln... ist aber auch alles beschrieben...

                                  let CardChartExample: PageType = 
                                  {
                                      'type': 'cardChart',
                                      'heading': 'Stromzähler L1+L2+L3',
                                      'items': [{ 
                                                  id: 'alias.0.NSPanel_1.cardChart', 
                                                  yAxis: 'Leistung [kW]', 
                                                  yAxisTicks: [0,10,20,30],
                                                  onColor: Yellow
                                               }]
                                  };
                                  

                                  auch in der Y-Achse ist die Skalierung dann 10 = 1,0; 20 = 2,0 usw...

                                  1 Reply Last reply Reply Quote 1
                                  • T
                                    TT-Tom @Rene55 last edited by TT-Tom

                                    @rene55 okay, die sind eindeutig zu hoch.
                                    wenn du im Stunden Raster nutzen möchtest, kannst du mein Script so nicht nehmen, es arbeitet auf Tagesverbrauch.

                                    1 Reply Last reply Reply Quote 0
                                    • Armilar
                                      Armilar Most Active Forum Testing @Rene55 last edited by Armilar

                                      @rene55

                                      4304^3~9475~5080~7928~5684~5661~5531~5711^3~5511~5372~5647~5263~4955~4901~4862^4~4991~4812~4809~4860~4931~5912~9183^4~5116~9032~5595~

                                      Deine xAxisTicks sehen auch sehr merkwürdig aus...

                                      Was für Werte werden denn aggregiert... Sind das sekündliche Daten? Da stimmt irgendwas grundsätzlich nicht in deinem Script...

                                      Wenn die TypeScripts zu komplex für dich sind, dann verwende doch das Blockly... macht meines Erachtens genau das was du benötigst...

                                      T Rene55 2 Replies Last reply Reply Quote 0
                                      • T
                                        TT-Tom @Armilar last edited by

                                        @armilar

                                        Kommt von meinem Script, es rechnet aber mit Tagen/ Tagesverbrauch. Und die Ticks sind der Tag halt.

                                        Armilar 1 Reply Last reply Reply Quote 1
                                        • Armilar
                                          Armilar Most Active Forum Testing @TT-Tom last edited by Armilar

                                          @tt-tom

                                          schon klar, aber wir können unmöglich für jeden Anwendungsfall ein Script erstellen...

                                          Da muss man ggfs. schon mal etwas im influx-Admin testen, damit die grundsätzliche Abfrage stimmt... 😊

                                          Und auch ein Blockly lässt sich in JS wandeln, wenn es dann reiner Code sein soll...

                                          sieht dann wohl so aus:

                                          var sourceDP, targetDP, AxisXHours, AxisXTicks, Debug, flux, AxisTickCounter, i, queryStunde, queryOutput, queryValue, AxisTicksBool, result;
                                          
                                          
                                          // Example String
                                          // 7^2:00~7~6^4:00~6~7^6:00~0~7^8:00~5~1^10:00~1~10^12:00~5~6^14:00~8
                                          // Start Parameter
                                          sourceDP = 'sonoff.0.DZG_DWSB20_2H.DZG_Leistung_Aktuell';
                                          targetDP = '0_userdata.0.Test.cardChart.txt';
                                          AxisXHours = 24;
                                          AxisXTicks = 5;
                                          Debug = false;
                                          // Ende Parameter
                                          on({id: [].concat(sourceDP), change: "ne"}, async function (obj) {
                                            var value = obj.state.val;
                                            var oldValue = obj.oldState.val;
                                            flux = ['from(bucket: "iobroker")','|> range(start: -24h, stop: now())','|> filter(fn: (r) => r["_measurement"] == "',sourceDP,'")','|> filter(fn: (r) => r["_field"] == "value")','|> aggregateWindow(every: 1h, fn: mean, createEmpty: false)','|> yield(name: "mean")'].join('');
                                            sendTo("influxdb.1", "query", flux, async function (result) {
                                                AxisTickCounter = 0;
                                              var i_inc = 1;
                                              if (1 > AxisXHours) {
                                                i_inc = -i_inc;
                                              }
                                              for (i = 1; i_inc >= 0 ? i <= AxisXHours : i >= AxisXHours; i += i_inc) {
                                                AxisTickCounter = (typeof AxisTickCounter == 'number' ? AxisTickCounter : 0) + 1;
                                                queryStunde = getDateObject(getAttr(JSON.stringify(result, null, 2), (['result.0.',i,'._time'].join('')))).getHours();
                                                queryValue = Math.round(parseFloat(parseFloat(getAttr(JSON.stringify(result, null, 2), (['result.0.',i,'._value'].join(''))))) / 100);
                                                if (i == 1) {
                                                  AxisTicksBool = true;
                                                } else if (AxisTickCounter == AxisXTicks) {
                                                  AxisTicksBool = true;
                                                  AxisTickCounter = 1;
                                                } else {
                                                  AxisTicksBool = false;
                                                }
                                                if (i == AxisXHours) {
                                                  if (AxisTicksBool) {
                                                    queryOutput = [queryOutput,queryValue,'^',queryStunde,':00'].join('');
                                                  } else {
                                                    queryOutput = String(queryOutput) + String(queryValue);
                                                  }
                                                } else {
                                                  if (AxisTicksBool) {
                                                    queryOutput = [queryOutput,queryValue,'^',queryStunde,':00','~'].join('');
                                                  } else {
                                                    queryOutput = [queryOutput,queryValue,'~'].join('');
                                                  }
                                                }
                                                if (i == AxisXHours) {
                                                  queryStunde = (typeof queryStunde == 'number' ? queryStunde : 0) + 1;
                                                }
                                                if (Debug) {
                                                  console.log(([i,' - ',queryValue,' - ',queryStunde].join('')));
                                                }
                                              }
                                              setStateDelayed(targetDP, queryOutput, false, parseInt(((0) || "").toString(), 10), false);
                                              if (Debug) {
                                                console.log(queryOutput);
                                              }
                                              queryOutput = '';
                                              });
                                          });
                                          
                                          Rene55 1 Reply Last reply Reply Quote 1
                                          • Rene55
                                            Rene55 @Armilar last edited by

                                            @armilar Ich würde schon selbst versuchen, für meinen evtl. speziellen Anwendungsfall was eigenes zu machen. Dazu muss ich aber vorher verstanden haben, was was bedeutet.

                                            Beispiel String: 28^14:00~27~31~28~28
                                            Daraus entnehme ich dass um 14:00 Uhr ein Wert von 27 (also 2.7) angezeigt werden soll, um 15 Uhr 31, 16 Uhr 28 und um 17 Uhr auch 28, und dann kommt die nächste Sequenz ab 18:00 Uhr. Was bedeutet die 28 und das ^ ?

                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            632
                                            Online

                                            31.7k
                                            Users

                                            79.7k
                                            Topics

                                            1.3m
                                            Posts

                                            lovelace ui nspanel sonoff
                                            261
                                            7176
                                            4885670
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo