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

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    14
    1
    332

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    601

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    1.8k

[UMFRAGE] Besteht Interesse an einem Octoprint Adapter

Geplant Angeheftet Gesperrt Verschoben Entwicklung
128 Beiträge 42 Kommentatoren 27.7k 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.
  • VanduraV Vandura

    Einfach nur mal Danke sagen......
    Nachdem ich mich Lange hier belesen habe und die Vis als Anregung genommen habe, habe ich jetzt alles soweit hinbekommen, dass es läuft......
    Octopi.jpg
    Danke für eure Unermüdliche Arbeit, die es so einem wie mir einfacher machen sich in die Materie einzufinden.

    Grüße Rick

    blue231181B Offline
    blue231181B Offline
    blue231181
    schrieb am zuletzt editiert von Negalein
    #109

    Hallo zusammen,

    ich hoffe Ihr könnt mir helfen.
    Ich bekomme folgende Meldung:

    octoprint.0 2023-02-10 10:33:03.690	info	error ECONNRESET from /api/connection: socket hang up
    octoprint.0 2023-02-10 10:34:03.691	info	error ECONNRESET from /api/connection: socket hang up
    octoprint.0 2023-02-10 10:33:03.690	info	error ECONNRESET from /api/connection: socket hang up
    octoprint.0 2023-02-10 10:32:03.696	info	error ECONNRESET from /api/connection: socket hang up
    octoprint.0 2023-02-10 10:31:03.678	info	error ECONNRESET from /api/connection: socket hang up
    

    Der Adapter ist verbunden
    Octoprint.jpg

    API wurde mehrmals gecheckt und ist korrekt eingetragen jedoch zeigt es mir:
    Octoprint2.jpg

    Danke im voraus

    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

      Jürgen B. 0J Offline
      Jürgen B. 0J Offline
      Jürgen B. 0
      schrieb am zuletzt editiert von Jürgen B. 0
      #110

      @joergeli hi, erstmal allen Respekt für dieses Arbeit und tolle Leistung. Leider kommen da für mich Fragen bzgl. dem Skript auf. Ich würde das gerne bei mir reinkopieren. Wärst du so nett und hilfst mir da weiter?

      1. Wo ändere ich den User und das Passwort? (Zeile)
      2. Zeile 4? wie kann ich das node-ssh in Javascript-Adapter installieren?
      3. Wie pflege ich das entsprechend im VIS-Editor ein?

      Entschuldige die Fragen, ich bin da in der Hinsicht ein Neuling. Es interessiert mich aber unheimlich.

      Vielen Dank schon mal für die Unterstützung.
      VG
      Jucky

      joergeliJ 1 Antwort Letzte Antwort
      0
      • Jürgen B. 0J Jürgen B. 0

        @joergeli hi, erstmal allen Respekt für dieses Arbeit und tolle Leistung. Leider kommen da für mich Fragen bzgl. dem Skript auf. Ich würde das gerne bei mir reinkopieren. Wärst du so nett und hilfst mir da weiter?

        1. Wo ändere ich den User und das Passwort? (Zeile)
        2. Zeile 4? wie kann ich das node-ssh in Javascript-Adapter installieren?
        3. Wie pflege ich das entsprechend im VIS-Editor ein?

        Entschuldige die Fragen, ich bin da in der Hinsicht ein Neuling. Es interessiert mich aber unheimlich.

        Vielen Dank schon mal für die Unterstützung.
        VG
        Jucky

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

        @jürgen-b-0 sagte in [UMFRAGE] Besteht Interesse an einem Octoprint Adapter:

        1.) Wo ändere ich den User und das Passwort? (Zeile)
        2.) Zeile 4? wie kann ich das node-ssh in Javascript-Adapter installieren?
        3.) Wie pflege ich das entsprechend im VIS-Editor ein?

        1.) User/Passwort: bei //Octoprint-Server via SSH herunterfahren - in der setTimeout(function() ab Zeile 150
        2.) node-ssh manuell in den Einstellungen des JavaScript-Adapters hinzufügen/reinschreiben:
        node-ssh.jpg
        Das dauert dann einen Moment, bis node-ssh installiert wurde.
        In den JavaSript-Einstellungen auch den Haken bei Kommandoe "exec" erlauben nicht vergessen!

        3.) Anbei mein vis-View nochmals als Export, den kannst Du importieren und Dich daran orientieren.
        Natürlich musst Du darin die Pfade anpassen, in denen die Bildchen, etc. gespeichert sind!

        Sieht jetzt so aus:
        octo-view_export.zip

        octo.jpg

        #######################################################################################

        Ich hatte mein Script zwischenzeitlich noch mal editiert, bzgl. zusätzlichen Ausgaben von Fertigstellungszeit / -Datum.
        Außerdem habe ich noch einen Schalter eingebaut, mit dem in der vis ausgewählt werden kann, ob der Drucker nach Fertigstellung und Abkühlung automatisch ausgeschaltet werden soll, oder nicht.
        Zusätzlich noch ein paar Buttons für X/Y-Positionierung des Druckkopfes.
        Dazu müssen in den vis-Buttons entspr. Werte eingetragen werden, z.B. so:
        xy.jpgxy-einstellungen.jpg

        autoshutdown.jpg
        autoshutdown-einstellungen.jpg

        Beachte bitte, daß ich die Sprachausgabe mit PAW mache, das musst Du sehr wahrscheinlich an Deine Gegebenheiten anpassen ( Alexa, Telegram, o.ä.)

        Anbei mein aktuelles Script:

        //#####################################################################
        // 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' // Shelly Plug S Steckdose Octopi und 3D-Drucker
        const octopi_autoshutdown           = 'javascript.0.OctoPi.AutoShutdown'        // Drucker nach Druckende autom. ausschalten
        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.printtimeLeft'
        
        
        const anycubic_extrudertemp         = 'octoprint.0.tools.tool0.actualTemperature'
        const anycubic_extrudertemp_soll    = 'octoprint.0.tools.tool0.targetTemperature'
        const anycubic_tempbed              = 'octoprint.0.tools.bed.actualTemperature'
        const anycubic_tempbed_soll         = 'octoprint.0.tools.bed.targetTemperature'
        
        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'
        const anycubic_laenge               = 'octoprint.0.printjob.filament.length'
        const anycubic_volumen              = 'octoprint.0.printjob.filament.volume'
        
        const anycubic_gesamtlayer          = 'octoprint.0.plugins.displayLayerProgress.layer.total'
        const anycubic_currentlayer         = 'octoprint.0.plugins.displayLayerProgress.layer.current'
        
        var pfad = 'javascript.0.OctoPi.';
        
        const {NodeSSH} = require('node-ssh')
        const ssh = new NodeSSH()
        
        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'
        });
        
        createState('javascript.0.OctoPi.Gesamtzeit', {
            name: 'Gesamtzeit',
            desc: 'Gesamtdauer des Druckjobs',
            type: 'string',
        });
        
        
        
        createState( pfad + 'EndeZeit', {
            name: 'EndeZeit',
            desc: 'Uhrzeit Fertigstellung des Druckes',
            type: 'string'
        });
        
        createState( pfad + 'AutoShutdown', {
            name: 'AutoShutdown',
            desc: 'Drucker nach Druckende ausschalten',
            type: 'boolean'
        });
        
        
        
        //______ 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) {
                var autoshut = false;
                octopi_startup();
            }
        });
        
        
        //____________________________________________________________________________________________________
        // Umrechnung der Druckzeiten von Sekunden in HH:MM:SS und Ende-Zeit berechnen
        on({id: [anycubic_timeleft], change: "lt"} , function (obj) {
            umrechnung();
            EndeZeit();
        });
        
        
        
        
        //____________________________________________________________________________________________________
        function octopi_shutdown() {
                        lautstaerke_tablet();  // Lautstaerke Tablet auf 13 setzen
        
                        twentyfive = 0;
                        fifty = 0;
                        seventyfive = 0;
                        ninety = 0;
                        done = 0;              
        
                        //ioBroker OctoPi-Instanz beenden
                        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 und Layer zuruecksetzen
                        setState("javascript.0.OctoPi.Restzeit", '---', true);
                        setState('javascript.0.OctoPi.Printzeit', '---', true);
                        setState("javascript.0.OctoPi.EndeZeit", '---', true);
        				setState("javascript.0.OctoPi.Gesamtzeit", '---', true);
                      
        				setState("javascript.0.OctoPi.AutoShutdown", false, true);
        				setState("javascript.0.OctoPi.Shutdown", true, true);
                        
                        setState('octoprint.0.plugins.displayLayerProgress.layer.averageDuration', 0, true);
                        setState('octoprint.0.plugins.displayLayerProgress.layer.current', 0, true);
                        setState('octoprint.0.plugins.displayLayerProgress.layer.total', 0, true);
                        }, 5000);
        
                        //Octoprint-Server via SSH herunterfahren
                        setTimeout(function(){
                        //log ('__ SSH Verbindung gestartet __');
                        //SSH-Session starten, um Octoprint-Raspi sauber! herunterzufahren
                            ssh.connect({
                                host: '192.168.192.30', //IP-Adresse des Octoprint-Raspi
                                username: 'pi',         //Username Octoprint-Raspi (normalerweise pi)
                                password: 'xxxxxxxx'    //Passwort Octoprint-Raspi
                            }).then(() => {
                                ssh.execCommand('echo "xxxxxxxx"|sudo -S shutdown -h now');
                                // Achtung! Im execCommand muss nochmals das Passwort für den Octoprint-Raspi eingetragen werden
                            });                           
        
                        }, 6000);   // 6 Sekunden warten
        
                        //Sprachansage, dass Octopi heruntergefahren wird
                        setTimeout(function(){
                        sendTo("paw.0",'Tablet_Jörg',{tts:  'Shutdown 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 down'});
                        //log ('__ Octoprint-Server ist down __');
                        setState (pfad + 'ShuttingDown', 'OctoPrint ist down ...', true);
                        }, 18000);
        
                        //OctoPi- Shelly Plug S - Steckdose ausschalten
                        setTimeout(function(){         
                        setState(octopi_steckdose, false);
                        sendTo("paw.0",'Tablet_Jörg',{tts:  'OctoPrint-Steckdose und 3 D-Drucker sind ausgeschaltet'});
                        log ('OctoPi-Steckdose ausgeschaltet');
                        setState (pfad + 'ShuttingDown', 'OctoPrint ist ausgeschaltet', true);
                        setState("javascript.0.OctoPi.EndeZeit", '---', true);
                        }, 24000);
        
        }   // Ende function octopi_shutdown
        
        //____________________________________________________________________________________________________
        function octopi_startup() {
                        lautstaerke_tablet();
        
                        twentyfive = 0;
                        fifty = 0;
                        seventyfive = 0;
                        ninety = 0;
                        done = 0;
        
                        //Druckzeiten und Layer  zuruecksetzen
                        setState("javascript.0.OctoPi.Restzeit", '---', true);
                        setState('javascript.0.OctoPi.Printzeit', '---', true);
                        setState("javascript.0.OctoPi.EndeZeit", '---', true);
        				setState("javascript.0.OctoPi.Gesamtzeit", '---', true);
        
                        setState("javascript.0.OctoPi.AutoShutdown", false, true);
        
        
                        setState('octoprint.0.plugins.displayLayerProgress.layer.averageDuration', 0, true);
                        setState('octoprint.0.plugins.displayLayerProgress.layer.current', 0, true);
                        setState('octoprint.0.plugins.displayLayerProgress.layer.total', 0, true);
                        setState('octoprint.0.printjob.progress.completion', 0, true);
                        //OctoPi-Instanz starten, wenn Octopi-Raspi kpl. hochgefahren ist
                        setTimeout(function(){
                        octo_adapter_on();
                        //sendTo("paw.0",'Tablet_Jörg',{tts:  'Octoprint Instanz wurde gestartet'});
                        log('Octoprint Instanz wurde gestartet');
                        }, 45000);
        
        
                        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);
                        }, 10000);
        
                        //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 startet ...');
                        }, 20000);
        
                        //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');
                        }, 35000);
        
                        setTimeout(function(){
                        // Steckdose einschalten
                        setState(octopi_steckdose, true);
                        setState (pfad + 'ShuttingDown', '3D Drucker wurde eingeschaltet ...', true);
                        log('3D Drucker wurde eingeschaltet ...');
                        sendTo("paw.0",'Tablet_Jörg',{tts:  'Der 3Dee Drucker wurde eingeschaltet'});
                        }, 100);
        
        
        
        
        }   //Ende function octopi_startup
        
        
        //____________________________________________________________________________________________________
        //OctoPi Online-Meldung, wenn Verbindung zum 3D-Drucker hergestellt wurde
        on({id: anycubic_verbindung, change: 'gt'}, function() {
                lautstaerke_tablet();
                
                twentyfive = 0;
                fifty = 0;
                seventyfive = 0;
                ninety = 0;
                done = 0;
        
                //Druckzeiten und Layer  zuruecksetzen
                setState("javascript.0.OctoPi.Restzeit", '---', true);
                setState('javascript.0.OctoPi.Printzeit', '---', true);
                setState("javascript.0.OctoPi.EndeZeit", '---', true);
        		setState("javascript.0.OctoPi.Gesamtzeit", '---', true);
                setState('octoprint.0.plugins.displayLayerProgress.layer.current', 0, true);
                setState('octoprint.0.plugins.displayLayerProgress.layer.total', 0, 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 online'});
                    log ('Octoprint-Server ist online');
                    setState (pfad + 'ShuttingDown', 'OctoPrint ist online', true);
        
                    variablen_abfragen();
        
                }
        }); // Ende Meldung Verbindungsherstellung
        
        
        //____________________________________________________________________________________________________
        
        // Wenn Steckdose ausgeschaltet wird, alles auf 0 setzen (fuer vis)
        on({id: octopi_steckdose, change: 'lt'}, function() {
                setState (anycubic_fortschritt, 0, true);
                setState (anycubic_timedone , 0, true);
                setState (anycubic_timeleft , 0, true);
                setState (anycubic_extrudertemp , 0, true);
                setState (anycubic_extrudertemp_soll , 0, true);
                setState (anycubic_tempbed , 0, true);
                setState (anycubic_tempbed_soll , 0, true);
                setState (anycubic_dateigroesse , 0, true);
                setState (anycubic_speicherort , '---', true);
                setState (anycubic_dateiname , '---', true);
                setState (anycubic_laenge, 0, true);
                setState (anycubic_volumen, 0, true);
        
                setState(anycubic_gesamtlayer, 0, true);
                setState(anycubic_currentlayer, 0, true);
        
                EndeZeit();
            }
        );
        
        //____________________________________________________________________________________________________
        // Octoprint-Datenpunkte abfragen
        function variablen_abfragen(){
            //log ('___ Octoprint-Datenpunkte werden gelesen ___');
            lautstaerke_tablet();    
            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;
            var druckdauer          = getState('javascript.0.OctoPi.Gesamtzeit').val;
        
        
            //log ('druckdauer= ' + druckdauer);	
        
        //    var laenge              = getState(anycubic_laenge).val;
        //    var volumen             = getState(anycubic_volumen).val;
        
        //    setState (pfad + 'Laenge', laenge, true);
        //    setState (pfad + 'Laenge', volumen, true);  
        
        }   // Ende function variablen_abfragen
        
        //____________________________________________________________________________________________________
        //Ansage Druckfortschritt
        on({id: anycubic_fortschritt, change: 'any'}, function() {
            lautstaerke_tablet();
            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 D-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 D-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 D-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 D-Drucker hat ' + druck_fortschritt + 'Prozent des Ausdruckes fertiggestellt'});
                        }, 2000);
                        log ('## AnyCubic ist zu ' + druck_fortschritt + '% fertig ##');
                        ninety = 1;
                    } // Ende if fortschrSprache >= 90
        }
        
        }); // Ende Ansage Druckfortschritte
        
        
        
        
        
        
        //____________________________________________________________________________________________________
        //____________________________________________________________________________________________________
        //Ansage, dass der Druck fertig ist, wenn Druckfortschritt = 100% und das Druckbett abgekuehlt (<= 50 Grad) ist,
        // optional danach automatisches Herunterfahren
        
        on({id: anycubic_tempbed, change: 'any'}, function() {
        
        if(done == 0 ){
                
        				var druck_fortschritt0  = getState(anycubic_fortschritt).val;
        				var druck_fortschritt   = Math.round(druck_fortschritt0 * 1) / 1; // keine Nachkommastellen ansagen
        				//log ('Druckfortschritt ist: ' + druck_fortschritt);
        
                        var bed_temp0           = getState(anycubic_tempbed).val;
                        var bed_temp            = Math.round(bed_temp0 * 1) / 1;          // keine Nachkommastellen ansagen
                        //log ('bed_temp ist: ' + bed_temp);
        
                        if(druck_fortschritt == 100 && bed_temp >= 48 && bed_temp <= 50 ){
        
                        var autoshut = getState('javascript.0.OctoPi.AutoShutdown').val;
                        log ('AutoShutdown ist ' + autoshut);
        
                        // bei aktivem AutoShutdown den Drucker nach Abkuehlung ausschalten
                        if ( autoshut  == true ){
                            setTimeout(function(){
                            log ('--> Drucker wird jetzt automatisch ausgeschaltet');
                            octopi_shutdown();
                            }, 17000);
        
                            setTimeout(function(){
                            sendTo("paw.0",'Tablet_Jörg',{tts:  'Der Drucker wird jetzt automatisch ausgeschaltet'});
                            }, 11000);
                        } // ende autoshut true
        
                        setTimeout(function(){
                        sendTo("paw.0",'Tablet_Jörg',{tts:  'Der 3 D-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 && bed_temp >= 48 && bed_temp <= 50 )
                    
        }   // ende if done
        
        }); // Ende On ID anycubic_tempbed change
        
        
        
        //____________________________________________________________________________________________________
        //____________________________________________________________________________________________________
        
        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_Adapter wurde gestartet __');
            setState("system.adapter.octoprint.0.alive", true);
        }
        
        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_Adapter wurde beendet __');
            setState("system.adapter.octoprint.0.alive", false);
        }
        
        // 
        function umrechnung() {
        // Umrechnung der Druckzeiten von Sekunden in HH:MM:SS
            var time_left = getState("octoprint.0.printjob.progress.printtimeLeft").val;
            var job_time  = getState('octoprint.0.printjob.progress.printtime').val;
        	var duration = time_left + job_time;
        
            // Hours
            var hours_restzeit  =  Math.floor( time_left / 3600 );
            var hours_printzeit =  Math.floor( job_time  / 3600 );
            var hours_duration  =  Math.floor( duration  / 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)
            if ( hours_duration < 10 ){var std_duration= "0" + String(hours_duration); }
                else var std_duration = String(hours_duration)			
        
            // Minutes
            var minutes_restzeit  = Math.floor( (time_left%3600) / 60 );
            var minutes_printzeit = Math.floor( (job_time%3600)  / 60 );
        	var minutes_duration  = Math.floor( (duration%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)
            if ( minutes_duration < 10 ){var min_duration= "0" + String(minutes_duration); }
                else var min_duration = String(minutes_duration)		
        
            // Seconds
            var seconds_restzeit  = Math.floor( time_left%60 );
            var seconds_printzeit = Math.floor( job_time%60  );
            var seconds_duration  = Math.floor( duration%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)
            if ( seconds_duration < 10 ){var sec_duration= "0" + String(seconds_duration); }
                else var sec_duration = String(seconds_duration)
        
            // Zeit in HH:MM:SS format
            var restzeit  = std_restzeit  + ':' + min_restzeit  + ':' + sec_restzeit;
            var printzeit = std_printzeit + ':' + min_printzeit + ':' + sec_printzeit;
            var dauer     = std_duration  + ':' + min_duration  + ':' + sec_duration;
        
        	//console.log("Restzeit:" + restzeit + "__" + " Printzeit:" + printzeit + "__"  +" Dauer:" + dauer);
        
            setState("javascript.0.OctoPi.Restzeit", restzeit, true);
            setState('javascript.0.OctoPi.Printzeit', printzeit, true);
        	setState("javascript.0.OctoPi.Gesamtzeit", dauer, true);
        
        }
        
        //____________________________________________________________________________________________________
        
        
        // Druck-Ende Uhrzeit berechnen //
        //#################################
        
        function EndeZeit(){
        
        var time_left = getState("octoprint.0.printjob.progress.printtimeLeft").val;
        var sekunden_restzeit  = time_left; // Restzeit in Sekunden aus Octopi
        if(time_left == null || time_left == 0 ){ setState("javascript.0.OctoPi.EndeZeit", '---', true) };
        
        var Zeit = new Date();
        //log('jetzt: ' + Zeit);
        
        var z0_neu = Zeit.getSeconds()+ sekunden_restzeit;
        var z_neu = Zeit.setSeconds(z0_neu);
        var ZeitNeu = new Date(z_neu);
        //console.log('Endezeit: '  + ZeitNeu);
        
        var h_ende = ZeitNeu.getHours();
        var m_ende = ZeitNeu.getMinutes();
        var s_ende = ZeitNeu.getSeconds();
        var tag_ende = ZeitNeu.getDate();
        var months = ["Jan", "Feb", "Mrz", "Apr", "Mai", "Jun", "Jul", "Aug", "Sep", "Okt", "Nov", "Dez"];
        var monat_ende  = months[ZeitNeu.getMonth()];
        
        var EndeZeit = tag_ende + '.' + monat_ende + ' ' + h_ende + ':' + m_ende + ':' + s_ende;
        //console.log('EndeZeit: '  + EndeZeit);
        
            // Führende 0 hinzufügen und als String wandeln
            if ( tag_ende  < 10 ){var endtag = "0" + String(tag_ende);}
                else var endtag = String(tag_ende)
            if ( h_ende  < 10 ){var endstunde = "0" + String(h_ende);}
                else var endstunde = String(h_ende)
            if ( m_ende  < 10 ){var endminute = "0" + String(m_ende);}
                else var endminute = String(m_ende)
            if ( s_ende  < 10 ){var endsekunde = "0" + String(s_ende);}
                else var endsekunde = String(s_ende)
        
        var EndeZeit = endtag + '. ' + monat_ende + '  ' + endstunde + ':' + endminute + ':' + endsekunde;
        //console.log('EndeZeit: '  + EndeZeit);
        //setState("javascript.0.OctoPi.EndeZeit", EndeZeit, true);
        
        if(time_left == null || time_left == 0 ){ setState("javascript.0.OctoPi.EndeZeit", '---', true) }
        else setState("javascript.0.OctoPi.EndeZeit", EndeZeit, true);
        
        }   // end of function EndeZeit()
        
        //____________________________________________________________________________________________________
        
        
        
        // Lautstaerke von Landvo-Smartphone auf 15 setzen
        function lautstaerke(){
            sendTo("paw.0",'Landvo',{volume: 15});
        }
        
        // Lautstaerke von Android-Tablet auf 13 setzen
        function lautstaerke_tablet(){ 
            sendTo("paw.0",'Tablet_Jörg',{volume: 13});
        }
        
        
        

        Das Ganze geht bestimmt auch eleganter/einfacher, aber da ich nicht so der JS-Crack bin, habe ich mir das so zusammengefrickelt.

        Jürgen B. 0J A blue231181B 3 Antworten Letzte Antwort
        0
        • joergeliJ joergeli

          @jürgen-b-0 sagte in [UMFRAGE] Besteht Interesse an einem Octoprint Adapter:

          1.) Wo ändere ich den User und das Passwort? (Zeile)
          2.) Zeile 4? wie kann ich das node-ssh in Javascript-Adapter installieren?
          3.) Wie pflege ich das entsprechend im VIS-Editor ein?

          1.) User/Passwort: bei //Octoprint-Server via SSH herunterfahren - in der setTimeout(function() ab Zeile 150
          2.) node-ssh manuell in den Einstellungen des JavaScript-Adapters hinzufügen/reinschreiben:
          node-ssh.jpg
          Das dauert dann einen Moment, bis node-ssh installiert wurde.
          In den JavaSript-Einstellungen auch den Haken bei Kommandoe "exec" erlauben nicht vergessen!

          3.) Anbei mein vis-View nochmals als Export, den kannst Du importieren und Dich daran orientieren.
          Natürlich musst Du darin die Pfade anpassen, in denen die Bildchen, etc. gespeichert sind!

          Sieht jetzt so aus:
          octo-view_export.zip

          octo.jpg

          #######################################################################################

          Ich hatte mein Script zwischenzeitlich noch mal editiert, bzgl. zusätzlichen Ausgaben von Fertigstellungszeit / -Datum.
          Außerdem habe ich noch einen Schalter eingebaut, mit dem in der vis ausgewählt werden kann, ob der Drucker nach Fertigstellung und Abkühlung automatisch ausgeschaltet werden soll, oder nicht.
          Zusätzlich noch ein paar Buttons für X/Y-Positionierung des Druckkopfes.
          Dazu müssen in den vis-Buttons entspr. Werte eingetragen werden, z.B. so:
          xy.jpgxy-einstellungen.jpg

          autoshutdown.jpg
          autoshutdown-einstellungen.jpg

          Beachte bitte, daß ich die Sprachausgabe mit PAW mache, das musst Du sehr wahrscheinlich an Deine Gegebenheiten anpassen ( Alexa, Telegram, o.ä.)

          Anbei mein aktuelles Script:

          //#####################################################################
          // 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' // Shelly Plug S Steckdose Octopi und 3D-Drucker
          const octopi_autoshutdown           = 'javascript.0.OctoPi.AutoShutdown'        // Drucker nach Druckende autom. ausschalten
          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.printtimeLeft'
          
          
          const anycubic_extrudertemp         = 'octoprint.0.tools.tool0.actualTemperature'
          const anycubic_extrudertemp_soll    = 'octoprint.0.tools.tool0.targetTemperature'
          const anycubic_tempbed              = 'octoprint.0.tools.bed.actualTemperature'
          const anycubic_tempbed_soll         = 'octoprint.0.tools.bed.targetTemperature'
          
          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'
          const anycubic_laenge               = 'octoprint.0.printjob.filament.length'
          const anycubic_volumen              = 'octoprint.0.printjob.filament.volume'
          
          const anycubic_gesamtlayer          = 'octoprint.0.plugins.displayLayerProgress.layer.total'
          const anycubic_currentlayer         = 'octoprint.0.plugins.displayLayerProgress.layer.current'
          
          var pfad = 'javascript.0.OctoPi.';
          
          const {NodeSSH} = require('node-ssh')
          const ssh = new NodeSSH()
          
          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'
          });
          
          createState('javascript.0.OctoPi.Gesamtzeit', {
              name: 'Gesamtzeit',
              desc: 'Gesamtdauer des Druckjobs',
              type: 'string',
          });
          
          
          
          createState( pfad + 'EndeZeit', {
              name: 'EndeZeit',
              desc: 'Uhrzeit Fertigstellung des Druckes',
              type: 'string'
          });
          
          createState( pfad + 'AutoShutdown', {
              name: 'AutoShutdown',
              desc: 'Drucker nach Druckende ausschalten',
              type: 'boolean'
          });
          
          
          
          //______ 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) {
                  var autoshut = false;
                  octopi_startup();
              }
          });
          
          
          //____________________________________________________________________________________________________
          // Umrechnung der Druckzeiten von Sekunden in HH:MM:SS und Ende-Zeit berechnen
          on({id: [anycubic_timeleft], change: "lt"} , function (obj) {
              umrechnung();
              EndeZeit();
          });
          
          
          
          
          //____________________________________________________________________________________________________
          function octopi_shutdown() {
                          lautstaerke_tablet();  // Lautstaerke Tablet auf 13 setzen
          
                          twentyfive = 0;
                          fifty = 0;
                          seventyfive = 0;
                          ninety = 0;
                          done = 0;              
          
                          //ioBroker OctoPi-Instanz beenden
                          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 und Layer zuruecksetzen
                          setState("javascript.0.OctoPi.Restzeit", '---', true);
                          setState('javascript.0.OctoPi.Printzeit', '---', true);
                          setState("javascript.0.OctoPi.EndeZeit", '---', true);
          				setState("javascript.0.OctoPi.Gesamtzeit", '---', true);
                        
          				setState("javascript.0.OctoPi.AutoShutdown", false, true);
          				setState("javascript.0.OctoPi.Shutdown", true, true);
                          
                          setState('octoprint.0.plugins.displayLayerProgress.layer.averageDuration', 0, true);
                          setState('octoprint.0.plugins.displayLayerProgress.layer.current', 0, true);
                          setState('octoprint.0.plugins.displayLayerProgress.layer.total', 0, true);
                          }, 5000);
          
                          //Octoprint-Server via SSH herunterfahren
                          setTimeout(function(){
                          //log ('__ SSH Verbindung gestartet __');
                          //SSH-Session starten, um Octoprint-Raspi sauber! herunterzufahren
                              ssh.connect({
                                  host: '192.168.192.30', //IP-Adresse des Octoprint-Raspi
                                  username: 'pi',         //Username Octoprint-Raspi (normalerweise pi)
                                  password: 'xxxxxxxx'    //Passwort Octoprint-Raspi
                              }).then(() => {
                                  ssh.execCommand('echo "xxxxxxxx"|sudo -S shutdown -h now');
                                  // Achtung! Im execCommand muss nochmals das Passwort für den Octoprint-Raspi eingetragen werden
                              });                           
          
                          }, 6000);   // 6 Sekunden warten
          
                          //Sprachansage, dass Octopi heruntergefahren wird
                          setTimeout(function(){
                          sendTo("paw.0",'Tablet_Jörg',{tts:  'Shutdown 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 down'});
                          //log ('__ Octoprint-Server ist down __');
                          setState (pfad + 'ShuttingDown', 'OctoPrint ist down ...', true);
                          }, 18000);
          
                          //OctoPi- Shelly Plug S - Steckdose ausschalten
                          setTimeout(function(){         
                          setState(octopi_steckdose, false);
                          sendTo("paw.0",'Tablet_Jörg',{tts:  'OctoPrint-Steckdose und 3 D-Drucker sind ausgeschaltet'});
                          log ('OctoPi-Steckdose ausgeschaltet');
                          setState (pfad + 'ShuttingDown', 'OctoPrint ist ausgeschaltet', true);
                          setState("javascript.0.OctoPi.EndeZeit", '---', true);
                          }, 24000);
          
          }   // Ende function octopi_shutdown
          
          //____________________________________________________________________________________________________
          function octopi_startup() {
                          lautstaerke_tablet();
          
                          twentyfive = 0;
                          fifty = 0;
                          seventyfive = 0;
                          ninety = 0;
                          done = 0;
          
                          //Druckzeiten und Layer  zuruecksetzen
                          setState("javascript.0.OctoPi.Restzeit", '---', true);
                          setState('javascript.0.OctoPi.Printzeit', '---', true);
                          setState("javascript.0.OctoPi.EndeZeit", '---', true);
          				setState("javascript.0.OctoPi.Gesamtzeit", '---', true);
          
                          setState("javascript.0.OctoPi.AutoShutdown", false, true);
          
          
                          setState('octoprint.0.plugins.displayLayerProgress.layer.averageDuration', 0, true);
                          setState('octoprint.0.plugins.displayLayerProgress.layer.current', 0, true);
                          setState('octoprint.0.plugins.displayLayerProgress.layer.total', 0, true);
                          setState('octoprint.0.printjob.progress.completion', 0, true);
                          //OctoPi-Instanz starten, wenn Octopi-Raspi kpl. hochgefahren ist
                          setTimeout(function(){
                          octo_adapter_on();
                          //sendTo("paw.0",'Tablet_Jörg',{tts:  'Octoprint Instanz wurde gestartet'});
                          log('Octoprint Instanz wurde gestartet');
                          }, 45000);
          
          
                          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);
                          }, 10000);
          
                          //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 startet ...');
                          }, 20000);
          
                          //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');
                          }, 35000);
          
                          setTimeout(function(){
                          // Steckdose einschalten
                          setState(octopi_steckdose, true);
                          setState (pfad + 'ShuttingDown', '3D Drucker wurde eingeschaltet ...', true);
                          log('3D Drucker wurde eingeschaltet ...');
                          sendTo("paw.0",'Tablet_Jörg',{tts:  'Der 3Dee Drucker wurde eingeschaltet'});
                          }, 100);
          
          
          
          
          }   //Ende function octopi_startup
          
          
          //____________________________________________________________________________________________________
          //OctoPi Online-Meldung, wenn Verbindung zum 3D-Drucker hergestellt wurde
          on({id: anycubic_verbindung, change: 'gt'}, function() {
                  lautstaerke_tablet();
                  
                  twentyfive = 0;
                  fifty = 0;
                  seventyfive = 0;
                  ninety = 0;
                  done = 0;
          
                  //Druckzeiten und Layer  zuruecksetzen
                  setState("javascript.0.OctoPi.Restzeit", '---', true);
                  setState('javascript.0.OctoPi.Printzeit', '---', true);
                  setState("javascript.0.OctoPi.EndeZeit", '---', true);
          		setState("javascript.0.OctoPi.Gesamtzeit", '---', true);
                  setState('octoprint.0.plugins.displayLayerProgress.layer.current', 0, true);
                  setState('octoprint.0.plugins.displayLayerProgress.layer.total', 0, 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 online'});
                      log ('Octoprint-Server ist online');
                      setState (pfad + 'ShuttingDown', 'OctoPrint ist online', true);
          
                      variablen_abfragen();
          
                  }
          }); // Ende Meldung Verbindungsherstellung
          
          
          //____________________________________________________________________________________________________
          
          // Wenn Steckdose ausgeschaltet wird, alles auf 0 setzen (fuer vis)
          on({id: octopi_steckdose, change: 'lt'}, function() {
                  setState (anycubic_fortschritt, 0, true);
                  setState (anycubic_timedone , 0, true);
                  setState (anycubic_timeleft , 0, true);
                  setState (anycubic_extrudertemp , 0, true);
                  setState (anycubic_extrudertemp_soll , 0, true);
                  setState (anycubic_tempbed , 0, true);
                  setState (anycubic_tempbed_soll , 0, true);
                  setState (anycubic_dateigroesse , 0, true);
                  setState (anycubic_speicherort , '---', true);
                  setState (anycubic_dateiname , '---', true);
                  setState (anycubic_laenge, 0, true);
                  setState (anycubic_volumen, 0, true);
          
                  setState(anycubic_gesamtlayer, 0, true);
                  setState(anycubic_currentlayer, 0, true);
          
                  EndeZeit();
              }
          );
          
          //____________________________________________________________________________________________________
          // Octoprint-Datenpunkte abfragen
          function variablen_abfragen(){
              //log ('___ Octoprint-Datenpunkte werden gelesen ___');
              lautstaerke_tablet();    
              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;
              var druckdauer          = getState('javascript.0.OctoPi.Gesamtzeit').val;
          
          
              //log ('druckdauer= ' + druckdauer);	
          
          //    var laenge              = getState(anycubic_laenge).val;
          //    var volumen             = getState(anycubic_volumen).val;
          
          //    setState (pfad + 'Laenge', laenge, true);
          //    setState (pfad + 'Laenge', volumen, true);  
          
          }   // Ende function variablen_abfragen
          
          //____________________________________________________________________________________________________
          //Ansage Druckfortschritt
          on({id: anycubic_fortschritt, change: 'any'}, function() {
              lautstaerke_tablet();
              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 D-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 D-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 D-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 D-Drucker hat ' + druck_fortschritt + 'Prozent des Ausdruckes fertiggestellt'});
                          }, 2000);
                          log ('## AnyCubic ist zu ' + druck_fortschritt + '% fertig ##');
                          ninety = 1;
                      } // Ende if fortschrSprache >= 90
          }
          
          }); // Ende Ansage Druckfortschritte
          
          
          
          
          
          
          //____________________________________________________________________________________________________
          //____________________________________________________________________________________________________
          //Ansage, dass der Druck fertig ist, wenn Druckfortschritt = 100% und das Druckbett abgekuehlt (<= 50 Grad) ist,
          // optional danach automatisches Herunterfahren
          
          on({id: anycubic_tempbed, change: 'any'}, function() {
          
          if(done == 0 ){
                  
          				var druck_fortschritt0  = getState(anycubic_fortschritt).val;
          				var druck_fortschritt   = Math.round(druck_fortschritt0 * 1) / 1; // keine Nachkommastellen ansagen
          				//log ('Druckfortschritt ist: ' + druck_fortschritt);
          
                          var bed_temp0           = getState(anycubic_tempbed).val;
                          var bed_temp            = Math.round(bed_temp0 * 1) / 1;          // keine Nachkommastellen ansagen
                          //log ('bed_temp ist: ' + bed_temp);
          
                          if(druck_fortschritt == 100 && bed_temp >= 48 && bed_temp <= 50 ){
          
                          var autoshut = getState('javascript.0.OctoPi.AutoShutdown').val;
                          log ('AutoShutdown ist ' + autoshut);
          
                          // bei aktivem AutoShutdown den Drucker nach Abkuehlung ausschalten
                          if ( autoshut  == true ){
                              setTimeout(function(){
                              log ('--> Drucker wird jetzt automatisch ausgeschaltet');
                              octopi_shutdown();
                              }, 17000);
          
                              setTimeout(function(){
                              sendTo("paw.0",'Tablet_Jörg',{tts:  'Der Drucker wird jetzt automatisch ausgeschaltet'});
                              }, 11000);
                          } // ende autoshut true
          
                          setTimeout(function(){
                          sendTo("paw.0",'Tablet_Jörg',{tts:  'Der 3 D-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 && bed_temp >= 48 && bed_temp <= 50 )
                      
          }   // ende if done
          
          }); // Ende On ID anycubic_tempbed change
          
          
          
          //____________________________________________________________________________________________________
          //____________________________________________________________________________________________________
          
          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_Adapter wurde gestartet __');
              setState("system.adapter.octoprint.0.alive", true);
          }
          
          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_Adapter wurde beendet __');
              setState("system.adapter.octoprint.0.alive", false);
          }
          
          // 
          function umrechnung() {
          // Umrechnung der Druckzeiten von Sekunden in HH:MM:SS
              var time_left = getState("octoprint.0.printjob.progress.printtimeLeft").val;
              var job_time  = getState('octoprint.0.printjob.progress.printtime').val;
          	var duration = time_left + job_time;
          
              // Hours
              var hours_restzeit  =  Math.floor( time_left / 3600 );
              var hours_printzeit =  Math.floor( job_time  / 3600 );
              var hours_duration  =  Math.floor( duration  / 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)
              if ( hours_duration < 10 ){var std_duration= "0" + String(hours_duration); }
                  else var std_duration = String(hours_duration)			
          
              // Minutes
              var minutes_restzeit  = Math.floor( (time_left%3600) / 60 );
              var minutes_printzeit = Math.floor( (job_time%3600)  / 60 );
          	var minutes_duration  = Math.floor( (duration%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)
              if ( minutes_duration < 10 ){var min_duration= "0" + String(minutes_duration); }
                  else var min_duration = String(minutes_duration)		
          
              // Seconds
              var seconds_restzeit  = Math.floor( time_left%60 );
              var seconds_printzeit = Math.floor( job_time%60  );
              var seconds_duration  = Math.floor( duration%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)
              if ( seconds_duration < 10 ){var sec_duration= "0" + String(seconds_duration); }
                  else var sec_duration = String(seconds_duration)
          
              // Zeit in HH:MM:SS format
              var restzeit  = std_restzeit  + ':' + min_restzeit  + ':' + sec_restzeit;
              var printzeit = std_printzeit + ':' + min_printzeit + ':' + sec_printzeit;
              var dauer     = std_duration  + ':' + min_duration  + ':' + sec_duration;
          
          	//console.log("Restzeit:" + restzeit + "__" + " Printzeit:" + printzeit + "__"  +" Dauer:" + dauer);
          
              setState("javascript.0.OctoPi.Restzeit", restzeit, true);
              setState('javascript.0.OctoPi.Printzeit', printzeit, true);
          	setState("javascript.0.OctoPi.Gesamtzeit", dauer, true);
          
          }
          
          //____________________________________________________________________________________________________
          
          
          // Druck-Ende Uhrzeit berechnen //
          //#################################
          
          function EndeZeit(){
          
          var time_left = getState("octoprint.0.printjob.progress.printtimeLeft").val;
          var sekunden_restzeit  = time_left; // Restzeit in Sekunden aus Octopi
          if(time_left == null || time_left == 0 ){ setState("javascript.0.OctoPi.EndeZeit", '---', true) };
          
          var Zeit = new Date();
          //log('jetzt: ' + Zeit);
          
          var z0_neu = Zeit.getSeconds()+ sekunden_restzeit;
          var z_neu = Zeit.setSeconds(z0_neu);
          var ZeitNeu = new Date(z_neu);
          //console.log('Endezeit: '  + ZeitNeu);
          
          var h_ende = ZeitNeu.getHours();
          var m_ende = ZeitNeu.getMinutes();
          var s_ende = ZeitNeu.getSeconds();
          var tag_ende = ZeitNeu.getDate();
          var months = ["Jan", "Feb", "Mrz", "Apr", "Mai", "Jun", "Jul", "Aug", "Sep", "Okt", "Nov", "Dez"];
          var monat_ende  = months[ZeitNeu.getMonth()];
          
          var EndeZeit = tag_ende + '.' + monat_ende + ' ' + h_ende + ':' + m_ende + ':' + s_ende;
          //console.log('EndeZeit: '  + EndeZeit);
          
              // Führende 0 hinzufügen und als String wandeln
              if ( tag_ende  < 10 ){var endtag = "0" + String(tag_ende);}
                  else var endtag = String(tag_ende)
              if ( h_ende  < 10 ){var endstunde = "0" + String(h_ende);}
                  else var endstunde = String(h_ende)
              if ( m_ende  < 10 ){var endminute = "0" + String(m_ende);}
                  else var endminute = String(m_ende)
              if ( s_ende  < 10 ){var endsekunde = "0" + String(s_ende);}
                  else var endsekunde = String(s_ende)
          
          var EndeZeit = endtag + '. ' + monat_ende + '  ' + endstunde + ':' + endminute + ':' + endsekunde;
          //console.log('EndeZeit: '  + EndeZeit);
          //setState("javascript.0.OctoPi.EndeZeit", EndeZeit, true);
          
          if(time_left == null || time_left == 0 ){ setState("javascript.0.OctoPi.EndeZeit", '---', true) }
          else setState("javascript.0.OctoPi.EndeZeit", EndeZeit, true);
          
          }   // end of function EndeZeit()
          
          //____________________________________________________________________________________________________
          
          
          
          // Lautstaerke von Landvo-Smartphone auf 15 setzen
          function lautstaerke(){
              sendTo("paw.0",'Landvo',{volume: 15});
          }
          
          // Lautstaerke von Android-Tablet auf 13 setzen
          function lautstaerke_tablet(){ 
              sendTo("paw.0",'Tablet_Jörg',{volume: 13});
          }
          
          
          

          Das Ganze geht bestimmt auch eleganter/einfacher, aber da ich nicht so der JS-Crack bin, habe ich mir das so zusammengefrickelt.

          Jürgen B. 0J Offline
          Jürgen B. 0J Offline
          Jürgen B. 0
          schrieb am zuletzt editiert von
          #112

          @joergeli Guten Morgen, vielen Dank für die Unterstützung. Ich werde es diese Woche gleich ausprobieren.
          VG

          1 Antwort Letzte Antwort
          0
          • VanduraV Vandura

            Einfach nur mal Danke sagen......
            Nachdem ich mich Lange hier belesen habe und die Vis als Anregung genommen habe, habe ich jetzt alles soweit hinbekommen, dass es läuft......
            Octopi.jpg
            Danke für eure Unermüdliche Arbeit, die es so einem wie mir einfacher machen sich in die Materie einzufinden.

            Grüße Rick

            A Offline
            A Offline
            andbru01
            schrieb am zuletzt editiert von
            #113

            @vandura Hallo, mir gefällt deine VIS sehr gut. Wäre es eventuell möglich das die Bilder inkl. View (Exportiert) hochgeladen werden?? Lg

            1 Antwort Letzte Antwort
            0
            • joergeliJ joergeli

              @jürgen-b-0 sagte in [UMFRAGE] Besteht Interesse an einem Octoprint Adapter:

              1.) Wo ändere ich den User und das Passwort? (Zeile)
              2.) Zeile 4? wie kann ich das node-ssh in Javascript-Adapter installieren?
              3.) Wie pflege ich das entsprechend im VIS-Editor ein?

              1.) User/Passwort: bei //Octoprint-Server via SSH herunterfahren - in der setTimeout(function() ab Zeile 150
              2.) node-ssh manuell in den Einstellungen des JavaScript-Adapters hinzufügen/reinschreiben:
              node-ssh.jpg
              Das dauert dann einen Moment, bis node-ssh installiert wurde.
              In den JavaSript-Einstellungen auch den Haken bei Kommandoe "exec" erlauben nicht vergessen!

              3.) Anbei mein vis-View nochmals als Export, den kannst Du importieren und Dich daran orientieren.
              Natürlich musst Du darin die Pfade anpassen, in denen die Bildchen, etc. gespeichert sind!

              Sieht jetzt so aus:
              octo-view_export.zip

              octo.jpg

              #######################################################################################

              Ich hatte mein Script zwischenzeitlich noch mal editiert, bzgl. zusätzlichen Ausgaben von Fertigstellungszeit / -Datum.
              Außerdem habe ich noch einen Schalter eingebaut, mit dem in der vis ausgewählt werden kann, ob der Drucker nach Fertigstellung und Abkühlung automatisch ausgeschaltet werden soll, oder nicht.
              Zusätzlich noch ein paar Buttons für X/Y-Positionierung des Druckkopfes.
              Dazu müssen in den vis-Buttons entspr. Werte eingetragen werden, z.B. so:
              xy.jpgxy-einstellungen.jpg

              autoshutdown.jpg
              autoshutdown-einstellungen.jpg

              Beachte bitte, daß ich die Sprachausgabe mit PAW mache, das musst Du sehr wahrscheinlich an Deine Gegebenheiten anpassen ( Alexa, Telegram, o.ä.)

              Anbei mein aktuelles Script:

              //#####################################################################
              // 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' // Shelly Plug S Steckdose Octopi und 3D-Drucker
              const octopi_autoshutdown           = 'javascript.0.OctoPi.AutoShutdown'        // Drucker nach Druckende autom. ausschalten
              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.printtimeLeft'
              
              
              const anycubic_extrudertemp         = 'octoprint.0.tools.tool0.actualTemperature'
              const anycubic_extrudertemp_soll    = 'octoprint.0.tools.tool0.targetTemperature'
              const anycubic_tempbed              = 'octoprint.0.tools.bed.actualTemperature'
              const anycubic_tempbed_soll         = 'octoprint.0.tools.bed.targetTemperature'
              
              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'
              const anycubic_laenge               = 'octoprint.0.printjob.filament.length'
              const anycubic_volumen              = 'octoprint.0.printjob.filament.volume'
              
              const anycubic_gesamtlayer          = 'octoprint.0.plugins.displayLayerProgress.layer.total'
              const anycubic_currentlayer         = 'octoprint.0.plugins.displayLayerProgress.layer.current'
              
              var pfad = 'javascript.0.OctoPi.';
              
              const {NodeSSH} = require('node-ssh')
              const ssh = new NodeSSH()
              
              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'
              });
              
              createState('javascript.0.OctoPi.Gesamtzeit', {
                  name: 'Gesamtzeit',
                  desc: 'Gesamtdauer des Druckjobs',
                  type: 'string',
              });
              
              
              
              createState( pfad + 'EndeZeit', {
                  name: 'EndeZeit',
                  desc: 'Uhrzeit Fertigstellung des Druckes',
                  type: 'string'
              });
              
              createState( pfad + 'AutoShutdown', {
                  name: 'AutoShutdown',
                  desc: 'Drucker nach Druckende ausschalten',
                  type: 'boolean'
              });
              
              
              
              //______ 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) {
                      var autoshut = false;
                      octopi_startup();
                  }
              });
              
              
              //____________________________________________________________________________________________________
              // Umrechnung der Druckzeiten von Sekunden in HH:MM:SS und Ende-Zeit berechnen
              on({id: [anycubic_timeleft], change: "lt"} , function (obj) {
                  umrechnung();
                  EndeZeit();
              });
              
              
              
              
              //____________________________________________________________________________________________________
              function octopi_shutdown() {
                              lautstaerke_tablet();  // Lautstaerke Tablet auf 13 setzen
              
                              twentyfive = 0;
                              fifty = 0;
                              seventyfive = 0;
                              ninety = 0;
                              done = 0;              
              
                              //ioBroker OctoPi-Instanz beenden
                              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 und Layer zuruecksetzen
                              setState("javascript.0.OctoPi.Restzeit", '---', true);
                              setState('javascript.0.OctoPi.Printzeit', '---', true);
                              setState("javascript.0.OctoPi.EndeZeit", '---', true);
              				setState("javascript.0.OctoPi.Gesamtzeit", '---', true);
                            
              				setState("javascript.0.OctoPi.AutoShutdown", false, true);
              				setState("javascript.0.OctoPi.Shutdown", true, true);
                              
                              setState('octoprint.0.plugins.displayLayerProgress.layer.averageDuration', 0, true);
                              setState('octoprint.0.plugins.displayLayerProgress.layer.current', 0, true);
                              setState('octoprint.0.plugins.displayLayerProgress.layer.total', 0, true);
                              }, 5000);
              
                              //Octoprint-Server via SSH herunterfahren
                              setTimeout(function(){
                              //log ('__ SSH Verbindung gestartet __');
                              //SSH-Session starten, um Octoprint-Raspi sauber! herunterzufahren
                                  ssh.connect({
                                      host: '192.168.192.30', //IP-Adresse des Octoprint-Raspi
                                      username: 'pi',         //Username Octoprint-Raspi (normalerweise pi)
                                      password: 'xxxxxxxx'    //Passwort Octoprint-Raspi
                                  }).then(() => {
                                      ssh.execCommand('echo "xxxxxxxx"|sudo -S shutdown -h now');
                                      // Achtung! Im execCommand muss nochmals das Passwort für den Octoprint-Raspi eingetragen werden
                                  });                           
              
                              }, 6000);   // 6 Sekunden warten
              
                              //Sprachansage, dass Octopi heruntergefahren wird
                              setTimeout(function(){
                              sendTo("paw.0",'Tablet_Jörg',{tts:  'Shutdown 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 down'});
                              //log ('__ Octoprint-Server ist down __');
                              setState (pfad + 'ShuttingDown', 'OctoPrint ist down ...', true);
                              }, 18000);
              
                              //OctoPi- Shelly Plug S - Steckdose ausschalten
                              setTimeout(function(){         
                              setState(octopi_steckdose, false);
                              sendTo("paw.0",'Tablet_Jörg',{tts:  'OctoPrint-Steckdose und 3 D-Drucker sind ausgeschaltet'});
                              log ('OctoPi-Steckdose ausgeschaltet');
                              setState (pfad + 'ShuttingDown', 'OctoPrint ist ausgeschaltet', true);
                              setState("javascript.0.OctoPi.EndeZeit", '---', true);
                              }, 24000);
              
              }   // Ende function octopi_shutdown
              
              //____________________________________________________________________________________________________
              function octopi_startup() {
                              lautstaerke_tablet();
              
                              twentyfive = 0;
                              fifty = 0;
                              seventyfive = 0;
                              ninety = 0;
                              done = 0;
              
                              //Druckzeiten und Layer  zuruecksetzen
                              setState("javascript.0.OctoPi.Restzeit", '---', true);
                              setState('javascript.0.OctoPi.Printzeit', '---', true);
                              setState("javascript.0.OctoPi.EndeZeit", '---', true);
              				setState("javascript.0.OctoPi.Gesamtzeit", '---', true);
              
                              setState("javascript.0.OctoPi.AutoShutdown", false, true);
              
              
                              setState('octoprint.0.plugins.displayLayerProgress.layer.averageDuration', 0, true);
                              setState('octoprint.0.plugins.displayLayerProgress.layer.current', 0, true);
                              setState('octoprint.0.plugins.displayLayerProgress.layer.total', 0, true);
                              setState('octoprint.0.printjob.progress.completion', 0, true);
                              //OctoPi-Instanz starten, wenn Octopi-Raspi kpl. hochgefahren ist
                              setTimeout(function(){
                              octo_adapter_on();
                              //sendTo("paw.0",'Tablet_Jörg',{tts:  'Octoprint Instanz wurde gestartet'});
                              log('Octoprint Instanz wurde gestartet');
                              }, 45000);
              
              
                              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);
                              }, 10000);
              
                              //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 startet ...');
                              }, 20000);
              
                              //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');
                              }, 35000);
              
                              setTimeout(function(){
                              // Steckdose einschalten
                              setState(octopi_steckdose, true);
                              setState (pfad + 'ShuttingDown', '3D Drucker wurde eingeschaltet ...', true);
                              log('3D Drucker wurde eingeschaltet ...');
                              sendTo("paw.0",'Tablet_Jörg',{tts:  'Der 3Dee Drucker wurde eingeschaltet'});
                              }, 100);
              
              
              
              
              }   //Ende function octopi_startup
              
              
              //____________________________________________________________________________________________________
              //OctoPi Online-Meldung, wenn Verbindung zum 3D-Drucker hergestellt wurde
              on({id: anycubic_verbindung, change: 'gt'}, function() {
                      lautstaerke_tablet();
                      
                      twentyfive = 0;
                      fifty = 0;
                      seventyfive = 0;
                      ninety = 0;
                      done = 0;
              
                      //Druckzeiten und Layer  zuruecksetzen
                      setState("javascript.0.OctoPi.Restzeit", '---', true);
                      setState('javascript.0.OctoPi.Printzeit', '---', true);
                      setState("javascript.0.OctoPi.EndeZeit", '---', true);
              		setState("javascript.0.OctoPi.Gesamtzeit", '---', true);
                      setState('octoprint.0.plugins.displayLayerProgress.layer.current', 0, true);
                      setState('octoprint.0.plugins.displayLayerProgress.layer.total', 0, 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 online'});
                          log ('Octoprint-Server ist online');
                          setState (pfad + 'ShuttingDown', 'OctoPrint ist online', true);
              
                          variablen_abfragen();
              
                      }
              }); // Ende Meldung Verbindungsherstellung
              
              
              //____________________________________________________________________________________________________
              
              // Wenn Steckdose ausgeschaltet wird, alles auf 0 setzen (fuer vis)
              on({id: octopi_steckdose, change: 'lt'}, function() {
                      setState (anycubic_fortschritt, 0, true);
                      setState (anycubic_timedone , 0, true);
                      setState (anycubic_timeleft , 0, true);
                      setState (anycubic_extrudertemp , 0, true);
                      setState (anycubic_extrudertemp_soll , 0, true);
                      setState (anycubic_tempbed , 0, true);
                      setState (anycubic_tempbed_soll , 0, true);
                      setState (anycubic_dateigroesse , 0, true);
                      setState (anycubic_speicherort , '---', true);
                      setState (anycubic_dateiname , '---', true);
                      setState (anycubic_laenge, 0, true);
                      setState (anycubic_volumen, 0, true);
              
                      setState(anycubic_gesamtlayer, 0, true);
                      setState(anycubic_currentlayer, 0, true);
              
                      EndeZeit();
                  }
              );
              
              //____________________________________________________________________________________________________
              // Octoprint-Datenpunkte abfragen
              function variablen_abfragen(){
                  //log ('___ Octoprint-Datenpunkte werden gelesen ___');
                  lautstaerke_tablet();    
                  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;
                  var druckdauer          = getState('javascript.0.OctoPi.Gesamtzeit').val;
              
              
                  //log ('druckdauer= ' + druckdauer);	
              
              //    var laenge              = getState(anycubic_laenge).val;
              //    var volumen             = getState(anycubic_volumen).val;
              
              //    setState (pfad + 'Laenge', laenge, true);
              //    setState (pfad + 'Laenge', volumen, true);  
              
              }   // Ende function variablen_abfragen
              
              //____________________________________________________________________________________________________
              //Ansage Druckfortschritt
              on({id: anycubic_fortschritt, change: 'any'}, function() {
                  lautstaerke_tablet();
                  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 D-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 D-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 D-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 D-Drucker hat ' + druck_fortschritt + 'Prozent des Ausdruckes fertiggestellt'});
                              }, 2000);
                              log ('## AnyCubic ist zu ' + druck_fortschritt + '% fertig ##');
                              ninety = 1;
                          } // Ende if fortschrSprache >= 90
              }
              
              }); // Ende Ansage Druckfortschritte
              
              
              
              
              
              
              //____________________________________________________________________________________________________
              //____________________________________________________________________________________________________
              //Ansage, dass der Druck fertig ist, wenn Druckfortschritt = 100% und das Druckbett abgekuehlt (<= 50 Grad) ist,
              // optional danach automatisches Herunterfahren
              
              on({id: anycubic_tempbed, change: 'any'}, function() {
              
              if(done == 0 ){
                      
              				var druck_fortschritt0  = getState(anycubic_fortschritt).val;
              				var druck_fortschritt   = Math.round(druck_fortschritt0 * 1) / 1; // keine Nachkommastellen ansagen
              				//log ('Druckfortschritt ist: ' + druck_fortschritt);
              
                              var bed_temp0           = getState(anycubic_tempbed).val;
                              var bed_temp            = Math.round(bed_temp0 * 1) / 1;          // keine Nachkommastellen ansagen
                              //log ('bed_temp ist: ' + bed_temp);
              
                              if(druck_fortschritt == 100 && bed_temp >= 48 && bed_temp <= 50 ){
              
                              var autoshut = getState('javascript.0.OctoPi.AutoShutdown').val;
                              log ('AutoShutdown ist ' + autoshut);
              
                              // bei aktivem AutoShutdown den Drucker nach Abkuehlung ausschalten
                              if ( autoshut  == true ){
                                  setTimeout(function(){
                                  log ('--> Drucker wird jetzt automatisch ausgeschaltet');
                                  octopi_shutdown();
                                  }, 17000);
              
                                  setTimeout(function(){
                                  sendTo("paw.0",'Tablet_Jörg',{tts:  'Der Drucker wird jetzt automatisch ausgeschaltet'});
                                  }, 11000);
                              } // ende autoshut true
              
                              setTimeout(function(){
                              sendTo("paw.0",'Tablet_Jörg',{tts:  'Der 3 D-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 && bed_temp >= 48 && bed_temp <= 50 )
                          
              }   // ende if done
              
              }); // Ende On ID anycubic_tempbed change
              
              
              
              //____________________________________________________________________________________________________
              //____________________________________________________________________________________________________
              
              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_Adapter wurde gestartet __');
                  setState("system.adapter.octoprint.0.alive", true);
              }
              
              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_Adapter wurde beendet __');
                  setState("system.adapter.octoprint.0.alive", false);
              }
              
              // 
              function umrechnung() {
              // Umrechnung der Druckzeiten von Sekunden in HH:MM:SS
                  var time_left = getState("octoprint.0.printjob.progress.printtimeLeft").val;
                  var job_time  = getState('octoprint.0.printjob.progress.printtime').val;
              	var duration = time_left + job_time;
              
                  // Hours
                  var hours_restzeit  =  Math.floor( time_left / 3600 );
                  var hours_printzeit =  Math.floor( job_time  / 3600 );
                  var hours_duration  =  Math.floor( duration  / 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)
                  if ( hours_duration < 10 ){var std_duration= "0" + String(hours_duration); }
                      else var std_duration = String(hours_duration)			
              
                  // Minutes
                  var minutes_restzeit  = Math.floor( (time_left%3600) / 60 );
                  var minutes_printzeit = Math.floor( (job_time%3600)  / 60 );
              	var minutes_duration  = Math.floor( (duration%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)
                  if ( minutes_duration < 10 ){var min_duration= "0" + String(minutes_duration); }
                      else var min_duration = String(minutes_duration)		
              
                  // Seconds
                  var seconds_restzeit  = Math.floor( time_left%60 );
                  var seconds_printzeit = Math.floor( job_time%60  );
                  var seconds_duration  = Math.floor( duration%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)
                  if ( seconds_duration < 10 ){var sec_duration= "0" + String(seconds_duration); }
                      else var sec_duration = String(seconds_duration)
              
                  // Zeit in HH:MM:SS format
                  var restzeit  = std_restzeit  + ':' + min_restzeit  + ':' + sec_restzeit;
                  var printzeit = std_printzeit + ':' + min_printzeit + ':' + sec_printzeit;
                  var dauer     = std_duration  + ':' + min_duration  + ':' + sec_duration;
              
              	//console.log("Restzeit:" + restzeit + "__" + " Printzeit:" + printzeit + "__"  +" Dauer:" + dauer);
              
                  setState("javascript.0.OctoPi.Restzeit", restzeit, true);
                  setState('javascript.0.OctoPi.Printzeit', printzeit, true);
              	setState("javascript.0.OctoPi.Gesamtzeit", dauer, true);
              
              }
              
              //____________________________________________________________________________________________________
              
              
              // Druck-Ende Uhrzeit berechnen //
              //#################################
              
              function EndeZeit(){
              
              var time_left = getState("octoprint.0.printjob.progress.printtimeLeft").val;
              var sekunden_restzeit  = time_left; // Restzeit in Sekunden aus Octopi
              if(time_left == null || time_left == 0 ){ setState("javascript.0.OctoPi.EndeZeit", '---', true) };
              
              var Zeit = new Date();
              //log('jetzt: ' + Zeit);
              
              var z0_neu = Zeit.getSeconds()+ sekunden_restzeit;
              var z_neu = Zeit.setSeconds(z0_neu);
              var ZeitNeu = new Date(z_neu);
              //console.log('Endezeit: '  + ZeitNeu);
              
              var h_ende = ZeitNeu.getHours();
              var m_ende = ZeitNeu.getMinutes();
              var s_ende = ZeitNeu.getSeconds();
              var tag_ende = ZeitNeu.getDate();
              var months = ["Jan", "Feb", "Mrz", "Apr", "Mai", "Jun", "Jul", "Aug", "Sep", "Okt", "Nov", "Dez"];
              var monat_ende  = months[ZeitNeu.getMonth()];
              
              var EndeZeit = tag_ende + '.' + monat_ende + ' ' + h_ende + ':' + m_ende + ':' + s_ende;
              //console.log('EndeZeit: '  + EndeZeit);
              
                  // Führende 0 hinzufügen und als String wandeln
                  if ( tag_ende  < 10 ){var endtag = "0" + String(tag_ende);}
                      else var endtag = String(tag_ende)
                  if ( h_ende  < 10 ){var endstunde = "0" + String(h_ende);}
                      else var endstunde = String(h_ende)
                  if ( m_ende  < 10 ){var endminute = "0" + String(m_ende);}
                      else var endminute = String(m_ende)
                  if ( s_ende  < 10 ){var endsekunde = "0" + String(s_ende);}
                      else var endsekunde = String(s_ende)
              
              var EndeZeit = endtag + '. ' + monat_ende + '  ' + endstunde + ':' + endminute + ':' + endsekunde;
              //console.log('EndeZeit: '  + EndeZeit);
              //setState("javascript.0.OctoPi.EndeZeit", EndeZeit, true);
              
              if(time_left == null || time_left == 0 ){ setState("javascript.0.OctoPi.EndeZeit", '---', true) }
              else setState("javascript.0.OctoPi.EndeZeit", EndeZeit, true);
              
              }   // end of function EndeZeit()
              
              //____________________________________________________________________________________________________
              
              
              
              // Lautstaerke von Landvo-Smartphone auf 15 setzen
              function lautstaerke(){
                  sendTo("paw.0",'Landvo',{volume: 15});
              }
              
              // Lautstaerke von Android-Tablet auf 13 setzen
              function lautstaerke_tablet(){ 
                  sendTo("paw.0",'Tablet_Jörg',{volume: 13});
              }
              
              
              

              Das Ganze geht bestimmt auch eleganter/einfacher, aber da ich nicht so der JS-Crack bin, habe ich mir das so zusammengefrickelt.

              A Offline
              A Offline
              andbru01
              schrieb am zuletzt editiert von
              #114

              @joergeli Hallo, mir gefällt deine VIS sehr gut. Wäre es eventuell möglich das die Bilder inkl. View (Exportiert) hochgeladen werden?? Lg

              VanduraV joergeliJ 2 Antworten Letzte Antwort
              0
              • A andbru01

                @joergeli Hallo, mir gefällt deine VIS sehr gut. Wäre es eventuell möglich das die Bilder inkl. View (Exportiert) hochgeladen werden?? Lg

                VanduraV Offline
                VanduraV Offline
                Vandura
                schrieb am zuletzt editiert von
                #115

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

                @joergeli Hallo, mir gefällt deine VIS sehr gut. Wäre es eventuell möglich das die Bilder inkl. View (Exportiert) hochgeladen werden?? Lg

                Anycubic.txt

                hier schnonmal die exportierte VIS.......Bilder wenn benötigt später

                Raspberry 4 - 8GB / 500 GB Festplatte mit IoBroker! 1xConbee 2, 15xAQARA Door Sensoren,2xSonoff Door Sensor, 2xSonoff Pov2, 2xAQARA Watersensoren, 3xIKEA TRÅDFRI Bewegungsmelder, 5xIKEA TRÅDFRI Repeater, 1x IKEA TRÅDFRI Treiber 10w, 10xTeckin Steckdosen mit Tasmota-Flash, 1xShelly SHSW-1, 2xAQARA Taster, 4xAlexa...usw.

                A 1 Antwort Letzte Antwort
                1
                • VanduraV Vandura

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

                  @joergeli Hallo, mir gefällt deine VIS sehr gut. Wäre es eventuell möglich das die Bilder inkl. View (Exportiert) hochgeladen werden?? Lg

                  Anycubic.txt

                  hier schnonmal die exportierte VIS.......Bilder wenn benötigt später

                  A Offline
                  A Offline
                  andbru01
                  schrieb am zuletzt editiert von
                  #116

                  @vandura vielen dank. Ja bitte die Bilder auch.

                  VanduraV 1 Antwort Letzte Antwort
                  0
                  • A andbru01

                    @vandura vielen dank. Ja bitte die Bilder auch.

                    VanduraV Offline
                    VanduraV Offline
                    Vandura
                    schrieb am zuletzt editiert von
                    #117

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

                    @vandura vielen dank. Ja bitte die Bilder auch.

                    Anycubic.zip

                    Bitteschön, alle verwendeten Bilder.....hoffe es klappt alles :blush: :+1:

                    Raspberry 4 - 8GB / 500 GB Festplatte mit IoBroker! 1xConbee 2, 15xAQARA Door Sensoren,2xSonoff Door Sensor, 2xSonoff Pov2, 2xAQARA Watersensoren, 3xIKEA TRÅDFRI Bewegungsmelder, 5xIKEA TRÅDFRI Repeater, 1x IKEA TRÅDFRI Treiber 10w, 10xTeckin Steckdosen mit Tasmota-Flash, 1xShelly SHSW-1, 2xAQARA Taster, 4xAlexa...usw.

                    A 1 Antwort Letzte Antwort
                    0
                    • VanduraV Vandura

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

                      @vandura vielen dank. Ja bitte die Bilder auch.

                      Anycubic.zip

                      Bitteschön, alle verwendeten Bilder.....hoffe es klappt alles :blush: :+1:

                      A Offline
                      A Offline
                      andbru01
                      schrieb am zuletzt editiert von
                      #118

                      @vandura Danke

                      1 Antwort Letzte Antwort
                      0
                      • A andbru01

                        @joergeli Hallo, mir gefällt deine VIS sehr gut. Wäre es eventuell möglich das die Bilder inkl. View (Exportiert) hochgeladen werden?? Lg

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

                        @andbru01

                        Sorry für die späte Antwort, war unterwegs.
                        Hier meine Octoprint-Icons (View als Export hatte ich weiter oben hier im Thread schon mal hochgeladen)

                        octoprint-icons.zip

                        Gruß
                        Jörg

                        A 2 Antworten Letzte Antwort
                        0
                        • joergeliJ joergeli

                          @andbru01

                          Sorry für die späte Antwort, war unterwegs.
                          Hier meine Octoprint-Icons (View als Export hatte ich weiter oben hier im Thread schon mal hochgeladen)

                          octoprint-icons.zip

                          Gruß
                          Jörg

                          A Offline
                          A Offline
                          andbru01
                          schrieb am zuletzt editiert von
                          #120

                          @joergeli Danke

                          1 Antwort Letzte Antwort
                          0
                          • joergeliJ joergeli

                            @andbru01

                            Sorry für die späte Antwort, war unterwegs.
                            Hier meine Octoprint-Icons (View als Export hatte ich weiter oben hier im Thread schon mal hochgeladen)

                            octoprint-icons.zip

                            Gruß
                            Jörg

                            A Offline
                            A Offline
                            andbru01
                            schrieb am zuletzt editiert von
                            #121

                            @joergeli Wie hast du dsa mit der Bedienung der achsen gelöst? Welches Widget ist das oder sind das alles einzelteile??

                            joergeliJ 1 Antwort Letzte Antwort
                            0
                            • A andbru01

                              @joergeli Wie hast du dsa mit der Bedienung der achsen gelöst? Welches Widget ist das oder sind das alles einzelteile??

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

                              @andbru01
                              Das sind alles Einzelwidgets vom Typ jqui - ButtonState.
                              Einstellungen für z.B. Z-Achse 10 Schritte hoch:
                              jog.jpg
                              jog2.jpg

                              Ach ja, drehen der Widgets mache ich mit CSS:
                              jog-css.jpg

                              A 2 Antworten Letzte Antwort
                              0
                              • joergeliJ joergeli

                                @andbru01
                                Das sind alles Einzelwidgets vom Typ jqui - ButtonState.
                                Einstellungen für z.B. Z-Achse 10 Schritte hoch:
                                jog.jpg
                                jog2.jpg

                                Ach ja, drehen der Widgets mache ich mit CSS:
                                jog-css.jpg

                                A Offline
                                A Offline
                                andbru01
                                schrieb am zuletzt editiert von
                                #123

                                @joergeli Danke

                                1 Antwort Letzte Antwort
                                0
                                • joergeliJ joergeli

                                  @andbru01
                                  Das sind alles Einzelwidgets vom Typ jqui - ButtonState.
                                  Einstellungen für z.B. Z-Achse 10 Schritte hoch:
                                  jog.jpg
                                  jog2.jpg

                                  Ach ja, drehen der Widgets mache ich mit CSS:
                                  jog-css.jpg

                                  A Offline
                                  A Offline
                                  andbru01
                                  schrieb am zuletzt editiert von
                                  #124

                                  @joergeli Das habe ich mal soweit. Jetzt fehlt mir nur mehr die Home Position.

                                  joergeliJ 1 Antwort Letzte Antwort
                                  0
                                  • A andbru01

                                    @joergeli Das habe ich mal soweit. Jetzt fehlt mir nur mehr die Home Position.

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

                                    @andbru01
                                    .... ebenfalls jqui- ButtonStates mit folgenden Einstellungen:
                                    xy-home.jpg
                                    z-home.jpg

                                    1 Antwort Letzte Antwort
                                    0
                                    • joergeliJ joergeli

                                      @jürgen-b-0 sagte in [UMFRAGE] Besteht Interesse an einem Octoprint Adapter:

                                      1.) Wo ändere ich den User und das Passwort? (Zeile)
                                      2.) Zeile 4? wie kann ich das node-ssh in Javascript-Adapter installieren?
                                      3.) Wie pflege ich das entsprechend im VIS-Editor ein?

                                      1.) User/Passwort: bei //Octoprint-Server via SSH herunterfahren - in der setTimeout(function() ab Zeile 150
                                      2.) node-ssh manuell in den Einstellungen des JavaScript-Adapters hinzufügen/reinschreiben:
                                      node-ssh.jpg
                                      Das dauert dann einen Moment, bis node-ssh installiert wurde.
                                      In den JavaSript-Einstellungen auch den Haken bei Kommandoe "exec" erlauben nicht vergessen!

                                      3.) Anbei mein vis-View nochmals als Export, den kannst Du importieren und Dich daran orientieren.
                                      Natürlich musst Du darin die Pfade anpassen, in denen die Bildchen, etc. gespeichert sind!

                                      Sieht jetzt so aus:
                                      octo-view_export.zip

                                      octo.jpg

                                      #######################################################################################

                                      Ich hatte mein Script zwischenzeitlich noch mal editiert, bzgl. zusätzlichen Ausgaben von Fertigstellungszeit / -Datum.
                                      Außerdem habe ich noch einen Schalter eingebaut, mit dem in der vis ausgewählt werden kann, ob der Drucker nach Fertigstellung und Abkühlung automatisch ausgeschaltet werden soll, oder nicht.
                                      Zusätzlich noch ein paar Buttons für X/Y-Positionierung des Druckkopfes.
                                      Dazu müssen in den vis-Buttons entspr. Werte eingetragen werden, z.B. so:
                                      xy.jpgxy-einstellungen.jpg

                                      autoshutdown.jpg
                                      autoshutdown-einstellungen.jpg

                                      Beachte bitte, daß ich die Sprachausgabe mit PAW mache, das musst Du sehr wahrscheinlich an Deine Gegebenheiten anpassen ( Alexa, Telegram, o.ä.)

                                      Anbei mein aktuelles Script:

                                      //#####################################################################
                                      // 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' // Shelly Plug S Steckdose Octopi und 3D-Drucker
                                      const octopi_autoshutdown           = 'javascript.0.OctoPi.AutoShutdown'        // Drucker nach Druckende autom. ausschalten
                                      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.printtimeLeft'
                                      
                                      
                                      const anycubic_extrudertemp         = 'octoprint.0.tools.tool0.actualTemperature'
                                      const anycubic_extrudertemp_soll    = 'octoprint.0.tools.tool0.targetTemperature'
                                      const anycubic_tempbed              = 'octoprint.0.tools.bed.actualTemperature'
                                      const anycubic_tempbed_soll         = 'octoprint.0.tools.bed.targetTemperature'
                                      
                                      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'
                                      const anycubic_laenge               = 'octoprint.0.printjob.filament.length'
                                      const anycubic_volumen              = 'octoprint.0.printjob.filament.volume'
                                      
                                      const anycubic_gesamtlayer          = 'octoprint.0.plugins.displayLayerProgress.layer.total'
                                      const anycubic_currentlayer         = 'octoprint.0.plugins.displayLayerProgress.layer.current'
                                      
                                      var pfad = 'javascript.0.OctoPi.';
                                      
                                      const {NodeSSH} = require('node-ssh')
                                      const ssh = new NodeSSH()
                                      
                                      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'
                                      });
                                      
                                      createState('javascript.0.OctoPi.Gesamtzeit', {
                                          name: 'Gesamtzeit',
                                          desc: 'Gesamtdauer des Druckjobs',
                                          type: 'string',
                                      });
                                      
                                      
                                      
                                      createState( pfad + 'EndeZeit', {
                                          name: 'EndeZeit',
                                          desc: 'Uhrzeit Fertigstellung des Druckes',
                                          type: 'string'
                                      });
                                      
                                      createState( pfad + 'AutoShutdown', {
                                          name: 'AutoShutdown',
                                          desc: 'Drucker nach Druckende ausschalten',
                                          type: 'boolean'
                                      });
                                      
                                      
                                      
                                      //______ 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) {
                                              var autoshut = false;
                                              octopi_startup();
                                          }
                                      });
                                      
                                      
                                      //____________________________________________________________________________________________________
                                      // Umrechnung der Druckzeiten von Sekunden in HH:MM:SS und Ende-Zeit berechnen
                                      on({id: [anycubic_timeleft], change: "lt"} , function (obj) {
                                          umrechnung();
                                          EndeZeit();
                                      });
                                      
                                      
                                      
                                      
                                      //____________________________________________________________________________________________________
                                      function octopi_shutdown() {
                                                      lautstaerke_tablet();  // Lautstaerke Tablet auf 13 setzen
                                      
                                                      twentyfive = 0;
                                                      fifty = 0;
                                                      seventyfive = 0;
                                                      ninety = 0;
                                                      done = 0;              
                                      
                                                      //ioBroker OctoPi-Instanz beenden
                                                      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 und Layer zuruecksetzen
                                                      setState("javascript.0.OctoPi.Restzeit", '---', true);
                                                      setState('javascript.0.OctoPi.Printzeit', '---', true);
                                                      setState("javascript.0.OctoPi.EndeZeit", '---', true);
                                      				setState("javascript.0.OctoPi.Gesamtzeit", '---', true);
                                                    
                                      				setState("javascript.0.OctoPi.AutoShutdown", false, true);
                                      				setState("javascript.0.OctoPi.Shutdown", true, true);
                                                      
                                                      setState('octoprint.0.plugins.displayLayerProgress.layer.averageDuration', 0, true);
                                                      setState('octoprint.0.plugins.displayLayerProgress.layer.current', 0, true);
                                                      setState('octoprint.0.plugins.displayLayerProgress.layer.total', 0, true);
                                                      }, 5000);
                                      
                                                      //Octoprint-Server via SSH herunterfahren
                                                      setTimeout(function(){
                                                      //log ('__ SSH Verbindung gestartet __');
                                                      //SSH-Session starten, um Octoprint-Raspi sauber! herunterzufahren
                                                          ssh.connect({
                                                              host: '192.168.192.30', //IP-Adresse des Octoprint-Raspi
                                                              username: 'pi',         //Username Octoprint-Raspi (normalerweise pi)
                                                              password: 'xxxxxxxx'    //Passwort Octoprint-Raspi
                                                          }).then(() => {
                                                              ssh.execCommand('echo "xxxxxxxx"|sudo -S shutdown -h now');
                                                              // Achtung! Im execCommand muss nochmals das Passwort für den Octoprint-Raspi eingetragen werden
                                                          });                           
                                      
                                                      }, 6000);   // 6 Sekunden warten
                                      
                                                      //Sprachansage, dass Octopi heruntergefahren wird
                                                      setTimeout(function(){
                                                      sendTo("paw.0",'Tablet_Jörg',{tts:  'Shutdown 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 down'});
                                                      //log ('__ Octoprint-Server ist down __');
                                                      setState (pfad + 'ShuttingDown', 'OctoPrint ist down ...', true);
                                                      }, 18000);
                                      
                                                      //OctoPi- Shelly Plug S - Steckdose ausschalten
                                                      setTimeout(function(){         
                                                      setState(octopi_steckdose, false);
                                                      sendTo("paw.0",'Tablet_Jörg',{tts:  'OctoPrint-Steckdose und 3 D-Drucker sind ausgeschaltet'});
                                                      log ('OctoPi-Steckdose ausgeschaltet');
                                                      setState (pfad + 'ShuttingDown', 'OctoPrint ist ausgeschaltet', true);
                                                      setState("javascript.0.OctoPi.EndeZeit", '---', true);
                                                      }, 24000);
                                      
                                      }   // Ende function octopi_shutdown
                                      
                                      //____________________________________________________________________________________________________
                                      function octopi_startup() {
                                                      lautstaerke_tablet();
                                      
                                                      twentyfive = 0;
                                                      fifty = 0;
                                                      seventyfive = 0;
                                                      ninety = 0;
                                                      done = 0;
                                      
                                                      //Druckzeiten und Layer  zuruecksetzen
                                                      setState("javascript.0.OctoPi.Restzeit", '---', true);
                                                      setState('javascript.0.OctoPi.Printzeit', '---', true);
                                                      setState("javascript.0.OctoPi.EndeZeit", '---', true);
                                      				setState("javascript.0.OctoPi.Gesamtzeit", '---', true);
                                      
                                                      setState("javascript.0.OctoPi.AutoShutdown", false, true);
                                      
                                      
                                                      setState('octoprint.0.plugins.displayLayerProgress.layer.averageDuration', 0, true);
                                                      setState('octoprint.0.plugins.displayLayerProgress.layer.current', 0, true);
                                                      setState('octoprint.0.plugins.displayLayerProgress.layer.total', 0, true);
                                                      setState('octoprint.0.printjob.progress.completion', 0, true);
                                                      //OctoPi-Instanz starten, wenn Octopi-Raspi kpl. hochgefahren ist
                                                      setTimeout(function(){
                                                      octo_adapter_on();
                                                      //sendTo("paw.0",'Tablet_Jörg',{tts:  'Octoprint Instanz wurde gestartet'});
                                                      log('Octoprint Instanz wurde gestartet');
                                                      }, 45000);
                                      
                                      
                                                      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);
                                                      }, 10000);
                                      
                                                      //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 startet ...');
                                                      }, 20000);
                                      
                                                      //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');
                                                      }, 35000);
                                      
                                                      setTimeout(function(){
                                                      // Steckdose einschalten
                                                      setState(octopi_steckdose, true);
                                                      setState (pfad + 'ShuttingDown', '3D Drucker wurde eingeschaltet ...', true);
                                                      log('3D Drucker wurde eingeschaltet ...');
                                                      sendTo("paw.0",'Tablet_Jörg',{tts:  'Der 3Dee Drucker wurde eingeschaltet'});
                                                      }, 100);
                                      
                                      
                                      
                                      
                                      }   //Ende function octopi_startup
                                      
                                      
                                      //____________________________________________________________________________________________________
                                      //OctoPi Online-Meldung, wenn Verbindung zum 3D-Drucker hergestellt wurde
                                      on({id: anycubic_verbindung, change: 'gt'}, function() {
                                              lautstaerke_tablet();
                                              
                                              twentyfive = 0;
                                              fifty = 0;
                                              seventyfive = 0;
                                              ninety = 0;
                                              done = 0;
                                      
                                              //Druckzeiten und Layer  zuruecksetzen
                                              setState("javascript.0.OctoPi.Restzeit", '---', true);
                                              setState('javascript.0.OctoPi.Printzeit', '---', true);
                                              setState("javascript.0.OctoPi.EndeZeit", '---', true);
                                      		setState("javascript.0.OctoPi.Gesamtzeit", '---', true);
                                              setState('octoprint.0.plugins.displayLayerProgress.layer.current', 0, true);
                                              setState('octoprint.0.plugins.displayLayerProgress.layer.total', 0, 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 online'});
                                                  log ('Octoprint-Server ist online');
                                                  setState (pfad + 'ShuttingDown', 'OctoPrint ist online', true);
                                      
                                                  variablen_abfragen();
                                      
                                              }
                                      }); // Ende Meldung Verbindungsherstellung
                                      
                                      
                                      //____________________________________________________________________________________________________
                                      
                                      // Wenn Steckdose ausgeschaltet wird, alles auf 0 setzen (fuer vis)
                                      on({id: octopi_steckdose, change: 'lt'}, function() {
                                              setState (anycubic_fortschritt, 0, true);
                                              setState (anycubic_timedone , 0, true);
                                              setState (anycubic_timeleft , 0, true);
                                              setState (anycubic_extrudertemp , 0, true);
                                              setState (anycubic_extrudertemp_soll , 0, true);
                                              setState (anycubic_tempbed , 0, true);
                                              setState (anycubic_tempbed_soll , 0, true);
                                              setState (anycubic_dateigroesse , 0, true);
                                              setState (anycubic_speicherort , '---', true);
                                              setState (anycubic_dateiname , '---', true);
                                              setState (anycubic_laenge, 0, true);
                                              setState (anycubic_volumen, 0, true);
                                      
                                              setState(anycubic_gesamtlayer, 0, true);
                                              setState(anycubic_currentlayer, 0, true);
                                      
                                              EndeZeit();
                                          }
                                      );
                                      
                                      //____________________________________________________________________________________________________
                                      // Octoprint-Datenpunkte abfragen
                                      function variablen_abfragen(){
                                          //log ('___ Octoprint-Datenpunkte werden gelesen ___');
                                          lautstaerke_tablet();    
                                          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;
                                          var druckdauer          = getState('javascript.0.OctoPi.Gesamtzeit').val;
                                      
                                      
                                          //log ('druckdauer= ' + druckdauer);	
                                      
                                      //    var laenge              = getState(anycubic_laenge).val;
                                      //    var volumen             = getState(anycubic_volumen).val;
                                      
                                      //    setState (pfad + 'Laenge', laenge, true);
                                      //    setState (pfad + 'Laenge', volumen, true);  
                                      
                                      }   // Ende function variablen_abfragen
                                      
                                      //____________________________________________________________________________________________________
                                      //Ansage Druckfortschritt
                                      on({id: anycubic_fortschritt, change: 'any'}, function() {
                                          lautstaerke_tablet();
                                          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 D-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 D-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 D-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 D-Drucker hat ' + druck_fortschritt + 'Prozent des Ausdruckes fertiggestellt'});
                                                      }, 2000);
                                                      log ('## AnyCubic ist zu ' + druck_fortschritt + '% fertig ##');
                                                      ninety = 1;
                                                  } // Ende if fortschrSprache >= 90
                                      }
                                      
                                      }); // Ende Ansage Druckfortschritte
                                      
                                      
                                      
                                      
                                      
                                      
                                      //____________________________________________________________________________________________________
                                      //____________________________________________________________________________________________________
                                      //Ansage, dass der Druck fertig ist, wenn Druckfortschritt = 100% und das Druckbett abgekuehlt (<= 50 Grad) ist,
                                      // optional danach automatisches Herunterfahren
                                      
                                      on({id: anycubic_tempbed, change: 'any'}, function() {
                                      
                                      if(done == 0 ){
                                              
                                      				var druck_fortschritt0  = getState(anycubic_fortschritt).val;
                                      				var druck_fortschritt   = Math.round(druck_fortschritt0 * 1) / 1; // keine Nachkommastellen ansagen
                                      				//log ('Druckfortschritt ist: ' + druck_fortschritt);
                                      
                                                      var bed_temp0           = getState(anycubic_tempbed).val;
                                                      var bed_temp            = Math.round(bed_temp0 * 1) / 1;          // keine Nachkommastellen ansagen
                                                      //log ('bed_temp ist: ' + bed_temp);
                                      
                                                      if(druck_fortschritt == 100 && bed_temp >= 48 && bed_temp <= 50 ){
                                      
                                                      var autoshut = getState('javascript.0.OctoPi.AutoShutdown').val;
                                                      log ('AutoShutdown ist ' + autoshut);
                                      
                                                      // bei aktivem AutoShutdown den Drucker nach Abkuehlung ausschalten
                                                      if ( autoshut  == true ){
                                                          setTimeout(function(){
                                                          log ('--> Drucker wird jetzt automatisch ausgeschaltet');
                                                          octopi_shutdown();
                                                          }, 17000);
                                      
                                                          setTimeout(function(){
                                                          sendTo("paw.0",'Tablet_Jörg',{tts:  'Der Drucker wird jetzt automatisch ausgeschaltet'});
                                                          }, 11000);
                                                      } // ende autoshut true
                                      
                                                      setTimeout(function(){
                                                      sendTo("paw.0",'Tablet_Jörg',{tts:  'Der 3 D-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 && bed_temp >= 48 && bed_temp <= 50 )
                                                  
                                      }   // ende if done
                                      
                                      }); // Ende On ID anycubic_tempbed change
                                      
                                      
                                      
                                      //____________________________________________________________________________________________________
                                      //____________________________________________________________________________________________________
                                      
                                      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_Adapter wurde gestartet __');
                                          setState("system.adapter.octoprint.0.alive", true);
                                      }
                                      
                                      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_Adapter wurde beendet __');
                                          setState("system.adapter.octoprint.0.alive", false);
                                      }
                                      
                                      // 
                                      function umrechnung() {
                                      // Umrechnung der Druckzeiten von Sekunden in HH:MM:SS
                                          var time_left = getState("octoprint.0.printjob.progress.printtimeLeft").val;
                                          var job_time  = getState('octoprint.0.printjob.progress.printtime').val;
                                      	var duration = time_left + job_time;
                                      
                                          // Hours
                                          var hours_restzeit  =  Math.floor( time_left / 3600 );
                                          var hours_printzeit =  Math.floor( job_time  / 3600 );
                                          var hours_duration  =  Math.floor( duration  / 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)
                                          if ( hours_duration < 10 ){var std_duration= "0" + String(hours_duration); }
                                              else var std_duration = String(hours_duration)			
                                      
                                          // Minutes
                                          var minutes_restzeit  = Math.floor( (time_left%3600) / 60 );
                                          var minutes_printzeit = Math.floor( (job_time%3600)  / 60 );
                                      	var minutes_duration  = Math.floor( (duration%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)
                                          if ( minutes_duration < 10 ){var min_duration= "0" + String(minutes_duration); }
                                              else var min_duration = String(minutes_duration)		
                                      
                                          // Seconds
                                          var seconds_restzeit  = Math.floor( time_left%60 );
                                          var seconds_printzeit = Math.floor( job_time%60  );
                                          var seconds_duration  = Math.floor( duration%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)
                                          if ( seconds_duration < 10 ){var sec_duration= "0" + String(seconds_duration); }
                                              else var sec_duration = String(seconds_duration)
                                      
                                          // Zeit in HH:MM:SS format
                                          var restzeit  = std_restzeit  + ':' + min_restzeit  + ':' + sec_restzeit;
                                          var printzeit = std_printzeit + ':' + min_printzeit + ':' + sec_printzeit;
                                          var dauer     = std_duration  + ':' + min_duration  + ':' + sec_duration;
                                      
                                      	//console.log("Restzeit:" + restzeit + "__" + " Printzeit:" + printzeit + "__"  +" Dauer:" + dauer);
                                      
                                          setState("javascript.0.OctoPi.Restzeit", restzeit, true);
                                          setState('javascript.0.OctoPi.Printzeit', printzeit, true);
                                      	setState("javascript.0.OctoPi.Gesamtzeit", dauer, true);
                                      
                                      }
                                      
                                      //____________________________________________________________________________________________________
                                      
                                      
                                      // Druck-Ende Uhrzeit berechnen //
                                      //#################################
                                      
                                      function EndeZeit(){
                                      
                                      var time_left = getState("octoprint.0.printjob.progress.printtimeLeft").val;
                                      var sekunden_restzeit  = time_left; // Restzeit in Sekunden aus Octopi
                                      if(time_left == null || time_left == 0 ){ setState("javascript.0.OctoPi.EndeZeit", '---', true) };
                                      
                                      var Zeit = new Date();
                                      //log('jetzt: ' + Zeit);
                                      
                                      var z0_neu = Zeit.getSeconds()+ sekunden_restzeit;
                                      var z_neu = Zeit.setSeconds(z0_neu);
                                      var ZeitNeu = new Date(z_neu);
                                      //console.log('Endezeit: '  + ZeitNeu);
                                      
                                      var h_ende = ZeitNeu.getHours();
                                      var m_ende = ZeitNeu.getMinutes();
                                      var s_ende = ZeitNeu.getSeconds();
                                      var tag_ende = ZeitNeu.getDate();
                                      var months = ["Jan", "Feb", "Mrz", "Apr", "Mai", "Jun", "Jul", "Aug", "Sep", "Okt", "Nov", "Dez"];
                                      var monat_ende  = months[ZeitNeu.getMonth()];
                                      
                                      var EndeZeit = tag_ende + '.' + monat_ende + ' ' + h_ende + ':' + m_ende + ':' + s_ende;
                                      //console.log('EndeZeit: '  + EndeZeit);
                                      
                                          // Führende 0 hinzufügen und als String wandeln
                                          if ( tag_ende  < 10 ){var endtag = "0" + String(tag_ende);}
                                              else var endtag = String(tag_ende)
                                          if ( h_ende  < 10 ){var endstunde = "0" + String(h_ende);}
                                              else var endstunde = String(h_ende)
                                          if ( m_ende  < 10 ){var endminute = "0" + String(m_ende);}
                                              else var endminute = String(m_ende)
                                          if ( s_ende  < 10 ){var endsekunde = "0" + String(s_ende);}
                                              else var endsekunde = String(s_ende)
                                      
                                      var EndeZeit = endtag + '. ' + monat_ende + '  ' + endstunde + ':' + endminute + ':' + endsekunde;
                                      //console.log('EndeZeit: '  + EndeZeit);
                                      //setState("javascript.0.OctoPi.EndeZeit", EndeZeit, true);
                                      
                                      if(time_left == null || time_left == 0 ){ setState("javascript.0.OctoPi.EndeZeit", '---', true) }
                                      else setState("javascript.0.OctoPi.EndeZeit", EndeZeit, true);
                                      
                                      }   // end of function EndeZeit()
                                      
                                      //____________________________________________________________________________________________________
                                      
                                      
                                      
                                      // Lautstaerke von Landvo-Smartphone auf 15 setzen
                                      function lautstaerke(){
                                          sendTo("paw.0",'Landvo',{volume: 15});
                                      }
                                      
                                      // Lautstaerke von Android-Tablet auf 13 setzen
                                      function lautstaerke_tablet(){ 
                                          sendTo("paw.0",'Tablet_Jörg',{volume: 13});
                                      }
                                      
                                      
                                      

                                      Das Ganze geht bestimmt auch eleganter/einfacher, aber da ich nicht so der JS-Crack bin, habe ich mir das so zusammengefrickelt.

                                      blue231181B Offline
                                      blue231181B Offline
                                      blue231181
                                      schrieb am zuletzt editiert von
                                      #126

                                      @joergeli Danke für dieses tolle Skript, kann ich hier anstatt paw.0 einfach meine Alexa Sprachausgabe (alexa2.1.Echo-Devices.G0913L061032041X.Commands.speak) einfügen?
                                      Viele Grüße

                                      joergeliJ 1 Antwort Letzte Antwort
                                      0
                                      • blue231181B blue231181

                                        @joergeli Danke für dieses tolle Skript, kann ich hier anstatt paw.0 einfach meine Alexa Sprachausgabe (alexa2.1.Echo-Devices.G0913L061032041X.Commands.speak) einfügen?
                                        Viele Grüße

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

                                        @blue231181
                                        Ich habe es zwar nicht getestet, sollte aber funktionieren.

                                        Edit:
                                        Gerade getestet ---> funktioniert :blush:

                                        setState("alexa2.0.Echo-Devices.G0922K062434xxxx.Commands.speak", '60; OctoPrint-Server wird gestartet.', false);
                                         //  sendTo("paw.0",'Tablet_Jörg',{tts:  'OctoPrint-Server wird gestartet'});
                                        
                                        

                                        Also die "sendTo( paw.....)-Befehle auskommentieren, oder löschen und stattdessen die
                                        entspr. Alexa-Commands.speak einfügen.
                                        Hinweis: die 60 im Beispiel ist die Lautstärke, mit der das Speak-Command ausgegeben wird.

                                        blue231181B 1 Antwort Letzte Antwort
                                        1
                                        • joergeliJ joergeli

                                          @blue231181
                                          Ich habe es zwar nicht getestet, sollte aber funktionieren.

                                          Edit:
                                          Gerade getestet ---> funktioniert :blush:

                                          setState("alexa2.0.Echo-Devices.G0922K062434xxxx.Commands.speak", '60; OctoPrint-Server wird gestartet.', false);
                                           //  sendTo("paw.0",'Tablet_Jörg',{tts:  'OctoPrint-Server wird gestartet'});
                                          
                                          

                                          Also die "sendTo( paw.....)-Befehle auskommentieren, oder löschen und stattdessen die
                                          entspr. Alexa-Commands.speak einfügen.
                                          Hinweis: die 60 im Beispiel ist die Lautstärke, mit der das Speak-Command ausgegeben wird.

                                          blue231181B Offline
                                          blue231181B Offline
                                          blue231181
                                          schrieb am zuletzt editiert von
                                          #128

                                          @joergeli dankeschön im Namen der Java unwissenden 👏

                                          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

                                          647

                                          Online

                                          32.5k

                                          Benutzer

                                          81.9k

                                          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