Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Entwicklung
    4. [UMFRAGE] Besteht Interesse an einem Octoprint Adapter

    NEWS

    • Monatsrückblick - April 2025

    • Minor js-controller 7.0.7 Update in latest repo

    • Save The Date: ioBroker@Smart Living Forum Solingen, 14.06.

    [UMFRAGE] Besteht Interesse an einem Octoprint Adapter

    This topic has been deleted. Only users with topic management privileges can see it.
    • ?
      A Former User @bishop last edited by

      @bishop also ich hätte Interesse an deinem Blockly. Danke schonmal im vorraus.

      1 Reply Last reply Reply Quote 0
      • G
        George_Best last edited by

        Hallo und ein gutes neues Jahr wünsche ich 😊

        Erstmal vielen, vielen Dank für den Adapter - kann ich gut gebrauchen😀

        Meine Frage: Wie kann ich die Datenpunkte bezüglich der Zeit (printtime; printtime_left) in hours:minutes:seconds umrechnen? Unix Timestamp bringt nicht wirklich sinnvolle Ergebnisse...

        Ich danke euch schon mal vielmals für Eure Unterstützung!

        G 1 Reply Last reply Reply Quote 0
        • G
          George_Best @George_Best last edited by

          @George_Best sagte in [UMFRAGE] Besteht Interesse an einem Octoprint Adapter:

          Hallo und ein gutes neues Jahr wünsche ich 😊

          Erstmal vielen, vielen Dank für den Adapter - kann ich gut gebrauchen😀

          Meine Frage: Wie kann ich die Datenpunkte bezüglich der Zeit (printtime; printtime_left) in hours:minutes:seconds umrechnen? Unix Timestamp bringt nicht wirklich sinnvolle Ergebnisse...

          Ich danke euch schon mal vielmals für Eure Unterstützung!

          Ok.... das war einfach zu einfach...
          Ich hab´s in der Doku von Octoprint gefunden - es sind einfach nur Sekunden 🙄 😊

          Webranger 1 Reply Last reply Reply Quote 0
          • Webranger
            Webranger @George_Best last edited by

            @George_Best Dann schreib doch auch die Lösung hier auf falls mal einer die Suche benutzt und genau das sucht 😉

            G 1 Reply Last reply Reply Quote 0
            • G
              George_Best @Webranger last edited by George_Best

              @Webranger sagte in [UMFRAGE] Besteht Interesse an einem Octoprint Adapter:

              @George_Best Dann schreib doch auch die Lösung hier auf falls mal einer die Suche benutzt und genau das sucht 😉

              Klar - sehr gerne:

              //************ Calculate objects in seconds to HH:MM:SS********************* */
              on({id: new RegExp('octoprint\\.0\\.printjob\\.progress\\.completion' + "|" + 'octoprint\\.0\\.printjob\\.progress\\.printtime'), change: "ne"}, function (obj) {
                var value = obj.state.val;
                var oldValue = obj.oldState.val;
                //console.log((getDateObject(getState("octoprint.0.printjob.progress.printtime_left").val).getMinutes()));
              
                  // variable for time left and job_time
                  // write value from object "printtime_left" (in seconds) to variable
                  var value_time_left;
                  var job_time
                  value_time_left = (getDateObject(getState("octoprint.0.printjob.progress.printtime_left").val));
                  job_time = (getDateObject(getState('octoprint.0.printjob.progress.printtime'/*Progress print time*/).val));
              
                  // Hours part 
                  var hours_value_time_left = Math.floor( value_time_left / 3600 );
                  var hours_job_time = Math.floor( job_time / 3600 );
              
                  // Minutes part 
                  var minutes_value_time_left = Math.floor( (value_time_left%3600) / 60 );
                  var minutes_job_time = Math.floor( (job_time%3600) / 60 );
              
                  // Seconds part 
                  var seconds_value_time_left = Math.floor( value_time_left%60 );
                  var seconds_job_time = Math.floor( job_time%60 );
              
                  // Will display time in 10:30:23 format
                  var formattedTime_value_time_left = hours_value_time_left + ':' + minutes_value_time_left + ':' + seconds_value_time_left;
                  var formattedTime_job_time = hours_job_time + ':' + minutes_job_time + ':' + seconds_job_time;
                  //console.log(formattedTime_value_time_left);
                  //console.log(formattedTime_job_time);
              
                  //write time_left to object
                  setState("javascript.0.3DPrinter.3DPrinter_Time_Left"/*3DPrinter_Time_Left*/, formattedTime_value_time_left, true);
                  setState('javascript.0.3DPrinter.3DPrinter_Job_Time'/*3DPrinter Job Time*/, formattedTime_job_time, true);
              });
              
                  //************ Text-to-Speech on Chromecast********************* */
              var  timeout;
              on({id: 'octoprint.0.printjob.progress.completion'/*Progress completion*/, change: "ne"}, function (obj) {
                  //console.log(getState("octoprint.0.printjob.progress.completion").val);
                  var value = obj.state.val;
                  var oldValue = obj.oldState.val;
                      if (getState("octoprint.0.printjob.progress.completion").val == 100) {
                          setState("sayit.0.tts.text", "de;" + '3D Drucker ist fertig');
                          sendTo("email.0", "send", {
                              text: '3D Drucker ist fertig',
                              to: 'xxxxxxxxxxxxx@gmail.com',
                              subject: '3D Drucker ist fertig'
                          });
                      }
                  });
              

              Das Script holt die beiden Datenpunkte des octoprint-Adapters "printtime_left" und "printtime", wandelt diese ins Format HH:MM:SS um und schreibt diese dann in zwei (zuvor manuell erstellte) Datenpunkte "3DPrinter_Time_Left" und "3DPrinter_Job_Time".
              Außerdem gebe ich noch "3D Drucker fertig" über Google Home (Chromecast) aus und schicke mir eine Email, sobald der Datenpunkt "completion" bei 100 ist.

              Webranger joergeli 2 Replies Last reply Reply Quote 0
              • B
                bishop last edited by bishop

                @telekom0815
                sorry für die Verspätung hier der Export von meinem Script.
                Gibt bestimmt noch fehler...Feedback erwünscht

                <xml xmlns="http://www.w3.org/1999/xhtml">
                  <variables>
                    <variable type="undefined" id="timeout2">timeout2</variable>
                    <variable type="undefined" id="timeout">timeout</variable>
                  </variables>
                  <block type="procedures_defcustomnoreturn" id="L)jSk0=?1664IBxAbQ${" x="413" y="-437">
                    <mutation statements="false"></mutation>
                    <field name="NAME">Licht</field>
                    <field name="SCRIPT">bm9kZV9zc2ggPSByZXF1aXJlKCdub2RlLXNzaCcpOw0Kc3NoID0gbmV3IG5vZGVfc3NoKCk7DQpzc2guY29ubmVjdCh7DQogIGhvc3Q6ICcxOTIuMTY4LjEuOTAnLA0KICB1c2VybmFtZTogJ3BpJywNCiAgcGFzc3dvcmQ6ICdkc2xmbGF0MjM4OCcNCn0pLnRoZW4oKCkgPT4gew0KICBzc2guZXhlY0NvbW1hbmQoInN1ZG8gLi9sZWRyZWxhaXMuc2giKTsNCn0p</field>
                    <comment pinned="false" h="80" w="160">Beschreibe diese Funktion …</comment>
                  </block>
                  <block type="procedures_defcustomnoreturn" id=".(*orQFL])}0jxjU)4Y?" x="412" y="-413">
                    <mutation statements="false"></mutation>
                    <field name="NAME">shutdown</field>
                    <field name="SCRIPT">bm9kZV9zc2ggPSByZXF1aXJlKCdub2RlLXNzaCcpOw0Kc3NoID0gbmV3IG5vZGVfc3NoKCk7DQpzc2guY29ubmVjdCh7DQogIGhvc3Q6ICcxOTIuMTY4LjEuOTAnLA0KICB1c2VybmFtZTogJ3VzZXInLA0KICBwYXNzd29yZDogJ3Bhc3N3b3JkJw0KfSkudGhlbigoKSA9PiB7DQogIHNzaC5leGVjQ29tbWFuZCgic3VkbyBzaHV0ZG93biBub3ciKTsNCn0p</field>
                    <comment pinned="false" h="80" w="160">Beschreibe diese Funktion …</comment>
                  </block>
                  <block type="on_ext" id="g{.@~ZsR7(G/6laF9/Q#" x="413" y="-362">
                    <mutation items="1"></mutation>
                    <field name="CONDITION">ne</field>
                    <field name="ACK_CONDITION"></field>
                    <value name="OID0">
                      <shadow type="field_oid" id="y~e.v;I`cDBP?LqcT?!U">
                        <field name="oid">sonoff.0.Pow_62_3dDrucker.POWER</field>
                      </shadow>
                    </value>
                    <statement name="STATEMENT">
                      <block type="controls_if" id="bq*f7B;^s0VIfH13or9d" collapsed="true">
                        <value name="IF0">
                          <block type="logic_compare" id="`)MWIWh=Tk#m/[rK2ME1">
                            <field name="OP">EQ</field>
                            <value name="A">
                              <block type="get_value" id="pI^wpX~rmS#KtR^3V#gW">
                                <field name="ATTR">val</field>
                                <field name="OID">sonoff.0.Pow_62_3dDrucker.POWER</field>
                              </block>
                            </value>
                            <value name="B">
                              <block type="logic_boolean" id="Dypo~(SMny:}4_n1*v;o">
                                <field name="BOOL">TRUE</field>
                              </block>
                            </value>
                          </block>
                        </value>
                        <statement name="DO0">
                          <block type="update" id=")N[JwuYwCAbha*=m~vb#">
                            <mutation delay_input="false"></mutation>
                            <field name="OID">javascript.0.schalter.3d_drucker_rpi_shutdown</field>
                            <field name="WITH_DELAY">FALSE</field>
                            <value name="VALUE">
                              <block type="logic_boolean" id="SMqJ),5=rxG.tWDzQFHc">
                                <field name="BOOL">TRUE</field>
                              </block>
                            </value>
                          </block>
                        </statement>
                      </block>
                    </statement>
                    <next>
                      <block type="on_ext" id="3BKaKP9u)QPYQ%fo_H*,">
                        <mutation items="1"></mutation>
                        <field name="CONDITION">ne</field>
                        <field name="ACK_CONDITION"></field>
                        <value name="OID0">
                          <shadow type="field_oid" id="/MXW2KlV+JX0__Wts%NE">
                            <field name="oid">javascript.0.schalter.3d_drucker_rpi_shutdown</field>
                          </shadow>
                        </value>
                        <statement name="STATEMENT">
                          <block type="controls_if" id="Y1]RH9fVR^;wJ8Phe!+c" collapsed="true">
                            <mutation elseif="1"></mutation>
                            <value name="IF0">
                              <block type="logic_compare" id="RYf.b.+|Wi,5*:d}+q|h">
                                <field name="OP">EQ</field>
                                <value name="A">
                                  <block type="get_value" id="HcDY3c]hT.Ge6sRml(#}">
                                    <field name="ATTR">val</field>
                                    <field name="OID">javascript.0.schalter.3d_drucker_rpi_shutdown</field>
                                  </block>
                                </value>
                                <value name="B">
                                  <block type="logic_boolean" id="id8SS.AOEpq,U9L#tYyw">
                                    <field name="BOOL">TRUE</field>
                                  </block>
                                </value>
                              </block>
                            </value>
                            <statement name="DO0">
                              <block type="control" id="jhq_UY7!XJ^;i,.Aw16/">
                                <mutation delay_input="false"></mutation>
                                <field name="OID">sonoff.0.Pow_62_3dDrucker.POWER</field>
                                <field name="WITH_DELAY">FALSE</field>
                                <value name="VALUE">
                                  <block type="logic_boolean" id="@7s`u,CbB44u*8Kc;{fW">
                                    <field name="BOOL">TRUE</field>
                                  </block>
                                </value>
                              </block>
                            </statement>
                            <value name="IF1">
                              <block type="logic_compare" id="H%jbito/W8rkjv5!omm(">
                                <field name="OP">EQ</field>
                                <value name="A">
                                  <block type="get_value" id="PZw8r5)!Jn`t%p0d}Ij2">
                                    <field name="ATTR">val</field>
                                    <field name="OID">javascript.0.schalter.3d_drucker_rpi_shutdown</field>
                                  </block>
                                </value>
                                <value name="B">
                                  <block type="logic_boolean" id="Uee7X#UslzxU]GjttWZ=">
                                    <field name="BOOL">FALSE</field>
                                  </block>
                                </value>
                              </block>
                            </value>
                            <statement name="DO1">
                              <block type="procedures_callcustomnoreturn" id="=#Q;NN(ZtFbYLwV?u3e7">
                                <mutation name="shutdown"></mutation>
                              </block>
                            </statement>
                          </block>
                        </statement>
                        <next>
                          <block type="on_ext" id=".lRhF1)wPIdz.yV?=jUi">
                            <mutation items="1"></mutation>
                            <field name="CONDITION">ne</field>
                            <field name="ACK_CONDITION"></field>
                            <value name="OID0">
                              <shadow type="field_oid" id="rD1iSaDm.=Mn4;HAX!SZ">
                                <field name="oid">octoprint.0.info.connection</field>
                              </shadow>
                            </value>
                            <statement name="STATEMENT">
                              <block type="controls_if" id="tceui~t=M5aK2PhN@AiR" collapsed="true">
                                <value name="IF0">
                                  <block type="logic_compare" id="B#)x#N+vJUarGf^s_6{+">
                                    <field name="OP">EQ</field>
                                    <value name="A">
                                      <block type="get_value" id="JW=V4G%F[o4KPRMMtzl^">
                                        <field name="ATTR">val</field>
                                        <field name="OID">octoprint.0.info.connection</field>
                                      </block>
                                    </value>
                                    <value name="B">
                                      <block type="logic_boolean" id="axn9[abqsx%lro~{tV2(">
                                        <field name="BOOL">FALSE</field>
                                      </block>
                                    </value>
                                  </block>
                                </value>
                                <statement name="DO0">
                                  <block type="timeouts_settimeout" id="SM?$]M-Vb4}!n0$moo8W">
                                    <field name="NAME">timeout2</field>
                                    <field name="DELAY">2</field>
                                    <field name="UNIT">min</field>
                                    <statement name="STATEMENT">
                                      <block type="control" id="7BJy+SZfqlC-1?uxgv}T">
                                        <mutation delay_input="false"></mutation>
                                        <field name="OID">sonoff.0.Pow_62_3dDrucker.POWER</field>
                                        <field name="WITH_DELAY">FALSE</field>
                                        <value name="VALUE">
                                          <block type="logic_boolean" id="Ae?^~gu-?tkI?Zf=l|05">
                                            <field name="BOOL">FALSE</field>
                                          </block>
                                        </value>
                                      </block>
                                    </statement>
                                  </block>
                                </statement>
                              </block>
                            </statement>
                            <next>
                              <block type="comment" id="/bgI6x_9=9MOPSSqT5y8">
                                <field name="COMMENT">Druck abbrechen</field>
                                <next>
                                  <block type="on_ext" id="]`}dT6ao59[g0Zi7-8JR">
                                    <mutation items="1"></mutation>
                                    <field name="CONDITION">ne</field>
                                    <field name="ACK_CONDITION"></field>
                                    <value name="OID0">
                                      <shadow type="field_oid" id="LBh%wWJ6EIHSB8k6[F1-">
                                        <field name="oid">zigbee.0.00158d0001e832d0.click</field>
                                      </shadow>
                                    </value>
                                    <statement name="STATEMENT">
                                      <block type="controls_if" id="um*;L|HSsNG~}n_7RvJl" collapsed="true">
                                        <mutation elseif="1"></mutation>
                                        <value name="IF0">
                                          <block type="logic_operation" id="p,OaYSoY:[YL+Zf=9,)L">
                                            <field name="OP">AND</field>
                                            <value name="A">
                                              <block type="logic_compare" id="AHZ~4BmMwj*u+R59IT3{">
                                                <field name="OP">EQ</field>
                                                <value name="A">
                                                  <block type="get_value" id="D}UcxJ1Sk=PqTRKjUY=D">
                                                    <field name="ATTR">val</field>
                                                    <field name="OID">zigbee.0.00158d0001e832d0.click</field>
                                                  </block>
                                                </value>
                                                <value name="B">
                                                  <block type="logic_boolean" id="OD)9Sh(MuozULEVN^)`#">
                                                    <field name="BOOL">TRUE</field>
                                                  </block>
                                                </value>
                                              </block>
                                            </value>
                                            <value name="B">
                                              <block type="logic_compare" id="#.1FXN4{StvBom4=GJya">
                                                <field name="OP">EQ</field>
                                                <value name="A">
                                                  <block type="get_value" id="hv||~J_bAqtb~m:Ba:ql">
                                                    <field name="ATTR">val</field>
                                                    <field name="OID">octoprint.0.printer_status</field>
                                                  </block>
                                                </value>
                                                <value name="B">
                                                  <block type="text" id="C-KJ-qgD/GSTwX-,ND*L">
                                                    <field name="TEXT">Printing</field>
                                                  </block>
                                                </value>
                                              </block>
                                            </value>
                                          </block>
                                        </value>
                                        <statement name="DO0">
                                          <block type="control" id="Qevct?*ro((VFE4%#+o0">
                                            <mutation delay_input="false"></mutation>
                                            <field name="OID">octoprint.0.command.printjob</field>
                                            <field name="WITH_DELAY">FALSE</field>
                                            <value name="VALUE">
                                              <block type="text" id="3y;+U@6WBcueR56Jy/oe">
                                                <field name="TEXT">cancel</field>
                                              </block>
                                            </value>
                                          </block>
                                        </statement>
                                        <value name="IF1">
                                          <block type="logic_operation" id="]3rHvQ||5QnEOLf5+ymh">
                                            <field name="OP">AND</field>
                                            <value name="A">
                                              <block type="logic_compare" id="?K]y+Tk%R|5-`ABPnU9U">
                                                <field name="OP">EQ</field>
                                                <value name="A">
                                                  <block type="get_value" id="l?oBL,{[]BYF*hzx/.BP">
                                                    <field name="ATTR">val</field>
                                                    <field name="OID">zigbee.0.00158d0001e832d0.click</field>
                                                  </block>
                                                </value>
                                                <value name="B">
                                                  <block type="logic_boolean" id="ds!DH]e(AJC2V3Fo;SL)">
                                                    <field name="BOOL">TRUE</field>
                                                  </block>
                                                </value>
                                              </block>
                                            </value>
                                            <value name="B">
                                              <block type="logic_compare" id="^:CngW9,,CgWBy*~XRm-">
                                                <field name="OP">EQ</field>
                                                <value name="A">
                                                  <block type="get_value" id="fM[uY=Ev^{lka.T7SMqR">
                                                    <field name="ATTR">val</field>
                                                    <field name="OID">octoprint.0.printer_status</field>
                                                  </block>
                                                </value>
                                                <value name="B">
                                                  <block type="text" id="?H0rQWj/PzXC).^mAZrL">
                                                    <field name="TEXT">Operational</field>
                                                  </block>
                                                </value>
                                              </block>
                                            </value>
                                          </block>
                                        </value>
                                        <statement name="DO1">
                                          <block type="control" id="XU3I,=yJ]psvvkPEN~h5">
                                            <mutation delay_input="false"></mutation>
                                            <field name="OID">octoprint.0.command.printjob</field>
                                            <field name="WITH_DELAY">FALSE</field>
                                            <value name="VALUE">
                                              <block type="text" id="Rno,oYD.kNna/wHj6s#5">
                                                <field name="TEXT">start</field>
                                              </block>
                                            </value>
                                          </block>
                                        </statement>
                                      </block>
                                    </statement>
                                    <next>
                                      <block type="comment" id="%H|c6ZCu?0Jj|mpe!fk/">
                                        <field name="COMMENT">temp einstellung button</field>
                                        <next>
                                          <block type="on_ext" id="~hcVKGpL=/72CVP6XSlJ">
                                            <mutation items="1"></mutation>
                                            <field name="CONDITION">ne</field>
                                            <field name="ACK_CONDITION"></field>
                                            <value name="OID0">
                                              <shadow type="field_oid" id="|-EXqAGm!ND+A-N;ddc_">
                                                <field name="oid">zigbee.0.00158d0001e832d0.double_click</field>
                                              </shadow>
                                            </value>
                                            <statement name="STATEMENT">
                                              <block type="controls_if" id="_MO0.wji;GsHR@M1g|8)" collapsed="true">
                                                <mutation elseif="1"></mutation>
                                                <value name="IF0">
                                                  <block type="logic_operation" id="xh-(v9+.g5*!4Y:4I,Zk">
                                                    <field name="OP">AND</field>
                                                    <value name="A">
                                                      <block type="logic_compare" id="_[MEoh(-#DiY{q4e7fG*">
                                                        <field name="OP">EQ</field>
                                                        <value name="A">
                                                          <block type="get_value" id="nwK%{g@#-dH},r[Xi@6M">
                                                            <field name="ATTR">val</field>
                                                            <field name="OID">zigbee.0.00158d0001e832d0.double_click</field>
                                                          </block>
                                                        </value>
                                                        <value name="B">
                                                          <block type="logic_boolean" id="ul{tzs2Gz@IuX[rZlOFE">
                                                            <field name="BOOL">TRUE</field>
                                                          </block>
                                                        </value>
                                                      </block>
                                                    </value>
                                                    <value name="B">
                                                      <block type="logic_operation" id="sL7w4jqN6vak2H4%*aoL" inline="false">
                                                        <field name="OP">AND</field>
                                                        <value name="A">
                                                          <block type="logic_compare" id="Y@{QMl3GeuOwy9kBa21W">
                                                            <field name="OP">LTE</field>
                                                            <value name="A">
                                                              <block type="get_value" id="B4iG!1%|qFlp!s295m%Z">
                                                                <field name="ATTR">val</field>
                                                                <field name="OID">octoprint.0.temperature.bed.target</field>
                                                              </block>
                                                            </value>
                                                            <value name="B">
                                                              <block type="math_number" id="3V%|drS@FVJ`:j~3?tz/">
                                                                <field name="NUM">0</field>
                                                              </block>
                                                            </value>
                                                          </block>
                                                        </value>
                                                        <value name="B">
                                                          <block type="logic_compare" id="V_YfG}cf!y=P8h|DC9/^">
                                                            <field name="OP">LTE</field>
                                                            <value name="A">
                                                              <block type="get_value" id="(LOs]qM)+^#R}ro?lX7#">
                                                                <field name="ATTR">val</field>
                                                                <field name="OID">octoprint.0.temperature.tool0.target</field>
                                                              </block>
                                                            </value>
                                                            <value name="B">
                                                              <block type="math_number" id="`gAj^-c@9`f!SfMtUb!E">
                                                                <field name="NUM">0</field>
                                                              </block>
                                                            </value>
                                                          </block>
                                                        </value>
                                                      </block>
                                                    </value>
                                                  </block>
                                                </value>
                                                <statement name="DO0">
                                                  <block type="comment" id="L,5QpW[=AX7IXmgfWm|0">
                                                    <field name="COMMENT">Bett Temperatur</field>
                                                    <next>
                                                      <block type="control" id="L[d?ER)zE`1|QrD#ovz4">
                                                        <mutation delay_input="false"></mutation>
                                                        <field name="OID">octoprint.0.temperature.bed.target</field>
                                                        <field name="WITH_DELAY">FALSE</field>
                                                        <value name="VALUE">
                                                          <block type="math_number" id="@n=w(S..!Jg)`ZL1udp)">
                                                            <field name="NUM">45</field>
                                                          </block>
                                                        </value>
                                                        <next>
                                                          <block type="comment" id="aFXN%;?3?g:#6rWXyjPO">
                                                            <field name="COMMENT">Nozzel Temperatur</field>
                                                            <next>
                                                              <block type="control" id="PG6:-RYgozPxp}/C?bay">
                                                                <mutation delay_input="false"></mutation>
                                                                <field name="OID">octoprint.0.temperature.tool0.target</field>
                                                                <field name="WITH_DELAY">FALSE</field>
                                                                <value name="VALUE">
                                                                  <block type="math_number" id="xetGsWY6TkaMi};ssZXs">
                                                                    <field name="NUM">180</field>
                                                                  </block>
                                                                </value>
                                                              </block>
                                                            </next>
                                                          </block>
                                                        </next>
                                                      </block>
                                                    </next>
                                                  </block>
                                                </statement>
                                                <value name="IF1">
                                                  <block type="logic_operation" id="CeUEdB|O~7ztxS2_LM4+">
                                                    <field name="OP">AND</field>
                                                    <value name="A">
                                                      <block type="logic_compare" id="5od2{|:VlYf69JiDSMJg">
                                                        <field name="OP">EQ</field>
                                                        <value name="A">
                                                          <block type="get_value" id=")moE*+yiYzqRK;VkFH]+">
                                                            <field name="ATTR">val</field>
                                                            <field name="OID">zigbee.0.00158d0001e832d0.double_click</field>
                                                          </block>
                                                        </value>
                                                        <value name="B">
                                                          <block type="logic_boolean" id="rIZ`y?szmU~M?cs*p9-r">
                                                            <field name="BOOL">TRUE</field>
                                                          </block>
                                                        </value>
                                                      </block>
                                                    </value>
                                                    <value name="B">
                                                      <block type="logic_operation" id="4xQ;Gag5UM2f]A)MF_;^" inline="false">
                                                        <field name="OP">AND</field>
                                                        <value name="A">
                                                          <block type="logic_compare" id="*noWYU*ip2[HWl5Jju4E">
                                                            <field name="OP">GTE</field>
                                                            <value name="A">
                                                              <block type="get_value" id="Y`lLaA6{,jW3kP6^8}FV">
                                                                <field name="ATTR">val</field>
                                                                <field name="OID">octoprint.0.temperature.bed.target</field>
                                                              </block>
                                                            </value>
                                                            <value name="B">
                                                              <block type="math_number" id="}Irl~8ZGghE,VFTnNRT%">
                                                                <field name="NUM">45</field>
                                                              </block>
                                                            </value>
                                                          </block>
                                                        </value>
                                                        <value name="B">
                                                          <block type="logic_compare" id="8)9Ke8Pb@X?g.o~0?J9g">
                                                            <field name="OP">GTE</field>
                                                            <value name="A">
                                                              <block type="get_value" id="aX.U2O-!C;rC!h}n@!%K">
                                                                <field name="ATTR">val</field>
                                                                <field name="OID">octoprint.0.temperature.tool0.target</field>
                                                              </block>
                                                            </value>
                                                            <value name="B">
                                                              <block type="math_number" id="4!WIJCN^xC(B)4nNIg3.">
                                                                <field name="NUM">40</field>
                                                              </block>
                                                            </value>
                                                          </block>
                                                        </value>
                                                      </block>
                                                    </value>
                                                  </block>
                                                </value>
                                                <statement name="DO1">
                                                  <block type="control" id="A`xL#p+S4Eh~BVL3vvIT">
                                                    <mutation delay_input="false"></mutation>
                                                    <field name="OID">octoprint.0.temperature.bed.target</field>
                                                    <field name="WITH_DELAY">FALSE</field>
                                                    <value name="VALUE">
                                                      <block type="math_number" id="TvZ~.tHp,.wCp#1jFg4Z">
                                                        <field name="NUM">0</field>
                                                      </block>
                                                    </value>
                                                    <next>
                                                      <block type="control" id="z@#vdQTEK{iS#2;gC94+">
                                                        <mutation delay_input="false"></mutation>
                                                        <field name="OID">octoprint.0.temperature.tool0.target</field>
                                                        <field name="WITH_DELAY">FALSE</field>
                                                        <value name="VALUE">
                                                          <block type="math_number" id="%Jf{v!1ywIHx;:3?n4(s">
                                                            <field name="NUM">0</field>
                                                          </block>
                                                        </value>
                                                      </block>
                                                    </next>
                                                  </block>
                                                </statement>
                                              </block>
                                            </statement>
                                            <next>
                                              <block type="comment" id="7cJNZp)c?U]6L5*OXe3N">
                                                <field name="COMMENT">Licht</field>
                                                <next>
                                                  <block type="on_ext" id="JH#v!^`pb0Mpp}`Nj,)p">
                                                    <mutation items="1"></mutation>
                                                    <field name="CONDITION">ne</field>
                                                    <field name="ACK_CONDITION"></field>
                                                    <value name="OID0">
                                                      <shadow type="field_oid" id="S[q1j_h4[wk=V#Y^H)w,">
                                                        <field name="oid">zigbee.0.00158d0001e832d0.triple_click</field>
                                                      </shadow>
                                                    </value>
                                                    <statement name="STATEMENT">
                                                      <block type="controls_if" id="POb=W3`E9[JG+Gu[NdZD">
                                                        <value name="IF0">
                                                          <block type="logic_compare" id="`@=;,CF]a4%;lKvwPKr]">
                                                            <field name="OP">EQ</field>
                                                            <value name="A">
                                                              <block type="get_value" id="fD]0iFX`,NzyvruDQ_RJ">
                                                                <field name="ATTR">val</field>
                                                                <field name="OID">zigbee.0.00158d0001e832d0.triple_click</field>
                                                              </block>
                                                            </value>
                                                            <value name="B">
                                                              <block type="logic_boolean" id="_#iz]hw`0Iq[sTjPtq/P">
                                                                <field name="BOOL">TRUE</field>
                                                              </block>
                                                            </value>
                                                          </block>
                                                        </value>
                                                        <statement name="DO0">
                                                          <block type="procedures_callcustomnoreturn" id=",}m+``lap``he:WJF6[@">
                                                            <mutation name="Licht"></mutation>
                                                            <next>
                                                              <block type="control" id="_xRVMZyO;trFt*m_069G" disabled="true">
                                                                <mutation delay_input="false"></mutation>
                                                                <field name="OID">octoprint.0.command.printer</field>
                                                                <field name="WITH_DELAY">FALSE</field>
                                                                <value name="VALUE">
                                                                  <block type="text" id="+L{6@Ms4387ig]_FQ-=.">
                                                                    <field name="TEXT">home</field>
                                                                  </block>
                                                                </value>
                                                              </block>
                                                            </next>
                                                          </block>
                                                        </statement>
                                                      </block>
                                                    </statement>
                                                    <next>
                                                      <block type="comment" id="tIbGBR3z,ZUwEoogwR~b">
                                                        <field name="COMMENT">Drucker ausschalten</field>
                                                        <next>
                                                          <block type="on_ext" id="J0q~1~aOryAei(bnjTv$">
                                                            <mutation items="1"></mutation>
                                                            <field name="CONDITION">ne</field>
                                                            <field name="ACK_CONDITION"></field>
                                                            <value name="OID0">
                                                              <shadow type="field_oid" id=".4Q(bhe];EXB$@P2X^h(">
                                                                <field name="oid">zigbee.0.00158d0001e832d0.quad_click</field>
                                                              </shadow>
                                                            </value>
                                                            <statement name="STATEMENT">
                                                              <block type="controls_if" id="zb2RA5uQ-o)(LsZ;u$hK" collapsed="true">
                                                                <value name="IF0">
                                                                  <block type="logic_operation" id="i`LcFCn/1En01on6xF/G" inline="false">
                                                                    <field name="OP">AND</field>
                                                                    <value name="A">
                                                                      <block type="logic_compare" id="A)EYGPyGQv9^C7}}eM3`">
                                                                        <field name="OP">EQ</field>
                                                                        <value name="A">
                                                                          <block type="get_value" id="wr|1U~=Qtc)Yt`-b!5I7">
                                                                            <field name="ATTR">val</field>
                                                                            <field name="OID">zigbee.0.00158d0001e832d0.quad_click</field>
                                                                          </block>
                                                                        </value>
                                                                        <value name="B">
                                                                          <block type="logic_boolean" id="N;?x?9SocoQWZa{P3kN.">
                                                                            <field name="BOOL">TRUE</field>
                                                                          </block>
                                                                        </value>
                                                                      </block>
                                                                    </value>
                                                                    <value name="B">
                                                                      <block type="logic_compare" id="V%u!qS9%|QzOHO$Itaoc">
                                                                        <field name="OP">NEQ</field>
                                                                        <value name="A">
                                                                          <block type="get_value" id="-5CP0a0X7{@+|uD9{LCG">
                                                                            <field name="ATTR">val</field>
                                                                            <field name="OID">octoprint.0.printer_status</field>
                                                                          </block>
                                                                        </value>
                                                                        <value name="B">
                                                                          <block type="text" id="_=#~RYt5E3cJgc^4tmA^">
                                                                            <field name="TEXT">	Printing</field>
                                                                          </block>
                                                                        </value>
                                                                      </block>
                                                                    </value>
                                                                  </block>
                                                                </value>
                                                                <statement name="DO0">
                                                                  <block type="control" id="[~*e*X-Wm-`AMi,!Xkfm">
                                                                    <mutation delay_input="false"></mutation>
                                                                    <field name="OID">javascript.0.schalter.3d_drucker_rpi_shutdown</field>
                                                                    <field name="WITH_DELAY">FALSE</field>
                                                                    <value name="VALUE">
                                                                      <block type="logic_boolean" id="-.:wT:^|fu[QSukm=iAq">
                                                                        <field name="BOOL">FALSE</field>
                                                                      </block>
                                                                    </value>
                                                                  </block>
                                                                </statement>
                                                              </block>
                                                            </statement>
                                                          </block>
                                                        </next>
                                                      </block>
                                                    </next>
                                                  </block>
                                                </next>
                                              </block>
                                            </next>
                                          </block>
                                        </next>
                                      </block>
                                    </next>
                                  </block>
                                </next>
                              </block>
                            </next>
                          </block>
                        </next>
                      </block>
                    </next>
                  </block>
                  <block type="on_ext" id="+A7wlutQO8gBfqosc.y3" x="-388" y="12">
                    <mutation items="2"></mutation>
                    <field name="CONDITION">ne</field>
                    <field name="ACK_CONDITION"></field>
                    <value name="OID0">
                      <shadow type="field_oid" id="L[i=p{|ii-ai*/YAZ@8s">
                        <field name="oid">octoprint.0.temperature.bed.actual</field>
                      </shadow>
                    </value>
                    <value name="OID1">
                      <shadow type="field_oid" id="SrqWt)hN`dugaePnqgR:">
                        <field name="oid">octoprint.0.temperature.tool0.actual</field>
                      </shadow>
                    </value>
                    <statement name="STATEMENT">
                      <block type="controls_if" id="V6]e:v6u:?I_dnQ6L_VO" collapsed="true">
                        <mutation elseif="1"></mutation>
                        <value name="IF0">
                          <block type="logic_compare" id="|GYXj{b?eejrNKL,dC1c">
                            <field name="OP">GTE</field>
                            <value name="A">
                              <block type="get_value" id="NE_0I9@@4+Vx=788NJ{O">
                                <field name="ATTR">val</field>
                                <field name="OID">octoprint.0.temperature.bed.actual</field>
                              </block>
                            </value>
                            <value name="B">
                              <block type="text" id="^ZZxvmafdi;Q}c)p)@Kd">
                                <field name="TEXT">50</field>
                              </block>
                            </value>
                          </block>
                        </value>
                        <statement name="DO0">
                          <block type="control" id="vs.J|^}}{M%%SJ1bpk;V">
                            <mutation delay_input="false"></mutation>
                            <field name="OID">javascript.0.schalter.3d_drucker_fertig</field>
                            <field name="WITH_DELAY">FALSE</field>
                            <value name="VALUE">
                              <block type="logic_boolean" id="gvfoVV5t!!Us3^C~!w.H">
                                <field name="BOOL">FALSE</field>
                              </block>
                            </value>
                          </block>
                        </statement>
                        <value name="IF1">
                          <block type="logic_compare" id=".^Vr3!/]n3+mJC!/xH_P">
                            <field name="OP">LT</field>
                            <value name="A">
                              <block type="get_value" id="SES|c80.WXQ*jSsOhFie">
                                <field name="ATTR">val</field>
                                <field name="OID">octoprint.0.temperature.bed.actual</field>
                              </block>
                            </value>
                            <value name="B">
                              <block type="text" id="yt?GRbeq!O:U6vuzE4-i">
                                <field name="TEXT">40</field>
                              </block>
                            </value>
                          </block>
                        </value>
                        <statement name="DO1">
                          <block type="control" id="W@d-F3O_9HHWW#dCNkL=">
                            <mutation delay_input="false"></mutation>
                            <field name="OID">javascript.0.schalter.3d_drucker_fertig</field>
                            <field name="WITH_DELAY">FALSE</field>
                            <value name="VALUE">
                              <block type="logic_boolean" id="A4H}`x`xaT~u.qw:OMjO">
                                <field name="BOOL">TRUE</field>
                              </block>
                            </value>
                          </block>
                        </statement>
                      </block>
                    </statement>
                    <next>
                      <block type="on_ext" id="u:R0u7j.Y,8EdsUCK6kQ">
                        <mutation items="1"></mutation>
                        <field name="CONDITION">ne</field>
                        <field name="ACK_CONDITION"></field>
                        <value name="OID0">
                          <shadow type="field_oid" id="jgpdw:j!HF59WUplmK}~">
                            <field name="oid">javascript.0.schalter.3d_drucker_fertig</field>
                          </shadow>
                        </value>
                        <statement name="STATEMENT">
                          <block type="controls_if" id="0KU30/v2h#W(!`#[gp76" collapsed="true">
                            <mutation elseif="1"></mutation>
                            <value name="IF0">
                              <block type="logic_compare" id="]-Zb+?Hn_!lMC-aT9alk">
                                <field name="OP">EQ</field>
                                <value name="A">
                                  <block type="get_value" id="ln#_*!,/omF%2!L4WRp-">
                                    <field name="ATTR">val</field>
                                    <field name="OID">javascript.0.schalter.3d_drucker_fertig</field>
                                  </block>
                                </value>
                                <value name="B">
                                  <block type="logic_boolean" id="pSN^b91_Se1kc2o;W4J^">
                                    <field name="BOOL">FALSE</field>
                                  </block>
                                </value>
                              </block>
                            </value>
                            <statement name="DO0">
                              <block type="telegram" id="i||{vH9*ebG3rYojyq#~">
                                <field name="INSTANCE">.0</field>
                                <field name="LOG"></field>
                                <field name="SILENT">FALSE</field>
                                <field name="PARSEMODE">default</field>
                                <value name="MESSAGE">
                                  <shadow type="text" id="U][E8N^7Bu/+`G(NxN}#">
                                    <field name="TEXT"></field>
                                  </shadow>
                                  <block type="text_join" id="2b|ng~sPvT|iC)a%*xI7">
                                    <mutation items="3"></mutation>
                                    <value name="ADD0">
                                      <block type="text" id="#1kx@/m~N,F+j0]M7kg{">
                                        <field name="TEXT">Der 3D-Drucker hat angefangen </field>
                                      </block>
                                    </value>
                                    <value name="ADD1">
                                      <block type="get_value" id="LhG1A9ZJ}qx=J?Fhl^@Y">
                                        <field name="ATTR">val</field>
                                        <field name="OID">octoprint.0.printjob.file.name</field>
                                      </block>
                                    </value>
                                    <value name="ADD2">
                                      <block type="text" id="o:.!{V?z_(eK9jLH:hJ|">
                                        <field name="TEXT"> zu drucken</field>
                                      </block>
                                    </value>
                                  </block>
                                </value>
                              </block>
                            </statement>
                            <value name="IF1">
                              <block type="logic_compare" id="21(9~CU|XRCn:EOXk2/@">
                                <field name="OP">EQ</field>
                                <value name="A">
                                  <block type="get_value" id="TSvo:2H{H+}IE{#M1`FO">
                                    <field name="ATTR">val</field>
                                    <field name="OID">javascript.0.schalter.3d_drucker_fertig</field>
                                  </block>
                                </value>
                                <value name="B">
                                  <block type="logic_boolean" id="h=.8?l5o{aiN|)W)LXh@">
                                    <field name="BOOL">TRUE</field>
                                  </block>
                                </value>
                              </block>
                            </value>
                            <statement name="DO1">
                              <block type="telegram" id="ed05d|bQf^sw*MK?SR-6">
                                <field name="INSTANCE">.0</field>
                                <field name="LOG"></field>
                                <field name="SILENT">FALSE</field>
                                <field name="PARSEMODE">default</field>
                                <value name="MESSAGE">
                                  <shadow type="text" id="sKyyX,f?IkAZP`RFQReF">
                                    <field name="TEXT">Die Waschmaschine ist fertig :)</field>
                                  </shadow>
                                  <block type="text_join" id=":?(LV%}eMmeGg5)=s63{">
                                    <mutation items="9"></mutation>
                                    <value name="ADD0">
                                      <block type="text" id="Me[sfL:79y?isrCAn~-e">
                                        <field name="TEXT">Der 3D-Drucker ist fertig! </field>
                                      </block>
                                    </value>
                                    <value name="ADD1">
                                      <block type="text_newline" id="=Ln@t]2hKoRekBO*=I$x">
                                        <field name="Type">\n</field>
                                      </block>
                                    </value>
                                    <value name="ADD2">
                                      <block type="text" id="0bN](j4?-62PDxGTFs`K">
                                        <field name="TEXT">Das waren </field>
                                      </block>
                                    </value>
                                    <value name="ADD3">
                                      <block type="get_value" id="5nYhH(Z-[f`G*,+qIZ;H">
                                        <field name="ATTR">val</field>
                                        <field name="OID">sonoff.0.Pow_62_3dDrucker.ENERGY_Today</field>
                                      </block>
                                    </value>
                                    <value name="ADD4">
                                      <block type="text" id=",nn}rYrBfCaxgJPdJkp7">
                                        <field name="TEXT"> kWh die für das Drucken verbraucht worden sind.</field>
                                      </block>
                                    </value>
                                    <value name="ADD5">
                                      <block type="text_newline" id="y[Hf}4D:ri]xj@q@[wha">
                                        <field name="Type">\n</field>
                                      </block>
                                    </value>
                                    <value name="ADD6">
                                      <block type="text" id="0%vbNiH.-uK;q[)6ZRx=">
                                        <field name="TEXT">Das sind ca.</field>
                                      </block>
                                    </value>
                                    <value name="ADD7">
                                      <block type="get_value" id="hCs/qrxQ~vwE?sKSN/10">
                                        <field name="ATTR">val</field>
                                        <field name="OID">javascript.0.Berechnungen.3D_Drucker.Heute</field>
                                      </block>
                                    </value>
                                    <value name="ADD8">
                                      <block type="text" id="@sTCB@TuHU6fdmi31@bV">
                                        <field name="TEXT">Euro</field>
                                      </block>
                                    </value>
                                  </block>
                                </value>
                                <next>
                                  <block type="controls_if" id="rfQaG-]RZG[J7N^zgcn}">
                                    <value name="IF0">
                                      <block type="logic_compare" id="|R+(A4n%[[2~FwDmCB!;">
                                        <field name="OP">LT</field>
                                        <value name="A">
                                          <block type="get_value" id="jfZP8qNUbZ+4PRi3OXZ9">
                                            <field name="ATTR">val</field>
                                            <field name="OID">octoprint.0.temperature.bed.actual</field>
                                          </block>
                                        </value>
                                        <value name="B">
                                          <block type="text" id="NjDd8G#S{W![sJ:pi6bw">
                                            <field name="TEXT">40</field>
                                          </block>
                                        </value>
                                      </block>
                                    </value>
                                    <statement name="DO0">
                                      <block type="debug" id="mk7sgm[,N@wIZIyGEF+2">
                                        <field name="Severity">log</field>
                                        <value name="TEXT">
                                          <shadow type="text" id="AQ~nPFy6}@Z-b5jNlXDc">
                                            <field name="TEXT">in 10min wird runtergefahren</field>
                                          </shadow>
                                        </value>
                                        <next>
                                          <block type="timeouts_settimeout" id="LC5}R,k-3]_F.tzTdv~y">
                                            <field name="NAME">timeout</field>
                                            <field name="DELAY">10</field>
                                            <field name="UNIT">min</field>
                                            <statement name="STATEMENT">
                                              <block type="controls_if" id="G_npA;)|vwA)AvdWb.it">
                                                <value name="IF0">
                                                  <block type="logic_compare" id="mm4*,5X2mVm,I[O^!M*|">
                                                    <field name="OP">LT</field>
                                                    <value name="A">
                                                      <block type="get_value" id="]qP|`R^KqX*{Qxy-;GB/">
                                                        <field name="ATTR">val</field>
                                                        <field name="OID">octoprint.0.temperature.bed.actual</field>
                                                      </block>
                                                    </value>
                                                    <value name="B">
                                                      <block type="text" id="06oZ4u||h!S@CRJuNrEj">
                                                        <field name="TEXT">35</field>
                                                      </block>
                                                    </value>
                                                  </block>
                                                </value>
                                                <statement name="DO0">
                                                  <block type="control" id="`4mp,TnHO)6@[,=Jg@G}">
                                                    <mutation delay_input="false"></mutation>
                                                    <field name="OID">javascript.0.schalter.3d_drucker_rpi_shutdown</field>
                                                    <field name="WITH_DELAY">FALSE</field>
                                                    <value name="VALUE">
                                                      <block type="logic_boolean" id="}:_~nb#_A7mJ7[Sq+F5n">
                                                        <field name="BOOL">FALSE</field>
                                                      </block>
                                                    </value>
                                                  </block>
                                                </statement>
                                              </block>
                                            </statement>
                                          </block>
                                        </next>
                                      </block>
                                    </statement>
                                  </block>
                                </next>
                              </block>
                            </statement>
                          </block>
                        </statement>
                      </block>
                    </next>
                  </block>
                </xml>
                
                1 Reply Last reply Reply Quote 1
                • Webranger
                  Webranger @George_Best last edited by Webranger

                  @George_Best

                  Gerade mal getestet und läuft super. Danke dafür

                  1 Reply Last reply Reply Quote 1
                  • joergeli
                    joergeli @George_Best last edited by joergeli

                    @George_Best
                    Hi, ich habe mir erlaubt, Dein Script mit meinem JS-Halbwissen etwas anzupassen, da führende Nullen bei Std, Min und Sec nicht angezeigt wurden.
                    Sieht m.E. schöner aus, wenn anstatt 0:35:9 -> 00:35:09 angezeigt wird.
                    Meine Datenpunkte javascript.0.OctoPi.Printzeit und javascript.0.OctoPi.Restzeit (Typ Zeichenkette) werden automatisch angelegt.
                    Fertigmeldung gebe ich bei mir mit einem anderen Script aus.

                    
                    //************ Umrechnung der Druckzeiten von Sekunden nach HH:MM:SS********************* */
                    
                    createState('javascript.0.OctoPi.Printzeit', {
                        name: 'Druckdauer',
                        desc: 'Druckdauer',
                        type: 'string'
                    });
                    
                    createState('javascript.0.OctoPi.Restzeit', {
                        name: 'Restzeit',
                        desc: 'Restzeit',
                        type: 'string'
                    });
                    
                    const restdauer  = 'octoprint.0.printjob.progress.printtime_left'
                    const druckdauer = 'octoprint.0.printjob.progress.printtime'
                    
                    on({id: [restdauer], change: "lt"} , function (obj) {
                        umrechnung();
                    });
                    
                    
                    //_________________________________________________________________________
                    
                    function umrechnung() {
                        var time_left = getState("octoprint.0.printjob.progress.printtime_left").val;
                        var job_time  = getState('octoprint.0.printjob.progress.printtime').val;
                    
                        // Hours
                        var hours_restzeit  =  Math.floor( time_left / 3600 );
                        var hours_printzeit =  Math.floor( job_time  / 3600 );
                        if ( hours_restzeit  < 10 ){var std_restzeit = "0" + String(hours_restzeit);}
                            else var std_restzeit = String(hours_restzeit)
                        if ( hours_printzeit < 10 ){var std_printzeit= "0" + String(hours_printzeit); }
                            else var std_printzeit = String(hours_printzeit)
                    
                        // Minutes
                        var minutes_restzeit  = Math.floor( (time_left%3600) / 60 );
                        var minutes_printzeit = Math.floor( (job_time%3600)  / 60 );
                        if ( minutes_restzeit  < 10 ){var min_restzeit = "0" + String(minutes_restzeit);}
                            else var min_restzeit = String(minutes_restzeit)
                        if ( minutes_printzeit < 10 ){var min_printzeit= "0" + String(minutes_printzeit); }
                            else var min_printzeit = String(minutes_restzeit)
                    
                        // Seconds
                        var seconds_restzeit  = Math.floor( time_left%60 );
                        var seconds_printzeit = Math.floor( job_time%60  );
                        if ( seconds_restzeit  < 10 ){var sec_restzeit = "0" + String(seconds_restzeit);}
                            else var sec_restzeit = String(seconds_restzeit)
                        if ( seconds_printzeit < 10 ){var sec_printzeit= "0" + String(seconds_printzeit); }
                            else var sec_printzeit = String(seconds_printzeit)
                    
                        // Zeit in HH:MM:SS format
                        var restzeit  = std_restzeit  + ':' + min_restzeit  + ':' + sec_restzeit;
                        var printzeit = std_printzeit + ':' + min_printzeit + ':' + sec_printzeit;
                    
                        console.log("Restzeit: " + restzeit);
                        console.log("Printzeit: " + printzeit);
                    
                        setState("javascript.0.OctoPi.Restzeit", restzeit, true);
                        setState('javascript.0.OctoPi.Printzeit', printzeit, true);
                    }
                    
                    

                    Gruß
                    Jörg

                    G 1 Reply Last reply Reply Quote 0
                    • G
                      George_Best @joergeli last edited by George_Best

                      @joergeli sagte in [UMFRAGE] Besteht Interesse an einem Octoprint Adapter:

                      @George_Best
                      Hi, ich habe mir erlaubt, Dein Script mit meinem JS-Halbwissen etwas anzupassen, da führende Nullen bei Std, Min und Sec nicht angezeigt wurden.
                      Sieht m.E. schöner aus, wenn anstatt 0:35:9 -> 00:35:09 angezeigt wird.
                      Meine Datenpunkte javascript.0.OctoPi.Printzeit und javascript.0.OctoPi.Restzeit (Typ Zeichenkette) werden automatisch angelegt.
                      Fertigmeldung gebe ich bei mir mit einem anderen Script aus.

                      
                      //************ Umrechnung der Druckzeiten von Sekunden nach HH:MM:SS********************* */
                      
                      createState('javascript.0.OctoPi.Printzeit', {
                          name: 'Druckdauer',
                          desc: 'Druckdauer',
                          type: 'string'
                      });
                      
                      createState('javascript.0.OctoPi.Restzeit', {
                          name: 'Restzeit',
                          desc: 'Restzeit',
                          type: 'string'
                      });
                      
                      const restdauer  = 'octoprint.0.printjob.progress.printtime_left'
                      const druckdauer = 'octoprint.0.printjob.progress.printtime'
                      
                      on({id: [restdauer, druckdauer], change: "any"} , function (obj) {
                          umrechnung();
                      });
                      
                      //_________________________________________________________________________
                      
                      function umrechnung() {
                          var time_left = (getDateObject(getState("octoprint.0.printjob.progress.printtime_left").val));
                          var job_time  = (getDateObject(getState('octoprint.0.printjob.progress.printtime').val));
                      
                          // Hours
                          var hours_restzeit  =  Math.floor( time_left / 3600 );
                          var hours_printzeit =  Math.floor( job_time  / 3600 );
                          if ( hours_restzeit  < 10 ){var std_restzeit = "0" + String(hours_restzeit);}
                              else var std_restzeit = String(hours_restzeit)
                          if ( hours_printzeit < 10 ){var std_printzeit= "0" + String(hours_printzeit); }
                              else var std_printzeit = String(hours_printzeit)
                      
                          // Minutes
                          var minutes_restzeit  = Math.floor( (time_left%3600) / 60 );
                          var minutes_printzeit = Math.floor( (job_time%3600)  / 60 );
                          if ( minutes_restzeit  < 10 ){var min_restzeit = "0" + String(minutes_restzeit);}
                              else var min_restzeit = String(minutes_restzeit)
                          if ( minutes_printzeit < 10 ){var min_printzeit= "0" + String(minutes_printzeit); }
                              else var min_printzeit = String(minutes_restzeit)
                      
                          // Seconds
                          var seconds_restzeit  = Math.floor( time_left%60 );
                          var seconds_printzeit = Math.floor( job_time%60  );
                          if ( seconds_restzeit  < 10 ){var sec_restzeit = "0" + String(seconds_restzeit);}
                              else var sec_restzeit = String(seconds_restzeit)
                          if ( seconds_printzeit < 10 ){var sec_printzeit= "0" + String(seconds_printzeit); }
                              else var sec_printzeit = String(seconds_printzeit)
                      
                          // Zeit in HH:MM:SS format
                          var restzeit  = std_restzeit  + ':' + min_restzeit  + ':' + sec_restzeit;
                          var printzeit = std_printzeit + ':' + min_printzeit + ':' + sec_printzeit;
                      
                          console.log("Restzeit: " + restzeit);
                          console.log("Printzeit: " + printzeit);
                      
                          setState("javascript.0.OctoPi.Restzeit", restzeit, true);
                          setState('javascript.0.OctoPi.Printzeit', printzeit, true);
                      }
                      
                      

                      Gruß
                      Jörg

                      Hallo Jörg,

                      sehr, sehr gerne darfst du das anpassen. Wow😳 - deine Umsetzung ist natürlich die Profi-Version! Klasse Beitrag!

                      joergeli 1 Reply Last reply Reply Quote 0
                      • joergeli
                        joergeli @George_Best last edited by joergeli

                        @George_Best
                        Hi,
                        ich habe mein Script gerade noch mal editiert:
                        getDateObject braucht man m.E. nicht, da sich das ja auf das aktuelle Datum bezieht und nichts mit den Druckzeiten zu tun hat.
                        Außerdem reicht es eigentlich aus, daß nur getriggert wird, wenn sich die Restdauer ( printtime_left ) verkleinert.
                        Die verangene Zeit = Druckdauer ( printtime ) wird ja trotzdem automatisch mit angepasst.

                        Hier also noch mal das angepasste Script:

                        //************ Umrechnung der Druckzeiten von Sekunden nach HH:MM:SS********************* */
                        createState('javascript.0.OctoPi.Printzeit', {
                            name: 'Druckdauer',
                            desc: 'Druckdauer',
                            type: 'string'
                        });
                        
                        createState('javascript.0.OctoPi.Restzeit', {
                            name: 'Restzeit',
                            desc: 'Restzeit',
                            type: 'string'
                        });
                        
                        const restdauer  = 'octoprint.0.printjob.progress.printtime_left'
                        const druckdauer = 'octoprint.0.printjob.progress.printtime'
                        
                        // Triggern, wenn sich Restzeit verkleinert
                        on({id: [restdauer], change: "lt"} , function (obj) {
                            umrechnung();
                        });
                        
                        //_________________________________________________________________________
                        
                        function umrechnung() {
                            var time_left = getState("octoprint.0.printjob.progress.printtime_left").val;
                            var job_time  = getState('octoprint.0.printjob.progress.printtime').val;
                        
                            // Hours
                            var hours_restzeit  =  Math.floor( time_left / 3600 );
                            var hours_printzeit =  Math.floor( job_time  / 3600 );
                            if ( hours_restzeit  < 10 ){var std_restzeit = "0" + String(hours_restzeit);}
                                else var std_restzeit = String(hours_restzeit)
                            if ( hours_printzeit < 10 ){var std_printzeit= "0" + String(hours_printzeit); }
                                else var std_printzeit = String(hours_printzeit)
                        
                            // Minutes
                            var minutes_restzeit  = Math.floor( (time_left%3600) / 60 );
                            var minutes_printzeit = Math.floor( (job_time%3600)  / 60 );
                            if ( minutes_restzeit  < 10 ){var min_restzeit = "0" + String(minutes_restzeit);}
                                else var min_restzeit = String(minutes_restzeit)
                            if ( minutes_printzeit < 10 ){var min_printzeit= "0" + String(minutes_printzeit); }
                                else var min_printzeit = String(minutes_restzeit)
                        
                            // Seconds
                            var seconds_restzeit  = Math.floor( time_left%60 );
                            var seconds_printzeit = Math.floor( job_time%60  );
                            if ( seconds_restzeit  < 10 ){var sec_restzeit = "0" + String(seconds_restzeit);}
                                else var sec_restzeit = String(seconds_restzeit)
                            if ( seconds_printzeit < 10 ){var sec_printzeit= "0" + String(seconds_printzeit); }
                                else var sec_printzeit = String(seconds_printzeit)
                        
                            // Zeit in HH:MM:SS format
                            var restzeit  = std_restzeit  + ':' + min_restzeit  + ':' + sec_restzeit;
                            var printzeit = std_printzeit + ':' + min_printzeit + ':' + sec_printzeit;
                        
                            console.log("Restzeit: " + restzeit);
                            console.log("Printzeit: " + printzeit);
                        
                            setState("javascript.0.OctoPi.Restzeit", restzeit, true);
                            setState('javascript.0.OctoPi.Printzeit', printzeit, true);
                        
                        }
                        
                        

                        Nebenbei:
                        Es gibt für Octoprint ein sog. DryRun-Plugin.
                        Damit kann man einen Druck simulieren, d.h. es werden alle Bewegungen des Druckkopfes ausgeführt, es wird aber kein Filament gefördert und Druckbett, bzw. HotEnd werden auch nicht beheizt.
                        Mit dieser Simulation kann man Scripte bzgl. Octoprint gut testen, ohne unnötig Filament zu verbrauchen.

                        Gruß
                        Jörg

                        Webranger 1 Reply Last reply Reply Quote 2
                        • Webranger
                          Webranger @joergeli last edited by Webranger

                          @joergeli

                          Aber irgendwas passt noch nicht so richtig oder?
                          Druckdauer/Printtime

                          Bildschirmfoto 2020-01-03 um 20.25.16.png

                          müsste das nicht minutes_printzeit am ende heissen?

                              if ( minutes_printzeit < 10 ){var min_printzeit= "0" + String(minutes_printzeit); }
                          
                                  else var min_printzeit = String(minutes_restzeit)
                          

                          gerade getestet.

                          so ist es richtig:

                              if ( minutes_printzeit < 10 ){var min_printzeit= "0" + String(minutes_printzeit); }
                          
                                  else var min_printzeit = String(minutes_printzeit)
                          
                          joergeli 1 Reply Last reply Reply Quote 0
                          • joergeli
                            joergeli @Webranger last edited by

                            @Webranger
                            Jepp, Copy & Paste Fehler meinerseits.

                            Sorry
                            Jörg

                            1 Reply Last reply Reply Quote 0
                            • HAL
                              HAL last edited by

                              Erstmal Danke an alle und besonders Jörg für den Adapter.
                              Ich bin gerade dabei meinen neuen Prusa i3 MKS zu tunen ( Frontplatte mit Raspi und Touchscreen, Spannungswandler für Raspi, Beleuchtung, Kamera und entkoppelte Standfüße ). Deshalb habe ich gestern abend nicht mehr mit gelesen.
                              Gerade habe ich einen Druck für Gehäuse Teile gestartet und im Display wird eine Restzeit von 20 Stunden angezeigt 😧

                              Dafür möchte ich den Adapter nutzen.

                              Wenn das Hotend weniger als 50° hat ( Druck ist fertig ) den Raspi runterfahren ( shutdown -h now) und dann die HM Steckdose ausschalten.

                              Während des Drucks eine Frage an Alexa stellen ( das klappt schon gut mit z.B. Alexa, sind Fenster offen?) Alexa, wie lange dauert der 3D Druck noch? Und dann die Restzeit angesagt bekommen bzw in VIS darstellen.

                              Jetzt müsste ich alle Infos haben und werde dass später ausprobieren. 😊

                              joergeli 1 Reply Last reply Reply Quote 0
                              • joergeli
                                joergeli @HAL last edited by

                                @HAL
                                Ich bin nicht der Autor des Adapters, nur ein Nutzer desselben.
                                Leider wird der Adapter wohl auch nicht mehr gepflegt.

                                Falls es interessiert, ein paar Fotos/Skizzen von meiner Konfiguration:
                                3D Drucker für den Einstieg

                                Als Kamera verwende ich diese hier: Raspberry Pi Fisheye 160°
                                denn mit dem Fisheye-Objektiv kannst Du die Cam recht nahe am Drucker positionieren und siehst trotzdem das ganze Druckbett.
                                Das mit diesen RaspiCams gelieferte Flachbandkabel ist i.d.R. recht kurz, deshalb habe ich die Cam über ein 1m-Verlängerungskabel angeschlossen.

                                Gruß
                                Jörg

                                HAL joergeli 2 Replies Last reply Reply Quote 0
                                • HAL
                                  HAL @joergeli last edited by

                                  @joergeli ,
                                  auf Grund Deiner kompetenten Antwort habe ich dich als Author des Adapters vermutet 😉 es ist aber Matthias Kleine info@haus-automatisierung.com.

                                  Ich habe momentan zwei USB Kameras ausprobiert, die Beide noch hier "rumlagen". 1.) Logitec C270 und eine
                                  2. ) PS3 Eye Kamera.
                                  Die PS3 Kamera hat den besseren Weitwinkel, aber zu wenig Auflösung und ich werde die Logitec nutzen.

                                  Momentan drucke ich mir eine neue Halterung für die C270 aus; die erste war eine Halterung am Stepermotor der Z-Achse. Man sieht schön das Hotend aber nicht das ganze Druckbild.

                                  Dein Javascript habe ich etwas erweitert, damit ich einfacher die Restzeit Stunden und Minuten mit Alexa ausgeben kann. Für VIS habe ich noch nichts fertig, Dein View gefällt mir gut. Magst Du den sharen ?

                                  Das Script für das automatischen abschalten am ende des Drucks ist noch in arbeit.

                                  VG Uwe

                                  joergeli 1 Reply Last reply Reply Quote 0
                                  • joergeli
                                    joergeli @joergeli last edited by joergeli

                                    @ all:

                                    Ich stelle hier mal mein komplettes "Octoprint-Script" zur Verfügung, evtl. hilft es dem Einen oder Anderen.
                                    Was kann das Script?:
                                    Via vis 3D-Drucker und Octoprint-Raspi mittels Shelly Plug S (WLAN-Steckdose) o.ä. Ein-/Ausschalten.
                                    Der OctoPrint-Raspi wird mit ssh.execCommand sauber heruntergefahren, d.h. nicht einfach ausgeschaltet
                                    (im Script muss dazu der entspr. User/Passwort des Raspis eingetragen werden!)

                                    Octoprint-Instanz wird mit Start des Druckers, bzw. der WLAN-Steckdose gestartet.
                                    Octoprint-Instanz wird mit Ausschalten des Druckers, bzw. der WLAN-Steckdose beendet.

                                    Anzeige div. Drucker-Parameter in vis: Status des Druckers, Druckdatei/Größe, Druckbett und HotEnd-Temp (ist/soll), Druckzeiten, Druck-Fortschritt.

                                    Verschiedene Ansagen ( z.B. Druck ist zu xx% fertig, Octoprint ist online, Druck ist fertig, etc.) mittels PAW-Adapter auf z.B. Android-Smartphone oder Tablet.

                                    Was kann es nicht?: Den Drucker steuern, z.B. Druck starten, Druckdatei hochladen, etc.
                                    Das muß im Browser über die OctoPrint-Webseite gemacht werden.

                                    //#####################################################################
                                    // Octoprint-Server ein-/ausschalten, bzw. ueberwachen
                                    //#####################################################################
                                    // node-ssh muss in Javascript-Adapter installiert sein !
                                    
                                    // Die folgenden Variablen werden benoetigt, damit die jeweilige Sprachausgabe - bei entspr. %-Zahl -  nur einmalig erfolgt
                                    var twentyfive = 0;     //25% gedruckt
                                    var fifty = 0;          //50% gedruckt
                                    var seventyfive = 0;    //75% gedruckt
                                    var ninety = 0;         //90% gedruckt
                                    var done = 0;           //100% gedruckt
                                    
                                    const octopi_steckdose              = 'shelly.0.SHPLG-S#04168A#1.Relay0.Switch' // Steckdose Octopi und 3D-Drucker
                                    const octoprint_adapter             = 'system.adapter.octoprint.0.connected'    //Octoprint-Adapter verbunden
                                    const ping_octoprint                = 'javascript.0.ping.Raspi Octoprint'       //Octoprint Ping
                                    const octoprint_verbindung          = 'octoprint.0.info.connection'             // Verbindung zum Drucker
                                    const anycubic_verbindung           = 'octoprint.0.printer_status'              // Printer Status
                                    const anycubic_timedone             = 'octoprint.0.printjob.progress.printtime'
                                    const anycubic_timeleft             = 'octoprint.0.printjob.progress.printtime_left'
                                    const anycubic_extrudertemp         = 'octoprint.0.temperature.tool0.actual'
                                    const anycubic_extrudertemp_soll    = 'octoprint.0.temperature.tool0.target'
                                    const anycubic_tempbed              = 'octoprint.0.temperature.bed.actual'
                                    const anycubic_tempbed_soll         = 'octoprint.0.temperature.bed.target'
                                    const anycubic_fortschritt          = 'octoprint.0.printjob.progress.completion'
                                    const anycubic_dateiname            = 'octoprint.0.printjob.file.name'
                                    const anycubic_speicherort          = 'octoprint.0.printjob.file.origin'
                                    const anycubic_dateigroesse         = 'octoprint.0.printjob.file.size'
                                    
                                    var pfad = 'javascript.0.OctoPi.';
                                    
                                    var node_ssh = require('node-ssh');
                                    var ssh = new node_ssh();
                                    
                                    
                                    createState( pfad + 'ShutdownState', false, {name: 'State of Shutdown Octopi'}); 
                                    createState( pfad + 'ShuttingDown', {
                                        name: 'Shuttingdown OctoPi',
                                        desc: 'Shutdown OctoÜi',
                                        type: 'string'
                                    });
                                    
                                    
                                    createState('javascript.0.OctoPi.Printzeit', {
                                        name: 'Druckdauer',
                                        desc: 'Druckdauer',
                                        type: 'string'
                                    });
                                    
                                    createState('javascript.0.OctoPi.Restzeit', {
                                        name: 'Restzeit',
                                        desc: 'Restzeit',
                                        type: 'string'
                                    });
                                    
                                    
                                    //____________________________________________________________________________________________________
                                    // Umrechnung der Druckzeiten von Sekunden in HH:MM:SS
                                    on({id: [anycubic_timeleft], change: "lt"} , function (obj) {
                                        umrechnung();
                                    });
                                    
                                    
                                    //______ pruefen, ob Shutdown-Button gedrueckt wurde ____
                                    on('javascript.0.OctoPi.Shutdown', function (obj) {
                                        if (!obj.state.ack && obj.state.val == true) {
                                            octopi_shutdown();
                                        }
                                    });
                                    
                                    //______ pruefen, ob Start-Button gedrueckt wurde ____
                                    on('javascript.0.OctoPi.Shutdown', function (obj) {
                                        if (!obj.state.ack && obj.state.val == false) {
                                            octopi_startup();
                                        }
                                    });
                                    
                                    
                                    //____________________________________________________________________________________________________
                                    function octopi_shutdown() {
                                                    lautstaerke();  // PAW-Lautstaerke auf Maximum setzen
                                    
                                                    twentyfive = 0;
                                                    fifty = 0;
                                                    seventyfive = 0;
                                                    ninety = 0;
                                                    done = 0;              
                                    
                                                    //ioBroker OctoPi-Instanz killen
                                                    setTimeout(function(){
                                                    octo_adapter_off();
                                                    sendTo("paw.0",'Tablet_Jörg',{tts:  'Octoprint-Instanz wurde beendet'});
                                                    }, 1000);
                                                    sendTo("paw.0",'Tablet_Jörg',{play: true});  // sofort default sound notification abspielen
                                                    setState (pfad + 'ShuttingDown', 'Octoprint-Instanz beendet ...', true); 
                                    
                                                    //Sprachansage, dass Octopi heruntergefahren wird
                                                    setTimeout(function(){
                                                    sendTo("paw.0",'Tablet_Jörg',{tts:  'OctoPrint-Server wird heruntergefahren'});
                                                    log ('__ OctoPrint wird heruntergefahren __');
                                                    setState (pfad + 'ShuttingDown', 'OctoPrint wird  gestoppt ...', true);
                                    
                                                    //Druckzeiten zuruecksetzen
                                                    setState("javascript.0.OctoPi.Restzeit", '---', true);
                                                    setState('javascript.0.OctoPi.Printzeit', '---', true);
                                    
                                                    }, 5000);
                                    
                                    
                                                    //Octoprint-Server via SSH herunterfahren
                                                    setTimeout(function(){
                                                    //log ('__ SSH Verbindung gestartet __');
                                                    //SSH-Session starten
                                                        ssh.connect({
                                                            host: '192.168.192.30',  // IP-Adresse des Octoprint-Raspi
                                                            username: 'xxxxxxx',     //Username
                                                            password: 'xxxxxxx'      //Passwort
                                                        }).then(() => {
                                                            ssh.execCommand('echo "xxxxxxx"|sudo -S shutdown -h now');
                                                            // Achtung! Im obigen execCommand muss das Passwort für den Raspi nochmals eingesetzt werden
                                                        });                           
                                    
                                                    }, 6000);
                                    
                                    
                                                    //Sprachansage, dass Octopi heruntergefahren wird
                                                    setTimeout(function(){
                                                    sendTo("paw.0",'Tablet_Jörg',{tts:  'Schatdaun wurde gestartet'});
                                                    //log ('__ Shutdown wurde gestartet ... __');
                                                    setState (pfad + 'ShuttingDown', 'Shutdown wurde gestartet ...', true);
                                                    }, 10000);
                                    
                                    
                                                    //OctoPi Shutdown Fertig-Meldung
                                                    setTimeout(function(){
                                                    sendTo("paw.0",'Tablet_Jörg',{tts:  'Octoprint-Server ist daun'});
                                                    //log ('__ Octoprint-Server ist down __');
                                                    setState (pfad + 'ShuttingDown', 'OctoPrint ist down ...', true);
                                                    }, 18000);
                                    
                                                    //OctoPi-Steckdose ausschalten
                                                    setTimeout(function(){         
                                                    setState(octopi_steckdose, false);
                                                    sendTo("paw.0",'Tablet_Jörg',{tts:  'OctoPrint-Steckdose und 3 Deeee Drucker sind ausgeschaltet'});
                                                    log ('__ OctoPi-Steckdose ausgeschaltet __');
                                                    setState (pfad + 'ShuttingDown', 'OctoPrint ist ausgeschaltet', true);
                                                    }, 24000);
                                    
                                     
                                    
                                    }   // Ende function octopi_shutdown
                                    
                                    //____________________________________________________________________________________________________
                                    function octopi_startup() {
                                                    lautstaerke();
                                    
                                                    twentyfive = 0;
                                                    fifty = 0;
                                                    seventyfive = 0;
                                                    ninety = 0;
                                                    done = 0;
                                    
                                                    //Druckzeiten zuruecksetzen
                                                    setState("javascript.0.OctoPi.Restzeit", '---', true);
                                                    setState('javascript.0.OctoPi.Printzeit', '---', true);
                                    
                                                    // Steckdose einschalten
                                                    setState(octopi_steckdose, true);
                                                    //log('__ OctoPi-Steckdose eingeschaltet __');
                                                  
                                                    //OctoPi-Instanz starten
                                                    setTimeout(function(){
                                                    octo_adapter_on();
                                                    sendTo("paw.0",'Tablet_Jörg',{tts:  'Octoprint-Instanz wurde gestartet'});
                                                    }, 2000);
                                                    sendTo("paw.0",'Tablet_Jörg',{play: true});  // sofort default sound notification abspielen
                                                    setState (pfad + 'ShuttingDown', 'Instanz wurde gestartet ...', true);
                                    
                                                    setTimeout(function(){
                                                    sendTo("paw.0",'Tablet_Jörg',{tts:  'OctoPrint-Server wird gestartet'});
                                                    log ('__ OctoPrint-Server wird gestartet __');
                                                    setState (pfad + 'ShuttingDown', 'OctoPrint wird gestartet ...', true);
                                                    }, 6000);
                                    
                                    
                                                    //Geduld1...
                                                    setTimeout(function(){
                                                    setState (pfad + 'ShuttingDown', 'Geduld, Octoprint startet ...', true);
                                                    sendTo("paw.0",'Tablet_Jörg',{tts:  'Bitte noch etwas Geduld, Octoprint startet noch'});
                                                    //log ('__ Geduld, Octoprint ist bald bereit __');
                                                    }, 14000);
                                    
                                                    //Geduld2...
                                                    setTimeout(function(){
                                                    setState (pfad + 'ShuttingDown', 'Octoprint ist gleich verfügbar ...', true);
                                                    sendTo("paw.0",'Tablet_Jörg',{tts:  'Geduld, Octoprint ist gleich verfügbar'});
                                                    //log ('__ Geduld, Octoprint ist gleich verfügbar __');
                                                    }, 21000);
                                    }   //Ende function octopi_startup
                                    
                                    
                                    //____________________________________________________________________________________________________
                                    //OctoPi Online-Meldung, wenn Verbindung zum 3D-Drucker hergestellt wurde
                                    on({id: anycubic_verbindung, change: 'gt'}, function() {
                                    
                                            twentyfive = 0;
                                            fifty = 0;
                                            seventyfive = 0;
                                            ninety = 0;
                                            done = 0;
                                    
                                            //Druckzeiten zuruecksetzen
                                            setState("javascript.0.OctoPi.Restzeit", '---', true);
                                            setState('javascript.0.OctoPi.Printzeit', '---', true);
                                    
                                            var stat = getState('octoprint.0.printer_status').val;
                                            if (stat == 'Operational'){
                                                //log ('___ Status= ' + stat + '___');
                                                sendTo("paw.0",'Tablet_Jörg',{tts:  'Octoprint-Server ist onnnlein'});
                                                log ('__ Octoprint-Server ist online __');
                                                setState (pfad + 'ShuttingDown', 'OctoPrint ist online', true);
                                    
                                                //Aktualisieren des Views
                                                setTimeout(function(){
                                                setState("vis.0.control.command", '{"instance": "FFFFFFFF", "command": "changeView", "data": "Touch/Solaranlagen"}');
                                                }, 100);
                                    
                                                setTimeout(function(){
                                                setState("vis.0.control.command", '{"instance": "FFFFFFFF", "command": "changeView", "data": "Touch/Anycubic"}');
                                                }, 600);
                                     
                                                variablen_abfragen();
                                            }
                                    });
                                    
                                    //____________________________________________________________________________________________________
                                    // Wenn Steckdose ausgeschaltet wird, alles auf 0 setzen (fuer vis)
                                    on({id: octopi_steckdose, change: 'lt'}, function() {
                                            setState (anycubic_fortschritt, 0);
                                            setState (anycubic_timedone , 0);
                                            setState (anycubic_timeleft , 0);
                                            setState (anycubic_extrudertemp , 0);
                                            setState (anycubic_extrudertemp_soll , 0);
                                            setState (anycubic_tempbed , 0);
                                            setState (anycubic_tempbed_soll , 0);
                                            setState (anycubic_dateigroesse , 0);
                                            setState (anycubic_speicherort , '---');
                                            setState (anycubic_dateiname , '---');
                                        }
                                    );
                                    
                                    //____________________________________________________________________________________________________
                                    // Octoprint-Datenpunkte abfragen
                                    function variablen_abfragen(){
                                        //log ('___ Octoprint-Datenpunkte werden gelesen ___');
                                        lautstaerke();    
                                        var verbleibende_zeit   = getState(anycubic_timeleft).val;
                                        var bed_temp0           = getState(anycubic_tempbed).val;
                                        var bed_temp            = Math.round(bed_temp0 * 1) / 1;          // keine Nachkommastellen ansagen
                                        var extruder_temp0      = getState(anycubic_extrudertemp).val;
                                        var extruder_temp       = Math.round(extruder_temp0 * 1) / 1;     // keine Nachkommastellen ansagen
                                        var druck_fortschritt0  = getState(anycubic_fortschritt).val;
                                        var druck_fortschritt   = Math.round(druck_fortschritt0 * 1) / 1; // keine Nachkommastellen ansagen
                                        var dateigroesse        = getState(anycubic_dateigroesse).val;
                                    }   // Ende function variablen_abfragen
                                    
                                    
                                    
                                    //____________________________________________________________________________________________________
                                    //Ansage Druckfortschritt
                                    on({id: anycubic_fortschritt, change: 'any'}, function() {
                                        lautstaerke(); 
                                        var verbleibende_zeit   = getState(anycubic_timeleft).val;
                                        var bed_temp0           = getState(anycubic_tempbed).val;
                                        var bed_temp            = Math.round(bed_temp0 * 1) / 1;          // keine Nachkommastellen ansagen
                                        var extruder_temp0      = getState(anycubic_extrudertemp).val;
                                        var extruder_temp       = Math.round(extruder_temp0 * 1) / 1;     // keine Nachkommastellen ansagen
                                        var druck_fortschritt0  = getState(anycubic_fortschritt).val;
                                        var druck_fortschritt   = Math.round(druck_fortschritt0 * 1) / 1; // keine Nachkommastellen ansagen
                                        var fortschrSprache     = Math.round(druck_fortschritt0 * 10) / 10;   // 1 Nachkommastelle
                                        //var dateigroesse        = getState(anycubic_dateigroesse).val;
                                    
                                        //log ("fort: " + fortschrSprache);
                                        //log ("bett: " + bed_temp0);
                                        
                                    
                                    //Ansage des Druck-Fortschrittes bei 25%
                                    if(twentyfive == 0 ){
                                                if(fortschrSprache >= 25 && fortschrSprache <= 27 ){
                                                    setTimeout(function(){
                                                    sendTo("paw.0",'Tablet_Jörg',{tts:  'Der 3 Deeee Drucker hat ' + druck_fortschritt + 'Prozent des Ausdruckes fertiggestellt'});
                                                    }, 2000);
                                                    log ('__ AnyCubic ist zu ' + druck_fortschritt + '% fertig __');
                                                    twentyfive = 1;
                                                } // Ende if fortschrSprache >= 25
                                    
                                    }
                                    
                                    //Ansage des Druck-Fortschrittes bei 50%
                                    if(fifty == 0 ){
                                                if(fortschrSprache >= 50 && fortschrSprache <= 52 ){
                                                    setTimeout(function(){
                                                    sendTo("paw.0",'Tablet_Jörg',{tts:  'Der 3 Deeee Drucker hat ' + druck_fortschritt + 'Prozent des Ausdruckes fertiggestellt'});
                                                    }, 2000);
                                                    log ('__ AnyCubic ist zu ' + druck_fortschritt + '% fertig __');
                                                    fifty = 1;
                                                } // Ende if fortschrSprache >= 50
                                    }
                                    
                                    //Ansage des Druck-Fortschrittes bei 75%
                                    if(seventyfive == 0 ){
                                                if(fortschrSprache >= 75 && fortschrSprache <= 77 ){
                                                    setTimeout(function(){
                                                    sendTo("paw.0",'Tablet_Jörg',{tts:  'Der 3 Deeee Drucker hat ' + druck_fortschritt + 'Prozent des Ausdruckes fertiggestellt'});
                                                    }, 2000);
                                                    log ('__ AnyCubic ist zu ' + druck_fortschritt + '% fertig __');
                                                    seventyfive = 1;
                                                } // Ende if fortschrSprache >= 75
                                    }
                                    
                                    
                                    //Ansage des Druck-Fortschrittes bei 90%
                                    if(ninety == 0 ){
                                                if(fortschrSprache >= 90 && fortschrSprache <= 92 ){
                                                    setTimeout(function(){
                                                    sendTo("paw.0",'Tablet_Jörg',{tts:  'Der 3 Deeee Drucker hat ' + druck_fortschritt + 'Prozent des Ausdruckes fertiggestellt'});
                                                    }, 2000);
                                                    log ('__ AnyCubic ist zu ' + druck_fortschritt + '% fertig __');
                                                    ninety = 1;
                                                } // Ende if fortschrSprache >= 90
                                    }
                                    
                                    //____________________________________________________________________________________________________
                                    //Ansage, dass der Druck fertig ist, wenn Druckfortschritt = 100% und das Druckbett abgekuehlt ist
                                    if(done == 0 ){
                                    
                                                if(druck_fortschritt == 100 && bed_temp0 >= 48 && bed_temp0 <= 50 ){
                                                    setTimeout(function(){
                                                    sendTo("paw.0",'Tablet_Jörg',{tts:  'Der 3 Deeee Drucker hat den Ausdruck fertiggestellt und die Druckbett-Temperatur ist auf ' + bed_temp + ' Grad gefallen'});
                                                    }, 2000);
                                                    //sendTo("paw.0",'Tablet_Jörg',{play: true});  // sofort default sound notification abspielen
                                                    log ('__ AnyCubic ist fertig, HotBed: ' + bed_temp + '°C __');
                                                    done = 1;
                                                } // Ende if druck_fortschritt == 100
                                    }
                                    
                                    
                                    
                                    }); // Ende Ansage Druckfortschritte
                                    
                                    
                                    
                                    //____________________________________________________________________________________________________
                                    
                                    function lautstaerke(){
                                        // PAW-Lautstaerke auf Maximum setzen
                                        sendTo("paw.0",'all',{volume: 15});
                                    }
                                    
                                    function octo_adapter_on() {
                                        // Octoprint-Adapter einschalten
                                        var octo_instanz = getObject("system.adapter.octoprint.0");
                                        octo_instanz.common.enabled = true;
                                        setObject("system.adapter.octoprint.0", octo_instanz);
                                        //log ('__ Octoprint_Instanz wurde gestartet __');
                                    }
                                    
                                    
                                    function octo_adapter_off() {
                                        // Octoprint-Adapter ausschalten
                                        var octo_instanz = getObject("system.adapter.octoprint.0");
                                        octo_instanz.common.enabled = false;
                                        setObject("system.adapter.octoprint.0", octo_instanz);
                                        //log ('__ Octoprint_Instanz wurde beendet __');
                                    }
                                    
                                    // 
                                    function umrechnung() {
                                    // Umrechnung der Druckzeiten von Sekunden in HH:MM:SS
                                        var time_left = getState("octoprint.0.printjob.progress.printtime_left").val;
                                        var job_time  = getState('octoprint.0.printjob.progress.printtime').val;
                                    
                                        // Hours
                                        var hours_restzeit  =  Math.floor( time_left / 3600 );
                                        var hours_printzeit =  Math.floor( job_time  / 3600 );
                                        if ( hours_restzeit  < 10 ){var std_restzeit = "0" + String(hours_restzeit);}
                                            else var std_restzeit = String(hours_restzeit)
                                        if ( hours_printzeit < 10 ){var std_printzeit= "0" + String(hours_printzeit); }
                                            else var std_printzeit = String(hours_printzeit)
                                    
                                        // Minutes
                                        var minutes_restzeit  = Math.floor( (time_left%3600) / 60 );
                                        var minutes_printzeit = Math.floor( (job_time%3600)  / 60 );
                                        if ( minutes_restzeit  < 10 ){var min_restzeit = "0" + String(minutes_restzeit);}
                                            else var min_restzeit = String(minutes_restzeit)
                                        if ( minutes_printzeit < 10 ){var min_printzeit= "0" + String(minutes_printzeit); }
                                            else var min_printzeit = String(minutes_printzeit)
                                    
                                    
                                        // Seconds
                                        var seconds_restzeit  = Math.floor( time_left%60 );
                                        var seconds_printzeit = Math.floor( job_time%60  );
                                        if ( seconds_restzeit  < 10 ){var sec_restzeit = "0" + String(seconds_restzeit);}
                                            else var sec_restzeit = String(seconds_restzeit)
                                        if ( seconds_printzeit < 10 ){var sec_printzeit= "0" + String(seconds_printzeit); }
                                            else var sec_printzeit = String(seconds_printzeit)
                                    
                                    
                                    
                                        // Zeit in HH:MM:SS format
                                        var restzeit  = std_restzeit  + ':' + min_restzeit  + ':' + sec_restzeit;
                                        var printzeit = std_printzeit + ':' + min_printzeit + ':' + sec_printzeit;
                                    
                                        //console.log("Restzeit: " + restzeit);
                                        //console.log("Printzeit: " + printzeit);
                                    
                                        setState("javascript.0.OctoPi.Restzeit", restzeit, true);
                                        setState('javascript.0.OctoPi.Printzeit', printzeit, true);
                                    
                                    }
                                    

                                    Hinweise zum Script:
                                    Die Parameter/Objekte für die WLAN-Steckdose und Ping müssen natürlich an die eigenen Gegebenheiten angepasst werden.
                                    Username/Passwort für Octoprint-Raspi müssen im Script eingetragen werden.
                                    Bitte nicht über "komische" Schreibweisen, wie z.B. "Der 3 Deeee Drucker hat ...", wundern, die Sprachausgabe hört sich sonst über den PAW-Adapter blöd an.
                                    Wenn der Drucker online ist, wechsele ich kurz auf einen andere vis-View und dann wieder zum Drucker-View zurück, weil bei mir sonst der WebCam-Stream nicht angezeigt wurde. Kann man aber auch rausnehmen und den View manuell im Browser aktualisieren/refreshen.

                                    Bitte nicht falsch verstehen:
                                    Ich habe nur rudimentäres JS Halbwissen und habe mir das Script größtenteils mit Try & Error zusammengeschustert und kann deshalb nur bedingt Hilfestellung geben.

                                    Gruß
                                    Jörg

                                    P.S.
                                    Bei Alexa bin ich raus 🙄

                                    M 1 Reply Last reply Reply Quote 0
                                    • joergeli
                                      joergeli @HAL last edited by joergeli

                                      @HAL
                                      Ich habe mal versucht, meinen AnyCubic-View zu exportieren:
                                      AnyCubic-View.zip
                                      (Als Text-Datei konnte ich es nicht hochladen, da hier nur 10000 Zeichen erlaubt sind.)
                                      Ich hoffe, das ist richtig so? (Habe ich zum ersten Mal gemacht)

                                      AnyCubic-Viewt

                                      Beachte aber, daß da wohl auch die Navigations-Tabs und meine Temperatur-Gauges mit enthalten sind.
                                      Selbst erstellte Grafiken könnte ich bei Bedarf nachliefern.

                                      Gruß
                                      Jörg

                                      HAL Röstkartoffel Jürgen B. 0 3 Replies Last reply Reply Quote 0
                                      • HAL
                                        HAL @joergeli last edited by

                                        @joergeli

                                        Erstmal besten Dank ! VIS ist importiert und einiges funktioniert schon . Dein Script muss ich noch anpassen; bei mir spricht Alexa und das geht "ziemlich" anders. Aber kriege ich hin 🙂 Ich werde auch vermutlich die Temperatur des Hotend als Trigger für den Shutdown des Raspi verwenden ( shutdown wenn Hotend Temp < 50° ) aber vieles von Deinem Script kann ich verwenden ( bisher habe ich das meiste in Blocky abgebildet , mit native Java bin ich noch am Anfang)

                                        VG Uwe

                                        joergeli 1 Reply Last reply Reply Quote 0
                                        • joergeli
                                          joergeli @HAL last edited by

                                          @HAL
                                          Ich nehme für die Fertigmeldung

                                          druck_fortschritt == 100 && bed_temp0 >= 48 && bed_temp0 <= 50
                                          

                                          also wenn Druckfortschritt = 100% und Bett-Temperatur <= 50°C, d.h. der Drucker abgekühlt ist.
                                          Ausschalten mache ich lieber über vis, denn es kommt vor, daß ich nach dem ersten Ausdruck noch einen anderen Druck starten will. Kann man natürlich auch als Trigger zum automatischen Runterfahren verwenden.

                                          Vielleicht noch ein Hinweis zu den Variablen twentyfive, fifty, seventyfive, etc.:
                                          Je nach Größe des Druckes kommt es vor, daß der Druckfortschritt z.B. 50,1%, 50,6%, 50,8%, etc. ist.
                                          Das hat dazu geführt, daß mich mein Tablet (via PAW) vollgelabert hat.
                                          Durch die zusätzlichen Variablen setze ich einen Merker, daß die jeweilige Ansage bereits erfolgt ist und mein Tablet "sagt" nur 1 Mal, daß der Drucker z.B. 50% fertiggestellt hat.

                                          Noch ein Tip:
                                          Standardmäßig aktualisiert der Octoprint-Adapter seine Werte "nur" alle 60 Sekunden.
                                          Dieser Zeitraum war mir zu lang, deshalb habe ich die Aktualisierungsrate auf 5 Sekunden verkürzt, siehe hier:
                                          Octoprint-Adapter Aktualisierungsintevall

                                          Gruß
                                          Jörg

                                          Röstkartoffel 1 Reply Last reply Reply Quote 0
                                          • Röstkartoffel
                                            Röstkartoffel @joergeli last edited by

                                            @joergeli

                                            Danke für das Teilen deiner View und des Skriptes.

                                            Könntest du bitte die Grafiken ebenfalls hochladen? Danke.

                                            Desweiteren habe ich ein Problem, in der main.js den Aktivierungsintervall zu ändern, da ich den entsprechenden Passus nicht finden kann.
                                            Ich finde lediglich diese Textpassage, in der eine Zeitangabe vorkommt:

                                            ...
                                                    }
                                                    
                                                            this.log.debug('re-creating refresh state timeout');
                                                            this.refreshStateTimeout = setTimeout(this.refreshState.bind(this), 60000);
                                                        }
                                            ...
                                            

                                            Ich habe den Adapter ioBroker.octoprint v.0.0.2 von matthias@klein0r.de über Github installiert, dieser läuft auch richtig. Benutzt du einen anderen?

                                            joergeli Webranger 2 Replies Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            551
                                            Online

                                            31.6k
                                            Users

                                            79.4k
                                            Topics

                                            1.3m
                                            Posts

                                            42
                                            128
                                            19550
                                            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