Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Entwicklung
  4. [UMFRAGE] Besteht Interesse an einem Octoprint Adapter

NEWS

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    10
    1
    152

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    24
    1
    1.4k

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    9.4k

[UMFRAGE] Besteht Interesse an einem Octoprint Adapter

Geplant Angeheftet Gesperrt Verschoben Entwicklung
128 Beiträge 42 Kommentatoren 27.4k Aufrufe 28 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • RöstkartoffelR Röstkartoffel

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

    joergeliJ Online
    joergeliJ Online
    joergeli
    schrieb am zuletzt editiert von
    #84

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

    Gruß
    Jörg

    RöstkartoffelR 1 Antwort Letzte Antwort
    0
    • joergeliJ joergeli

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

      Gruß
      Jörg

      RöstkartoffelR Offline
      RöstkartoffelR Offline
      Röstkartoffel
      schrieb am zuletzt editiert von Röstkartoffel
      #85

      @joergeli

      Die 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 Ping
      

      Danke.

      Gruß
      Volker

      NUC7i3BNH mit Proxmox und ioBroker (VM Debian Buster), Raspi3 (Slave Smartmeter für eHZ easymeter), Hardware CCU2, SMA SB5000TL-21

      joergeliJ 1 Antwort Letzte Antwort
      0
      • RöstkartoffelR Röstkartoffel

        @joergeli

        Die 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 Ping
        

        Danke.

        Gruß
        Volker

        joergeliJ Online
        joergeliJ Online
        joergeli
        schrieb am zuletzt editiert von joergeli
        #86

        @Röstkartoffel
        Anbei das fehlende Bildchen:
        dialog-warning-2.png

        Ping:
        Das ist ein extra JS, mit dem ich alle meine (W)LAN-Geräte auf on-/offline prüfe.
        Im Octoprint-Script prüft es nur, ob der Octoprint-Raspi online ist, bevor verschiedene States abgefragt werden.
        Es würde m.E. hier zu weit führen, das auch noch zu verhackstücken.

        Edit 17.01.2020: Ich habe den "PING-Abschnitt" jetzt kpl. aus dem Script entfernt, der war unnötig.

        1 Antwort Letzte Antwort
        1
        • RöstkartoffelR Röstkartoffel

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

          WebrangerW Offline
          WebrangerW Offline
          Webranger
          schrieb am zuletzt editiert von
          #87

          @Röstkartoffel

          Bei mir sieht das auch so aus.

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

          hab es getestet und Aktuallisiert nun alle 5 sec

          Kann das nachteile für den druck geben weil jetzt höhere abfrage am octoprint?

          Intel NUC Celeron, Xiaomi Gateway, Fritzbox 7590, XS1

          joergeliJ 1 Antwort Letzte Antwort
          1
          • WebrangerW Webranger

            @Röstkartoffel

            Bei mir sieht das auch so aus.

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

            hab es getestet und Aktuallisiert nun alle 5 sec

            Kann das nachteile für den druck geben weil jetzt höhere abfrage am octoprint?

            joergeliJ Online
            joergeliJ Online
            joergeli
            schrieb am zuletzt editiert von joergeli
            #88

            @Webranger
            Ich habe keine Nachteile festgestellt, das schafft der Raspi locker.

            1 Antwort Letzte Antwort
            0
            • joergeliJ 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

              RöstkartoffelR Offline
              RöstkartoffelR Offline
              Röstkartoffel
              schrieb am zuletzt editiert von
              #89

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

              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

              Moin Jörg.

              Ich habe jetzt deine View an meine Umgebung angepasst und benötige jetzt noch die von dir in den Widgets eingetragenen CSS-Klassen und zwar:
              blinkklasse, horizontalzentrieren, rotate-20 und blinkklasse_langsam

              Kannst du diese bitte auch hochladen und sagen, woher du diese Klassen hast?

              Danke.

              NUC7i3BNH mit Proxmox und ioBroker (VM Debian Buster), Raspi3 (Slave Smartmeter für eHZ easymeter), Hardware CCU2, SMA SB5000TL-21

              joergeliJ 1 Antwort Letzte Antwort
              0
              • RöstkartoffelR Röstkartoffel

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

                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

                Moin Jörg.

                Ich habe jetzt deine View an meine Umgebung angepasst und benötige jetzt noch die von dir in den Widgets eingetragenen CSS-Klassen und zwar:
                blinkklasse, horizontalzentrieren, rotate-20 und blinkklasse_langsam

                Kannst du diese bitte auch hochladen und sagen, woher du diese Klassen hast?

                Danke.

                joergeliJ Online
                joergeliJ Online
                joergeli
                schrieb am zuletzt editiert von
                #90

                @Röstkartoffel
                anbei die CSS-Einstellungen:

                
                .horizontalzentrieren div {
                    display: flex;
                    align-items: center; /* vertikal*/
                    justify-content: center; /* horizontal */
                }
                
                .rotate-20{
                transform: rotate(-20deg);
                }
                .rotate90{
                transform: rotate(90deg);
                }
                .rotate-90{
                transform: rotate(-90deg);
                }
                
                
                .blinkklasse {
                  animation: blink 0.5s linear infinite;
                }
                .blinkklasse_langsam {
                  animation: blink 1.5s linear infinite;
                }
                .blinkklasse_schnell {
                  animation: blink 0.002s linear infinite;
                }
                
                @keyframes blink {
                  0%, 25% {
                    opacity: 0.2;
                  }
                  25.01%, 50% {
                    opacity: 0.4;
                  }
                  50.01%, 75% {
                    opacity: 0.8;
                  } 
                  75.01%, 100% {
                    opacity: 1;
                  }
                }
                
                

                Die habe ich mir irgendwo "ausgeliehen", bzw. ergoogelt.

                Gruß
                Jörg

                1 Antwort Letzte Antwort
                0
                • B Offline
                  B Offline
                  bishop
                  schrieb am zuletzt editiert von bishop
                  #91

                  @haus-automatisierung

                  ist es auch möglich in den Adapter ein DP einzufügen mit dem man die X,Y,Z, achsen steuern kann?

                  1 Antwort Letzte Antwort
                  0
                  • ? Offline
                    ? Offline
                    Ein ehemaliger Benutzer
                    schrieb am zuletzt editiert von
                    #92

                    Moin,

                    funktionieren die links zu github nicht mehr?

                    Die Installation über die Github Links auch über die Konsole klappen nicht.

                    Über die Links installiert er irgendwas wohl aber keine Instanz erscheint auch nach einem Neustart nicht.

                    Über die Konsole kommen nur Error Meldungen.
                    Tobias

                    1 Antwort Letzte Antwort
                    0
                    • joergeliJ 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 :face_with_rolling_eyes:

                      M Offline
                      M Offline
                      martin
                      schrieb am zuletzt editiert von
                      #93

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

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

                      Danke für deinen Hinweis im anderen Beitrag.
                      Wo genau muss denn das Script jetzt hin? Unter Skripte oder in die VIS?

                      GlasfaserG 1 Antwort Letzte Antwort
                      0
                      • M martin

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

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

                        Danke für deinen Hinweis im anderen Beitrag.
                        Wo genau muss denn das Script jetzt hin? Unter Skripte oder in die VIS?

                        GlasfaserG Offline
                        GlasfaserG Offline
                        Glasfaser
                        schrieb am zuletzt editiert von
                        #94

                        @martin

                        Wo genau muss denn das Script jetzt hin? Unter Skripte oder in die VIS?

                        in JS unter Scripte .

                        kennst du nicht den Adapter Link Text

                        Synology 918+ 16GB - ioBroker in Docker v9 , VISO auf Trekstor Primebook C13 13,3" , Hikvision Domkameras mit Surveillance Station .. CCU RaspberryMatic in Synology VM .. Zigbee CC2538+CC2592 .. Sonoff .. KNX .. Modbus ..

                        M 1 Antwort Letzte Antwort
                        0
                        • GlasfaserG Glasfaser

                          @martin

                          Wo genau muss denn das Script jetzt hin? Unter Skripte oder in die VIS?

                          in JS unter Scripte .

                          kennst du nicht den Adapter Link Text

                          M Offline
                          M Offline
                          martin
                          schrieb am zuletzt editiert von
                          #95

                          @Glasfaser Doch, den habe ich auch installiert.
                          Wie genau muss das Skript heißen um nicht in der View alles ändern zu müssen?
                          Da ist auch im View immer ein Script "OctoPi.ShuttingDown". Ist das dieses hier? Oder noch ein anderes?

                          GlasfaserG 1 Antwort Letzte Antwort
                          0
                          • M martin

                            @Glasfaser Doch, den habe ich auch installiert.
                            Wie genau muss das Skript heißen um nicht in der View alles ändern zu müssen?
                            Da ist auch im View immer ein Script "OctoPi.ShuttingDown". Ist das dieses hier? Oder noch ein anderes?

                            GlasfaserG Offline
                            GlasfaserG Offline
                            Glasfaser
                            schrieb am zuletzt editiert von
                            #96

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

                            Wie genau muss das Skript heißen

                            Das ist egal .
                            Ausschlaggebend sind die Datenpunkt die das Script erzeugt , brauchst also nicht´s weiter machen außer das Script zu starten .

                            Synology 918+ 16GB - ioBroker in Docker v9 , VISO auf Trekstor Primebook C13 13,3" , Hikvision Domkameras mit Surveillance Station .. CCU RaspberryMatic in Synology VM .. Zigbee CC2538+CC2592 .. Sonoff .. KNX .. Modbus ..

                            M 1 Antwort Letzte Antwort
                            0
                            • GlasfaserG Glasfaser

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

                              Wie genau muss das Skript heißen

                              Das ist egal .
                              Ausschlaggebend sind die Datenpunkt die das Script erzeugt , brauchst also nicht´s weiter machen außer das Script zu starten .

                              M Offline
                              M Offline
                              martin
                              schrieb am zuletzt editiert von martin
                              #97

                              @Glasfaser Danke!

                              Ich konnte es jetzt so weit ändern. Was mir noch fehlt ist anstatt des weißen Kastens oben das Zeichen vom Raspberry. Das Bild habe ich zwar hochgeladen aber das Widget dazu fehlt mir.

                              alt text

                              GlasfaserG joergeliJ 2 Antworten Letzte Antwort
                              0
                              • M martin

                                @Glasfaser Danke!

                                Ich konnte es jetzt so weit ändern. Was mir noch fehlt ist anstatt des weißen Kastens oben das Zeichen vom Raspberry. Das Bild habe ich zwar hochgeladen aber das Widget dazu fehlt mir.

                                alt text

                                GlasfaserG Offline
                                GlasfaserG Offline
                                Glasfaser
                                schrieb am zuletzt editiert von
                                #98

                                @martin

                                Die View habe ich so eigentlich nicht .... habe mal eben alles bei mir eingefügt .... ist alles da !

                                Die Bilder werden erst bei den Bedingungen false/true vom Datenpunkt ...Shutdown angezeigt !!

                                1.JPG

                                Synology 918+ 16GB - ioBroker in Docker v9 , VISO auf Trekstor Primebook C13 13,3" , Hikvision Domkameras mit Surveillance Station .. CCU RaspberryMatic in Synology VM .. Zigbee CC2538+CC2592 .. Sonoff .. KNX .. Modbus ..

                                1 Antwort Letzte Antwort
                                0
                                • M martin

                                  @Glasfaser Danke!

                                  Ich konnte es jetzt so weit ändern. Was mir noch fehlt ist anstatt des weißen Kastens oben das Zeichen vom Raspberry. Das Bild habe ich zwar hochgeladen aber das Widget dazu fehlt mir.

                                  alt text

                                  joergeliJ Online
                                  joergeliJ Online
                                  joergeli
                                  schrieb am zuletzt editiert von
                                  #99

                                  @martin
                                  Evtl. ist bei Dir in ioBroker das Fancyswitch-Widget, mit dem ich den "Kippschalter" gebastelt habe, in ioBroker nicht installiert ?: ---> Nachinstallieren
                                  iob-fancyswitch.gif

                                  Wenn sie installiert sind/wurden, sollten in VIS unter "Widget einfügen" der entspr.
                                  "Switch light Off/On" vorhanden sein:
                                  fancyswitch Schalter.gif

                                  Du kannst aber auch jedes andere On/Off-Widget verwenden.

                                  Nur ein Hinweis:
                                  Oben in der "Verbindungsübersicht" werden die Bildchen je nach Status der Datenpunkte angezeigt.
                                  Teilweise liegen die Bildchen, als auch Texte übereinander (ist nur im VIS-Editor sichtbar).
                                  Sie sind teilweise auch über den z-index der Widgets geschichtet.

                                  Layer.gif

                                  Gruß
                                  Jörg

                                  M 1 Antwort Letzte Antwort
                                  0
                                  • joergeliJ joergeli

                                    @martin
                                    Evtl. ist bei Dir in ioBroker das Fancyswitch-Widget, mit dem ich den "Kippschalter" gebastelt habe, in ioBroker nicht installiert ?: ---> Nachinstallieren
                                    iob-fancyswitch.gif

                                    Wenn sie installiert sind/wurden, sollten in VIS unter "Widget einfügen" der entspr.
                                    "Switch light Off/On" vorhanden sein:
                                    fancyswitch Schalter.gif

                                    Du kannst aber auch jedes andere On/Off-Widget verwenden.

                                    Nur ein Hinweis:
                                    Oben in der "Verbindungsübersicht" werden die Bildchen je nach Status der Datenpunkte angezeigt.
                                    Teilweise liegen die Bildchen, als auch Texte übereinander (ist nur im VIS-Editor sichtbar).
                                    Sie sind teilweise auch über den z-index der Widgets geschichtet.

                                    Layer.gif

                                    Gruß
                                    Jörg

                                    M Offline
                                    M Offline
                                    martin
                                    schrieb am zuletzt editiert von
                                    #100

                                    @joergeli Danke. Das Fancyswitch-Widget hat gefehlt. Jetzt sieht es besser aus. Testen kann ich es jedoch erst die nächsten Tage.

                                    M 1 Antwort Letzte Antwort
                                    0
                                    • M martin

                                      @joergeli Danke. Das Fancyswitch-Widget hat gefehlt. Jetzt sieht es besser aus. Testen kann ich es jedoch erst die nächsten Tage.

                                      M Offline
                                      M Offline
                                      martin
                                      schrieb am zuletzt editiert von martin
                                      #101

                                      Danke. Jetzt sieht es so aus.
                                      Das Widget mit der Druckzeit fehlt mir noch. Auf welchen Datenpunkt bezieht sich das?

                                      alt text

                                      joergeliJ 1 Antwort Letzte Antwort
                                      0
                                      • M martin

                                        Danke. Jetzt sieht es so aus.
                                        Das Widget mit der Druckzeit fehlt mir noch. Auf welchen Datenpunkt bezieht sich das?

                                        alt text

                                        joergeliJ Online
                                        joergeliJ Online
                                        joergeli
                                        schrieb am zuletzt editiert von joergeli
                                        #102

                                        @martin
                                        Bitte Bilder direkt hier hochladen ( über das Wolkensymbol mit Pfeil nach oben).
                                        Der direkte Link aus dem Forum auf das externe Bild funktioniert nicht, nur wenn man den Linktext kopiert und direkt in einem neuen Tab im Browser einfügt.

                                        Die Druckzeiten werden mit 2 Widgets "basic - String" gebildet.
                                        Datenpunkt für vergangene Zeit : javascript.0.OctoPi.Printzeit
                                        Datenpunkt für Restzeit: javascript.0.OctoPi.Restzeit

                                        Octoprint-Restzeit.jpg

                                        Beachte, daß diese Datenpunkte erst durch mein Java-Script angelegt, bzw. befüllt werden.
                                        Ich habe deshalb 2 neue Datenpunkte erstellt, weil die originalen die Datenpunkte octoprint.0.printjob.progress.printtime und octoprint.0.printjob.progress.printtime_left die Zeiten nur in Sekunden ausgeben.

                                        Im Script werden die Sekunden in Std:Min:Sek umgerechnet und dann die beiden neuen Datenpunkte damit befüllt.
                                        Ist halt leichter lesbar, als z.B. 37190 Sekunden :blush:

                                        1 Antwort Letzte Antwort
                                        0
                                        • M Offline
                                          M Offline
                                          martin
                                          schrieb am zuletzt editiert von
                                          #103

                                          Vielen Dank. Habe ich verstanden.
                                          In dem Widget unter dem Test "Druckzeit" steht allerdings nur bei Name "Gruppe Druckzeiten" drin und sonst nichts.
                                          Kannst du vielleicht dieses Widget nochmal hochladen?

                                          joergeliJ 1 Antwort Letzte Antwort
                                          0
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          426

                                          Online

                                          32.5k

                                          Benutzer

                                          81.7k

                                          Themen

                                          1.3m

                                          Beiträge
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Anmelden

                                          • Du hast noch kein Konto? Registrieren

                                          • Anmelden oder registrieren, um zu suchen
                                          • Erster Beitrag
                                            Letzter Beitrag
                                          0
                                          • Home
                                          • Aktuell
                                          • Tags
                                          • Ungelesen 0
                                          • Kategorien
                                          • Unreplied
                                          • Beliebt
                                          • GitHub
                                          • Docu
                                          • Hilfe