Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Blockly
    5. Stoppuhr

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    Stoppuhr

    This topic has been deleted. Only users with topic management privileges can see it.
    • liv-in-sky
      liv-in-sky @Schlagschatten last edited by

      @Schlagschatten

      wenn es nicht heute sein muss:

      warte noch ein wenig - ich konnte die laufzeit und den performancegebrauch noch etwas reduzieren - außerdem überlege ich noch an dem stopp und der wiederaufnahme. das werden dann mehrere änderungen

      dann ist es sinnvoller, wenn du noch mal alles importierst und die datenpunkte setzt - da übersieht man dann weniger

      ist das ok für dich

      1 Reply Last reply Reply Quote 0
      • S
        Schlagschatten last edited by

        Prima, dann warte ich noch und teste erstmal das aktuelle Script.
        Danke für die Mühe

        1 Reply Last reply Reply Quote 0
        • S
          Schlagschatten last edited by

          Zur Info: Habe das Script angepasst und es startet bei mir immer Zeitversetzt zwischen 10 und 30 sek.
          Die Zeit selbst läuft richtig.

          1 Reply Last reply Reply Quote 0
          • liv-in-sky
            liv-in-sky last edited by

            @Schlagschatten

            das ist richtig so -. ich wollte vermeiden, das es ein script gibt, das jede sekunde etwas ausführen muss - alle 30 sekunden wird die anzeige upgedatet und berechnet - braucht man die sekunden anzeige nicht wirklich, könnte man das auch auf alle 1 oder 2,5 minuten stellen - berechnung und die letzte anzeige ist immer richtig - kommt auf die benutzung an

            habe jetzt einen scriptversuch mit wiederaufnahme der startfunktion - kann man unendlich oft ausführen (start-stopp - start-stopp - ....). die zeiten sollten addiert werden
            für den reset muss vorher stopp gedrückt werden und dann erst der reset knopf

            es gibt noch 2 neue datenpunkte: "reset" als logiktyp und "berechnen" als zahlentyp

            Image 14.png

            widget:

            widget.txt

            script:

            script-stoppuhr.txt

            nach dem import bitte wieder alle datenpunkte einrichten (sorry dafür)
            ich hoffe, es gibt keine weiteren großen updates mehr

            rantanplan 1 Reply Last reply Reply Quote 0
            • rantanplan
              rantanplan @liv-in-sky last edited by rantanplan

              @liv-in-sky Hallo

              Habe mir gerade mal das Script importiert. Fleißig, fleißig☺

              Mir ist aufgefallen, dass da noch ein Block nicht verbunden ist.
              Bei so umfangreichen und in Blockly dann recht unübersichtlichen Scripten, habe ich mir angewöhnt das "Prüfe Icon" (Flagge) häufiger zu klicken. Da werden dann solche "Leichen" angezeigt.

              Dann steuerst Du die Datenpunkte immer direkt und davon eine ganze Menge, die dann noch teilweise von einander abhängig sind. Dazu jede Menge Timer und Verzögerungen.
              Man sollte bei solchen Sachen immer daran denken das JavaScript asyncron läuft!
              "steuere" wartet immer auf eine Bestätigung und während auf die Bestätigung gewartet wird, werden die nächsten Befehle schon ausgeführt.
              Da können die wildesten Sachen passieren und eine Fehlersuche kann einen dann wahnsinnig machen.

              Es ist zwar am Anfang viel Arbeit aber lege doch für die Datenpunkte jeweils eine lokale Variablen an.

              1. Aktuelle Werte in lokale Varible einlesen. (Funktion)
              2. Mit den lokalen Variablen arbeiten
              3. Lokale Variablen in Datenpunkte schreiben. (Funktion)

              Das ist hinterher viel leichter zu warten und Du kannst Dir die ganzen Verzögerungen sparen.

              Verstehe das bitte als Tipp und nicht als Kritik.

              liv-in-sky 2 Replies Last reply Reply Quote 0
              • liv-in-sky
                liv-in-sky @rantanplan last edited by

                i @rantanplan

                bin immer dankbar für wertvolle tipps ! werd das mal in ruhe anschauen

                im moment versuche ich das anlegen der datenpunkte hinzubekommen - funktioniert noch nicht richtig, die erzeugten datenpunkte machen irgendwelche probleme

                magst du mal drüber schauen - besonders die "numbers" machen ärger

                createState('STOPPUHR.Werte.Sekunden', { name: 'Sek', desc: 'Sek', type: 'number', unit: 'Sek' });
                createState('STOPPUHR.Werte.Minuten', { name: 'Minuten', desc: 'Sek', type: 'number', unit: 'Min' });
                createState('STOPPUHR.Werte.Stunden', { name: 'Stunden', desc: 'Sek', type: 'number', unit: 'Std' });
                createState('STOPPUHR.Werte.Tage', { name: 'Tage', desc: 'Sek', type: 'number', unit: 'Day' });
                createState('STOPPUHR.Berechnen', { name: 'Berechnen', desc: 'Sek', type: 'number', unit: 'mSek' });

                createState('STOPPUHR.Steuerung.Reset', { name: 'Reset', desc: 'Reset', type: 'boolean' });
                createState('STOPPUHR.Steuerung.Start', { name: 'Start', desc: 'Start', type: 'boolean' });
                createState('STOPPUHR.Steuerung.Stopp', { name: 'Stopp', desc: 'Stopp', type: 'boolean' });

                createState('STOPPUHR.Anfang', { name: 'Anfang', desc: 'Anfang in ms', type: 'string' })
                createState('STOPPUHR.Ausgabehilfe', { name: 'Ausgabehilfe', desc: 'Ausgabehilfe', type: 'string' })
                createState('STOPPUHR.Ende', { name: 'Ende', desc: 'Ende', type: 'string' })
                createState('STOPPUHR.Momentan', { name: 'Momentan', desc: 'Momentan', type: 'string' })

                rantanplan 1 Reply Last reply Reply Quote 0
                • liv-in-sky
                  liv-in-sky @rantanplan last edited by

                  @rantanplan sagte in Stoppuhr:

                  @liv-in-sky Hallo

                  Habe mir gerade mal das Script importiert. Fleißig, fleißig☺

                  Mir ist aufgefallen, dass da noch ein Block nicht verbunden ist.
                  Bei so umfangreichen und in Blockly dann recht unübersichtlichen Scripten, habe ich mir angewöhnt das "Prüfe Icon" (Flagge) häufiger zu klicken. Da werden dann solche "Leichen" angezeigt.

                  Dann steuerst Du die Datenpunkte immer direkt und davon eine ganze Menge, die dann noch teilweise von einander abhängig sind. Dazu jede Menge Timer und Verzögerungen.
                  Man sollte bei solchen Sachen immer daran denken das JavaScript asyncron läuft!
                  "steuere" wartet immer auf eine Bestätigung und während auf die Bestätigung gewartet wird, werden die nächsten Befehle schon ausgeführt.
                  Da können die wildesten Sachen passieren und eine Fehlersuche kann einen dann wahnsinnig machen.

                  Es ist zwar am Anfang viel Arbeit aber lege doch für die Datenpunkte jeweils eine lokale Variablen an.

                  1. Aktuelle Werte in lokale Varible einlesen. (Funktion)
                  2. Mit den lokalen Variablen arbeiten
                  3. Lokale Variablen in Datenpunkte schreiben. (Funktion)

                  Das ist hinterher viel leichter zu warten und Du kannst Dir die ganzen Verzögerungen sparen.

                  Verstehe das bitte als Tipp und nicht als Kritik.

                  ich will sicher sein, das weitergezählt wird, wenn script neustart oder iobroker neustart gemacht wird -

                  aber ich schau nochmal ob ich mehr variablen nutzen kann

                  rantanplan 1 Reply Last reply Reply Quote 0
                  • rantanplan
                    rantanplan @liv-in-sky last edited by

                    @liv-in-sky sagte in Stoppuhr:

                    ich will sicher sein, das weitergezählt wird, wenn script neustart oder iobroker neustart gemacht wird -

                    Das macht keinen Unterschied. Am Grundablauf ändert sich ja nichts. Der wird nur sicherer abgearbeitet.

                    1 Reply Last reply Reply Quote 0
                    • rantanplan
                      rantanplan @liv-in-sky last edited by

                      @liv-in-sky sagte in Stoppuhr:

                      magst du mal drüber schauen - besonders die "numbers" machen ärger

                      Ich habe den neuen Baustein noch nicht☺ und deshalb auch noch nicht testen können.
                      Da musste aufpassen, wenn Du den in Deinem Script einsetzen willst. Der ist noch nicht offiziell und viele haben den noch nicht.
                      Nimm doch das Beispiel hier aus dem Forum. (Ich weis jetzt nicht mehr vom wem es ist)

                      <xml xmlns="http://www.w3.org/1999/xhtml">
                        <variables>
                          <variable type="" id="FBRMInq]cmeK@PIx26k-">Name</variable>
                          <variable type="" id="b%fh+m8|cc?7K@#Bb(v=">Initialisierung</variable>
                          <variable type="" id="EVB$-0(O@vC6ip%213,5">Beschreibung</variable>
                          <variable type="" id="_J*8+6%%,[BJjhVu8jxZ">Type</variable>
                          <variable type="" id="_F3NI18eUQsGs2qt.T]">Rolle</variable>
                          <variable type="" id="J=uVGW;P^k@A!vhBphUm">smartName</variable>
                        </variables>
                        <block type="procedures_defcustomnoreturn" id="49kvg:%69IF}@lKJq@(J" x="-337" y="13">
                          <mutation statements="false">
                            <arg name="Name" varid="FBRMInq]cmeK@PIx26k-"></arg>
                            <arg name="Initialisierung" varid="b%fh+m8|cc?7K@#Bb(v="></arg>
                            <arg name="Beschreibung" varid="EVB$-0(O@vC6ip%213,5"></arg>
                            <arg name="Type" varid="_J*8+6%%,[BJjhVu8jxZ"></arg>
                            <arg name="Rolle" varid="_F3NI18eUQsGs2qt.T]"></arg>
                            <arg name="smartName" varid="J=uVGW;P^k@A!vhBphUm"></arg>
                          </mutation>
                          <field name="NAME">Variablen anlegen</field>
                          <field name="SCRIPT">Y3JlYXRlU3RhdGUoTmFtZSwgSW5pdGlhbGlzaWVydW5nLCB7DQogIG5hbWU6IEJlc2NocmVpYnVuZywNCiAgcmVhZDogdHJ1ZSwgDQogIHdyaXRlOiB0cnVlLCANCiAgdHlwZTogVHlwZSwgDQogIGRlZjogZmFsc2UsDQogIHJvbGU6IFJvbGxlLA0KICBzbWFydE5hbWU6IHNtYXJ0TmFtZQ0KfSk7DQo=</field>
                          <comment pinned="false" h="80" w="160">Beschreibe diese Funktion …</comment>
                        </block>
                        <block type="procedures_callcustomnoreturn" id="O45R/5Gw(j@)2M*_xdcB" x="-337" y="62">
                          <mutation name="Variablen anlegen">
                            <arg name="Name"></arg>
                            <arg name="Initialisierung"></arg>
                            <arg name="Beschreibung"></arg>
                            <arg name="Type"></arg>
                            <arg name="Rolle"></arg>
                            <arg name="smartName"></arg>
                          </mutation>
                          <value name="ARG0">
                            <block type="text" id="nSr7Hq~;DUU2#lB+Yj:}">
                              <field name="TEXT">MyVars.Test</field>
                            </block>
                          </value>
                          <value name="ARG1">
                            <block type="text" id="xlqa55O11o@{+#@Yj;%">
                              <field name="TEXT">true</field>
                            </block>
                          </value>
                          <value name="ARG2">
                            <block type="text" id="yEhqZqxh*}Ip8?yzOW7I">
                              <field name="TEXT">neuer Datenpunkt A</field>
                            </block>
                          </value>
                          <value name="ARG3">
                            <block type="text" id="sYAGk@@-Fz^fIDONX!/i">
                              <field name="TEXT">boolean</field>
                            </block>
                          </value>
                          <value name="ARG4">
                            <block type="text" id="/t]#6;-K%9u+eD1jG09@">
                              <field name="TEXT">button</field>
                            </block>
                          </value>
                          <value name="ARG5">
                            <block type="text" id="f?//#sV0P}x+|S.8nzy">
                              <field name="TEXT">SmartName A</field>
                            </block>
                          </value>
                        </block>
                      </xml>
                      
                      <xml xmlns="http://www.w3.org/1999/xhtml">
                        <variables>
                          <variable type="" id="FBRMInq]cmeK@PIx26k-">Name</variable>
                          <variable type="" id="b%fh+m8|cc?7K@#Bb(v=">Initialisierung</variable>
                          <variable type="" id="EVB$-0(O@vC6ip%213,5">Beschreibung</variable>
                          <variable type="" id="_J*8+6%%,[BJjhVu8jxZ">Type</variable>
                          <variable type="" id="_F3NI18eUQsGs2qt.T]">Rolle</variable>
                          <variable type="" id="J=uVGW;P^k@A!vhBphUm">smartName</variable>
                        </variables>
                        <block type="procedures_defcustomnoreturn" id="49kvg:%69IF}@lKJq@(J" x="-337" y="13">
                          <mutation statements="false">
                            <arg name="Name" varid="FBRMInq]cmeK@PIx26k-"></arg>
                            <arg name="Initialisierung" varid="b%fh+m8|cc?7K@#Bb(v="></arg>
                            <arg name="Beschreibung" varid="EVB$-0(O@vC6ip%213,5"></arg>
                            <arg name="Type" varid="_J*8+6%%,[BJjhVu8jxZ"></arg>
                            <arg name="Rolle" varid="_F3NI18eUQsGs2qt.T]"></arg>
                            <arg name="smartName" varid="J=uVGW;P^k@A!vhBphUm"></arg>
                          </mutation>
                          <field name="NAME">Variablen anlegen</field>
                          <field name="SCRIPT">Y3JlYXRlU3RhdGUoTmFtZSwgSW5pdGlhbGlzaWVydW5nLCB7DQogIG5hbWU6IEJlc2NocmVpYnVuZywNCiAgcmVhZDogdHJ1ZSwgDQogIHdyaXRlOiB0cnVlLCANCiAgdHlwZTogVHlwZSwgDQogIGRlZjogZmFsc2UsDQogIHJvbGU6IFJvbGxlLA0KICBzbWFydE5hbWU6IHNtYXJ0TmFtZQ0KfSk7DQo=</field>
                          <comment pinned="false" h="80" w="160">Beschreibe diese Funktion …</comment>
                        </block>
                        <block type="procedures_callcustomnoreturn" id="O45R/5Gw(j@)2M*_xdcB" x="-337" y="62">
                          <mutation name="Variablen anlegen">
                            <arg name="Name"></arg>
                            <arg name="Initialisierung"></arg>
                            <arg name="Beschreibung"></arg>
                            <arg name="Type"></arg>
                            <arg name="Rolle"></arg>
                            <arg name="smartName"></arg>
                          </mutation>
                          <value name="ARG0">
                            <block type="text" id="nSr7Hq~;DUU2#lB+Yj:}">
                              <field name="TEXT">MyVars.Test</field>
                            </block>
                          </value>
                          <value name="ARG1">
                            <block type="text" id="xlqa55O11o@{+#@Yj;%">
                              <field name="TEXT">true</field>
                            </block>
                          </value>
                          <value name="ARG2">
                            <block type="text" id="yEhqZqxh*}Ip8?yzOW7I">
                              <field name="TEXT">neuer Datenpunkt A</field>
                            </block>
                          </value>
                          <value name="ARG3">
                            <block type="text" id="sYAGk@@-Fz^fIDONX!/i">
                              <field name="TEXT">boolean</field>
                            </block>
                          </value>
                          <value name="ARG4">
                            <block type="text" id="/t]#6;-K%9u+eD1jG09@">
                              <field name="TEXT">button</field>
                            </block>
                          </value>
                          <value name="ARG5">
                            <block type="text" id="f?//#sV0P}x+|S.8nzy">
                              <field name="TEXT">SmartName A</field>
                            </block>
                          </value>
                        </block>
                      </xml>
                      

                      1 Reply Last reply Reply Quote 0
                      • liv-in-sky
                        liv-in-sky last edited by

                        @rantanplan

                        das ist kein kein baustein sondern ein js-script eingebundenen in blockly

                        Image 1.png

                        unter objekte werden sie angezeigt - aber z.b die vis findet sie nicht, obwhl ich den datenpunktpfad hinein kopiert habe - auch das script macht einen fehler mit missing datenpunkt

                        Image 3.png

                        rantanplan 1 Reply Last reply Reply Quote 0
                        • rantanplan
                          rantanplan @liv-in-sky last edited by

                          @liv-in-sky sagte in Stoppuhr:

                          @rantanplan

                          das ist kein kein baustein sondern ein js-script eingebundenen in blockly

                          Woher sollte ich das wissen?
                          Vielleicht noch ein Tipp? Wenn Du "etwas tun3" anklickst, kannst Du den Funktionsnamen in etwas "sprechendes" umbenennen. Kann man auch im Nachhinein ändern.

                          Datenpunkte die in einem Script neu anlegt, kann man nicht direkt beim ersten Start benutzen!
                          ioBroker braucht dazu etwas Zeit.
                          Stript Start, Script Stop, Script Start.

                          1 Reply Last reply Reply Quote 0
                          • S
                            Schlagschatten last edited by

                            Moin,
                            das war wohl wirklich eine Menge Arbeit. Habe das Script angepasst und läuft. Start/Stop und Reset auch. Prima und danke dafür. Da ich gestern das alte Script getestet habe und sich mein Pi bei den ersten beiden Versuchen verabschiedet hat, und ich im schlimmsten Fall bis zu 8 Zähler gleichzeitig laufen lasse möchte, denke ich das es Probleme mit der Performance geben könnte.
                            Der dritte Versuch funktionierte bis jetzt tadelos, bis auf auf den Zeitversatz von 10 sek., was nicht so wichtig ist. s.h. bild4.PNG

                            Vielleicht könnte man das Ganze ein wenig abspecken. Z.B. die Ausgabehilfen reduzieren, und nur das Start Datum/Zeit anzeigen lassen. Leider bin ich keine große Hilfe, da ich das Script nicht komplett verstehe.

                            Schaut doch bitte mal das Script von mir an, vielleicht könnt ihr mir sagen, was man besser machen kann. Das Script funktioniert soweit, nur Zeit läuft nach ca. 45min langsamer.

                            Vg Chris

                            1 Reply Last reply Reply Quote 0
                            • S
                              Schlagschatten last edited by

                              Frage: Woher kommt die Meldung?5.PNG

                              1 Reply Last reply Reply Quote 0
                              • liv-in-sky
                                liv-in-sky @Schlagschatten last edited by

                                @Schlagschatten sagte in Stoppuhr:

                                3.PNG

                                meist du dieses script ?

                                1 Reply Last reply Reply Quote 0
                                • liv-in-sky
                                  liv-in-sky last edited by

                                  @Schlagschatten sagte in Stoppuhr:

                                  Frage: Woher kommt die Meldung?5.PNG

                                  das sind fehlermeldungen für mich zum debuggen (fehlersuche)

                                  geh mit der rechten maustaste darauf und wähle deaktivieren aus - dann ist es weg - ich mache solche meldungen immer mit warnung oder error - weil dann farbig im log und einfacher zum finden - es sind aber keine warnungen oder fehler

                                  1 Reply Last reply Reply Quote 0
                                  • liv-in-sky
                                    liv-in-sky last edited by liv-in-sky

                                    nur zur klarstellung

                                    wenn du mehrere zähler benutzen willst, brauchst du für jeden zaehler ein eigenes script als stoppuhr

                                    ich programmiere gerade das automatische anlegen von den datenpunkten - dann kann viel einfacher mehrere solcher scripte installieren

                                    update kommt bald

                                    1 Reply Last reply Reply Quote 0
                                    • S
                                      Schlagschatten last edited by

                                      Ok, die Meldungen kommen von dir. Habe die Scripte schon angelegt, 8 für jeden Zähler. Da der Pi gerade wieder abgestürtzt ist, mache ich mir wirlich Sorgen.

                                      liv-in-sky 1 Reply Last reply Reply Quote 0
                                      • liv-in-sky
                                        liv-in-sky @Schlagschatten last edited by

                                        @Schlagschatten

                                        ich muss mmal einen überblick bekommen

                                        du nutzt 8 von meinen sripts !

                                        und du hast 8 skripte, die das ganze steuern - oder hast du meine scripts manipuliert ?

                                        liv-in-sky 1 Reply Last reply Reply Quote 0
                                        • S
                                          Schlagschatten last edited by

                                          Ich habe mit meinem Script angefangen und dementsprechen auch Scripte angelegt. Nun habe ich bei 2 Zählern das Script von dir am laufen. Erster Zähler das Script von gestern und der zweite Zähler von heute. Z.z. laufen nur die Scripte von dir. Und ich kann mir halt nicht vorstellen, das die Leistung ausreicht.6.PNG

                                          1 Reply Last reply Reply Quote 0
                                          • liv-in-sky
                                            liv-in-sky @liv-in-sky last edited by liv-in-sky

                                            @liv-in-sky

                                            wenn das so ist - bitte ändere die anlaufzeit, damit nicht alle gleichzeitig zu rechnen beginnen

                                            Image 4.png

                                            gehe in den zeitplan und ändere die 30 sekunden auf eine unterschiedliche primzahl z.b.

                                            also einer ist auf "alle 23 sekunden" der nächste auf " alle 29" dann 37, 41, 43, 47,53 - damit hast du keine überschneidungen bei der berechnung mehr

                                            und bitte erkläre mir, was du da eigentlich machst - nur um eine vorstellung zu bekommen, was das für wasserstände sind

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            401
                                            Online

                                            31.8k
                                            Users

                                            79.9k
                                            Topics

                                            1.3m
                                            Posts

                                            4
                                            130
                                            10192
                                            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