Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. [GELÖST] Javascript von einer ext. Seite Einbinden in ioBroker

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    [GELÖST] Javascript von einer ext. Seite Einbinden in ioBroker

    This topic has been deleted. Only users with topic management privileges can see it.
    • paul53
      paul53 last edited by

      https://forum.iobroker.net/viewtopic.php?f=21&t=11987&p=126520#p127232 lässt sich sicherlich auf bis zu 100 Bildern erweitern.

      1 Reply Last reply Reply Quote 0
      • T
        tomdeboom last edited by

        Danke Paul, aber dann müsste ich z.B. im Widget Image 8 alle 100 Bilder hinterlegen?

        Und anstatt "states: {" müsste ich aus der neuen funktion "phase" benutzen?

        Gruß,

        Tom

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

          @tomdeboom:

          dann müsste ich z.B. im Widget Image 8 alle 100 Bilder hinterlegen? `
          Von VIS habe ich keine Ahnung 😞
          @tomdeboom:

          anstatt "states: {" müsste ich aus der neuen funktion "phase" benutzen? `
          states (Zustandstexte) ist eine definierte Eigenschaft von Datenpunkten in ioBroker. Wenn mehr Bilder gewünscht werden, muss die Anzahl erweitert werden (pro Bild ein Integer-Wert 0…N).

          1 Reply Last reply Reply Quote 0
          • T
            tomdeboom last edited by

            Ok, danke ich versuche mal mein Glück…

            Ich Lasse aber die Frage nochmal offen. 😄

            Gruß,

            Tom

            1 Reply Last reply Reply Quote 0
            • arteck
              arteck Developer Most Active last edited by

              du kannst doch dynamisch die das Widget füllen

              1 Reply Last reply Reply Quote 0
              • T
                tomdeboom last edited by

                Hallo arteck,

                und wie mache ich das?

                Gruß,

                Tom

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

                  @tomdeboom:

                  anstatt "states: {" müsste ich aus der neuen funktion "phase" benutzen? `
                  Die states kann man auch weglassen, was bei 100 Werten zu empfehlen ist. Die Integerwerte erzeugt man dann nicht mit if(…), sondern per Berechnung.

                  const suncalc = require('suncalc');
                  const idVis = 'Vis.Mondphase';  // Für Vis
                  
                  createState(idVis, 0, {
                     type: 'number',
                     min: 1,
                     max: 100,
                     role: 'level',
                  });
                  
                  function mpVis() {
                     var mond = suncalc.getMoonIllumination(new Date());
                     var mp = mond.phase;  // 0...1 mit 0 = Neumond
                     mp = 100 * mp - 50;
                     if(mp < 0.5) mp = mp + 100;  // Neumond = 50 
                     mp = Math.round(mp); // Integer 1 ... 100, 100 = Vollmond
                     setState(idVis, mp, true);
                  }
                  
                  mpVis(); // Skriptstart
                  
                  schedule("*/10 * * * *", mpVis);  // alle 10 Minuten
                  
                  1 Reply Last reply Reply Quote 0
                  • T
                    tomdeboom last edited by

                    Hallo Paul,

                    vielen Dank für das Script, es funktioniert so das ich die Bild Nummer in ein State geschrieben bekomme.

                    Nun versuche ich gerade das Script so zu ergänzen das ich den kompletten Bildpfad als State geschrieben bekomme.

                    Nur bekomme ich es nicht hin, habe jetzt schon verschiedene Ansätze versucht, aber irgendwie funktioniert es nicht…

                    Hier mein Versuch:

                    const suncalc = require('suncalc');
                    const idVis = 'Vis.Mondphase2';  // Für Vis
                    
                    var pfad = "/vis.0/main/Icon/Wetter/phasenbilder/";
                    
                    // createState('Vis.Image', 0, {type: 'string'});
                    createState('Vis.Image', pfad + mp + '.png', {type: 'string'}); // funktioniert nicht
                    
                    createState(idVis, 0, {
                       type: 'number',
                       min: 1,
                       max: 100,
                       role: 'level',
                    });
                    
                    function mpVis() {
                       var mond = suncalc.getMoonIllumination(new Date());
                       var mp = mond.phase;  // 0...1 mit 0 = Neumond
                       mp = 100 * mp - 50;
                       if(mp < 0.5) mp = mp + 100;  // Neumond = 50 
                       mp = Math.round(mp); // Integer 1 ... 100, 100 = Vollmond
                       setState(idVis, mp, true);
                    }
                    
                    // setState('Vis.Image', pfad + mp + '.png'); // funktioniert nicht
                    
                    mpVis(); // Skriptstart
                    
                    schedule("*/1 * * * *", mpVis);  // alle 1 Minuten
                    
                    

                    Kannst du mir dabei helfen? Und kann ich dann später diesen State dazu nutzen um das Bild mit z.B. "basic - string img scr" mir anzeigen zu lassen?

                    Gruß,

                    Tom

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

                      Möchtest Du den Pfad zur png-Datei in den Datenpunkt schreiben ? Wenn ja, wozu ?

                      Oder möchtest Du den Inhalt der png-Datei in den Datenpunkt schreiben ? Das dürfte kaum gelingen.
                      @tomdeboom:

                      Und kann ich dann später diesen State dazu nutzen um das Bild mit z.B. "basic - string img scr" mir anzeigen zu lassen? `
                      Wie schon weiter oben erwähnt, habe ich von VIS keine Ahnung.

                      1 Reply Last reply Reply Quote 0
                      • T
                        tomdeboom last edited by

                        sorry wg. der vis Anfrage…

                        Also ich hätte gerne einen Datenpunkt wo dann der komplette Pfad mit dem jeweiligen Bild steht.

                        so: /vis.0/main/Icon/Wetter/phasenbilder/32.png

                        Gruß,

                        Tom

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

                          @tomdeboom:

                          Datenpunkt wo dann der komplette Pfad mit dem jeweiligen Bild steht.

                          so: /vis.0/main/Icon/Wetter/phasenbilder/32.png `
                          Bei createState() kann die Variable mp nicht verwendet werden, da sie lokal (innerhalb einer Funktion) deklariert ist.

                          Das setState() muss innerhalb der Funktion aufgerufen werden.

                          const suncalc = require('suncalc');
                          const idVis = 'Vis.Mondphase2';  // Für Vis
                          const pfad = '/vis.0/main/Icon/Wetter/phasenbilder/';
                          
                          createState('Vis.Image', pfad + '1.png', {type: 'string'});
                          
                          createState(idVis, 0, {
                             type: 'number',
                             min: 1,
                             max: 100,
                             role: 'level',
                          });
                          
                          function mpVis() {
                             var mond = suncalc.getMoonIllumination(new Date());
                             var mp = mond.phase;  // 0...1 mit 0 = Neumond
                             mp = 100 * mp - 50;
                             if(mp < 0.5) mp = mp + 100;  // Neumond = 50 
                             mp = Math.round(mp); // Integer 1 ... 100, 100 = Vollmond
                             setState(idVis, mp, true);
                             setState('Vis.Image', pfad + mp + '.png', true);
                          }
                          
                          mpVis(); // Skriptstart
                          
                          schedule("*/1 * * * *", mpVis);  // alle 1 Minuten
                          
                          1 Reply Last reply Reply Quote 0
                          • T
                            tomdeboom last edited by

                            Guten Morgen,

                            vielen Dank für die schnelle Beantwortung! Ich finde es immer wieder Super das du es auch erklärst was man falsch gemacht hat.

                            Nur so kann ich es Lernen.

                            Schönen Tag und Gruß,

                            Tom

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

                            Support us

                            ioBroker
                            Community Adapters
                            Donate

                            851
                            Online

                            31.7k
                            Users

                            79.8k
                            Topics

                            1.3m
                            Posts

                            3
                            14
                            1428
                            Loading More Posts
                            • Oldest to Newest
                            • Newest to Oldest
                            • Most Votes
                            Reply
                            • Reply as topic
                            Log in to reply
                            Community
                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                            The ioBroker Community 2014-2023
                            logo