NEWS
[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!@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

-
@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

@George_Best Dann schreib doch auch die L
ö
sung hier auf falls mal einer die Suche benutzt und genau das sucht 
-
@George_Best Dann schreib doch auch die L
ö
sung hier auf falls mal einer die Suche benutzt und genau das sucht 
@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. -
@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> -
@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.Gerade mal getestet und l
ä
uft super. Danke daf
ü
r -
@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.@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 -
@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@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
ö
rgHallo J
ö
rg,sehr, sehr gerne darfst du das anpassen. Wow
- deine Umsetzung ist nat
ü
rlich die Profi-Version! Klasse Beitrag! -
@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
ö
rgHallo J
ö
rg,sehr, sehr gerne darfst du das anpassen. Wow
- deine Umsetzung ist nat
ü
rlich die Profi-Version! Klasse Beitrag!@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 -
@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
ö
rgAber irgendwas passt noch nicht so richtig oder?
Druckdauer/Printtime
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) -
Aber irgendwas passt noch nicht so richtig oder?
Druckdauer/Printtime
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)@Webranger
Jepp, Copy & Paste Fehler meinerseits.Sorry
J
ö
rg -
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. 
-
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. 
@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 EinstiegAls 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
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 EinstiegAls 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@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
-
@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 EinstiegAls 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@ 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
ö
rgP.S.
Bei Alexa bin ich raus
-
@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
@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)
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
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)
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
ö
rgErstmal 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
-
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
@HAL
Ich nehme f
ü
r die Fertigmeldungdruck_fortschritt == 100 && bed_temp0 >= 48 && bed_temp0 <= 50also 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 AktualisierungsintevallGru
ß
J
ö
rg -
@HAL
Ich nehme f
ü
r die Fertigmeldungdruck_fortschritt == 100 && bed_temp0 >= 48 && bed_temp0 <= 50also 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 AktualisierungsintevallGru
ß
J
ö
rgDanke 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? -
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?@R
ö
stkartoffel
Hi, ich habe auch den Octoprint-Adapter V 0.0.2 installiert, allerdings - soweit ich mich erinnere - ganz normal
ü
ber die ioBroker Adapterliste.
Bei mir gibt es eine Datei /iobroker/node_modules/iobroker.octoprint/main.js und darin hatte ich ich der function main() das Intervall auf 5000 ( = 5 Sekunden) ge
ä
ndert:function main() { adapter.subscribeStates('*'); adapter.setState('printer_status', {val: printerStatus, ack: true}); // Refresh State every 5 seconds refreshState(); setInterval(refreshState, 5000); .....Hast Du auch die richtige main.js im Ordner /iobroker/node_modules/iobroker.octoprint/main.js ausgew
ä
hlt?
Falls Deine main.js - aus welchen Gr
ü
nden auch immer - anders aussieht, kann ich dazu leider nichts sagen.
Aber probier doch einfach mal, in Deiner main.js die 60000 auf 5000 zu
ä
ndern (vorher aber backup der main.js machen).
Danach die Octoprint-Instanz neu starten (wichtig!).Anbei meine GIF-Bilder (ich hoffe, ich habe keins vergessen)
octoprint-gifs.zipGru
ß
J
ö
rg -
@R
ö
stkartoffel
Hi, ich habe auch den Octoprint-Adapter V 0.0.2 installiert, allerdings - soweit ich mich erinnere - ganz normal
ü
ber die ioBroker Adapterliste.
Bei mir gibt es eine Datei /iobroker/node_modules/iobroker.octoprint/main.js und darin hatte ich ich der function main() das Intervall auf 5000 ( = 5 Sekunden) ge
ä
ndert:function main() { adapter.subscribeStates('*'); adapter.setState('printer_status', {val: printerStatus, ack: true}); // Refresh State every 5 seconds refreshState(); setInterval(refreshState, 5000); .....Hast Du auch die richtige main.js im Ordner /iobroker/node_modules/iobroker.octoprint/main.js ausgew
ä
hlt?
Falls Deine main.js - aus welchen Gr
ü
nden auch immer - anders aussieht, kann ich dazu leider nichts sagen.
Aber probier doch einfach mal, in Deiner main.js die 60000 auf 5000 zu
ä
ndern (vorher aber backup der main.js machen).
Danach die Octoprint-Instanz neu starten (wichtig!).Anbei meine GIF-Bilder (ich hoffe, ich habe keins vergessen)
octoprint-gifs.zipGru
ß
J
ö
rgDie main.js ist in diesem Ordner "/opt/iobroker/node_modules/iobroker.octoprint", richtig?Ich habe eben mal auf GitHub geschaut, dort steht bei der aktuellen Version folgender Change vom 20. Oktober 2019: "setTimeout instead of setInterval".
Wenn ich mir den Fork von resper vom 21. Januar 2019 ansehe, finde ich eine andere main.js und dort auch deine Eintr
ä
ge.Ich werde in der mir vorliegenden main.js die 60000 auf 5000
ä
ndern und mal schauen, was passiert.In deiner zip fehlt leider folgendes Bild: dialog-warning-2.png
K
ö
nntest du dieses bitte auch hochladen?Du machst mit einem Javascript einen Ping auf den OctoPi, kannst du dieses bitte auch bereitstellen?
const ping_octoprint = 'javascript.0.ping.Raspi Octoprint' //Octoprint PingDanke.
Gru
ß
Volker
Hey! Du scheinst an dieser Unterhaltung interessiert zu sein, hast aber noch kein Konto.
Hast du es satt, bei jedem Besuch durch die gleichen Beiträge zu scrollen? Wenn du dich für ein Konto anmeldest, kommst du immer genau dorthin zurück, wo du zuvor warst, und kannst dich über neue Antworten benachrichtigen lassen (entweder per E-Mail oder Push-Benachrichtigung). Du kannst auch Lesezeichen speichern und Beiträge positiv bewerten, um anderen Community-Mitgliedern deine Wertschätzung zu zeigen.
Mit deinem Input könnte dieser Beitrag noch besser werden 💗
Registrieren Anmelden