Skip to content
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • 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

  • Default (No Skin)
  • No Skin
Collapse
Logo
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. JavaScript
  5. [Vorlage] Automatischer View-Wechsel u. Slideshow

NEWS

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

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    1.8k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    15
    1
    2.0k

[Vorlage] Automatischer View-Wechsel u. Slideshow

[Vorlage] Automatischer View-Wechsel u. Slideshow

Scheduled Pinned Locked Moved JavaScript
143 Posts 22 Posters 22.5k Views 48 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • S Offline
    S Offline
    Solider
    wrote on last edited by
    #101

    Moin ! 🙂

    Vorweg schonmal Super Arbeit!

    ich häng grad n bissl...
    Ich möchte kein durchschalten der Views, da bei mir der Touchscreen nach 2 min eh ausschaltet. (Hab 1 RPI 4 als "Zentralen Rechner" und 1 RPI3B+ mit 10.1 " Touchscreen als Wandtablet)

    Ich möchte also nur, dass er nach Zeit X zu Homeview zurückkehrt.
    JS macht mir eigentlich weniger Probleme nur ich kann hier nicht ganz auseinanderfriemeln, was jetzt wofür ist. (die Alarmanlagengeschichte hab ich bei mir schon auskommentiert :D)

    Aber irgendwie macht er bisher garnichts...

    Ich könnte ja die nur die Homeview in die slideshow nehmen und dann bildschirmschoner nach 2 minuten. aber das scheint mir eher "gecheatet" im sinne des Scripts 😄
    Best Grüße

    Florian 🙂

    PeoplesP 1 Reply Last reply
    0
    • PeoplesP Peoples

      @Bostil
      Das mit dem Schreibfehler hat es teilweise verschlimmert, weil du nur einen der Schreibfehler korrigiert hast 😁

      Wenn ich oben nachsehe hast du Zeile 215 korrigiert, aber die Zeile 67 in der das Objekt angelegt wird nicht.

      Besser die mal aus und sag Bescheid ob sich was ändert.

      BostilB Offline
      BostilB Offline
      Bostil
      wrote on last edited by
      #102

      @Peoples Danke dir! Das war auf jedenfall eines der Probleme! Danke danke 🙂

      Jetzt bleibt nur noch folgende Fehlermeldung, wenn ich über den Schalte den Screensaver aktiviere:
      22:01:25.846 error javascript.0 (1210) at Object.<anonymous> (script.js.common.Viewwechsel:235:9)

      //
      // Seitenwechsel-Script
      // Autor: Peoples
      //
      //
      // Funktionen:  1. Bei Viewwechsel wird geprüft ob eine andere View als Home gewählt ist
      //                 wenn das der Fall ist wird ein Timer gesetzt nach dessen Ablauf wieder zurück
      //                 auf Home gewechselt wird.
      //              2. Wenn die Alarmanlage eingeschalten ist wird die PinEingabeView angezeigt.
      //              3. Bei SystemView läuft kein Timer
      //
      //
      // v2.0.0 - 30.09.2018  Neue Version - Grundaufbau geändert
      // v2.0.1 - 09.03.2019  Slideshow aller gewünschen Views integriert
      // v2.0.2 - 23.03.2019  Zusatzfunktion zum steuern der Sonderdatenpunkte eingebaut
      // v2.0.3 - 28.03.2019  Zahlenwerte durch parseInt konvertiert
      // v2.0.4 - 21.05.2019  Fehlerkorrekturen
      // v2.0.5 - 14.09.2019  AutoViewWechsel als Screensaver möglich
      // *******************************************************************************************************
       
      // -----------------------------------------------------------------------------
      // allgemeine Variablen
      // -----------------------------------------------------------------------------
      var logging = false;                                        // Logging on/off
      var instanz = 'javascript.0';   instanz = instanz + '.';    // 
                                                                  //
      var pfad0 =   'System.Iobroker';      pfad0 = pfad0 + '.';  // Pfad innerhalb der Instanz 
      var timerTout;
      var timerAutoSV;
      var DefaultView = 'Main';                                   // Standard-View
       
      // Aus Datenpunkt vis.0.control.data entnehmen 
      // der Teil vor dem Slash ist der Projektname:
      // "Wandtablet/Home"
      var project = "Vision";     project = project + '/';    // Name des Vis-Projekts
       
      var DisplayTime = '480';                                     // Darstellungszeit der Views bei Autowechsel
      var startView = 1;                                          // Startview bei Autowechsel
      var screenSv_time = 1;                                     // Zeit nach der der ScreenSaver Seitenwechsel angeht in Minuten
       
      //Alle vorhandenen Views
      var VisViews = [
          
              /* View Name */                  /* Anzeigezeit */   /* In Slideshow anzeigen? */
       
          {'view':'Screensaver1',             'SWSec':180,            'ShowIAV':'yes'},
          {'view':'Screensaver2',         'SWSec':180,            'ShowIAV':'yes'},
          {'view':'Screensaver3',                     'SWSec':180,            'ShowIAV':'yes'},
          {'view':'Screensaver4',                      'SWSec':180,            'ShowIAV':'yes'},
          {'view':'Screensaver5',                     'SWSec':120,            'ShowIAV':'yes'},
          {'view':'Screensaver6',                       'SWSec':60,             'ShowIAV':'yes'},
          {'view':'Screensaver7',            'SWSec':40,             'ShowIAV':'yes'},
          {'view':'Screensaver8',                   'SWSec':180,            'ShowIAV':'yes'},
          {'view':'Screensaver9',                   'SWSec':180,            'ShowIAV':'yes'},
          {'view':'Screensaver10',       'SWSec':90,             'ShowIAV':'yes'},
          {'view':'Main',                         'SWSec':0,              'ShowIAV':'yes'},
          {'view':'Screensaver11',                      'SWSec':90,             'ShowIAV':'yes'},
          {'view':'Screensaver12',                'SWSec':60,             'ShowIAV':'no'},
      
      ];
      // -----------------------------------------------------------------------------
      // Objekte
      // -----------------------------------------------------------------------------
      // Objekt für Alle Automatischen Abläufe
      createState(pfad0 + 'Timer_View_Switch',  {def: '0',type: 'number',name: 'Timer für Wechsel auf DefaultView'});
      createState(pfad0 + 'Auto_Switch_View',  {def: 'false',type: 'boolean',name: 'Alle Views durchlaufen lassen'});
      createState(pfad0 + 'ScreenSaverActive',  {def: 'false',type: 'boolean',name: 'Bildschirmschoner'});
       
       
      if(logging)log("Total "+Object.keys(VisViews).length+" entries");
       
      // $$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$
      // $$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$
      // $$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$
      // $$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$
       
      // #############################################################################
      // #                                                                           #
      // #  Funktion zum automatischen Viewwechsel nach Timerablauf                  #
      // #                                                                           #
      // #############################################################################
       
      function switchToHomeView() {
              timerTout = setTimeout(function () {
                  var timer = parseInt(getState(pfad0 + 'Timer_View_Switch').val, 10);
                  if (timer > 1) {
                      setState(pfad0 + 'Timer_View_Switch',timer - 1);
                      switchToHomeView();
                  }
                  else{
                      setState(pfad0 + 'Timer_View_Switch', 0);
                      setState('vis.0.control.instance', 'FFFFFFFF'); //getState("vis.0.control.instance").val/*Control vis*/);
                      setState('vis.0.control.data', project + DefaultView);
                      setState('vis.0.control.command', 'changeView');
                  }
              }, 1000);
      }
       
      // #############################################################################
      // #                                                                           #
      // #  Funktion zum automatisch umlaufenden Viewwechsel                         #
      // #                                                                           #
      // #############################################################################
       
      function autoSwitchView(dspTime,i) {
              if(i === '') i = 0;
              if(logging) log(i);
              if(i < Object.keys(VisViews).length){
                  if(VisViews[i].ShowIAV == 'yes'){
                      timerAutoSV = setTimeout(function () {
                          var timer = parseInt(getState(pfad0 + 'Timer_View_Switch').val, 10);
                          if (timer > 1) {
                              setState(pfad0 + 'Timer_View_Switch', timer - 1);
                              autoSwitchView(dspTime, i);
                          }
                          else{
                                  setState(pfad0 + 'Timer_View_Switch', 0);
                                  if(getState(pfad0 + 'Auto_Switch_View').val === true) switchView(project+VisViews[i].view);
                                  startAutoSwitchView(dspTime,(i+1));
                          }
                      }, 1000);
                  }
                  else{
                      startAutoSwitchView(dspTime,(i+1));
                  }
              }
              else{
                 startAutoSwitchView(dspTime,startView); 
              }
      }
       
      // #############################################################################
      // #                                                                           #
      // #  Funktion zum Starten und Stoppen des automatischen Viewwechsel           #
      // #                                                                           #
      // #############################################################################
      function startAutoSwitchView(dspTime,i){
          if(getState(pfad0 + 'Auto_Switch_View').val === true){
              if(dspTime !== ''){
                  setState(pfad0 + 'Timer_View_Switch',parseInt(dspTime, 10));
              }
              else{
                  setState(pfad0 + 'Timer_View_Switch',15);
              }
              autoSwitchView(dspTime,i);
          } 
          else{
              if(timerTout) clearTimeout(timerTout);
              switchView(project + DefaultView);
              setStateDelayed(pfad0 + 'Timer_View_Switch',0,2000);
          }
      }
      //
      // Beobachten des View Datenpunktes
      on({id:"javascript.0.System.Iobroker.Auto_Switch_View", change: "ne"}, function (dp) {
      //    if(dp.state.val === true){
              startAutoSwitchView(DisplayTime,startView);
      //    }
      });
       
      // #############################################################################
      // #                                                                           #
      // #  Funktion zum Scriptbasierten Viewwechsel                                 #
      // #                                                                           #
      // #############################################################################
       
      function switchView(view){
          setState('vis.0.control.instance', 'FFFFFFFF');
          setState('vis.0.control.data', view);
          setState('vis.0.control.command', 'changeView');
      }
       
      // #############################################################################
      // #                                                                           #
      // #  Funktion zum Prüfen der Wunsch View und zum auslesen der Darstellzeit    #
      // #                                                                           #
      // #############################################################################
       
      function checkView(wishView){
          if(logging) log('View to check:'+wishView);
          if(getState(pfad0 + 'Auto_Switch_View').val === false ){
              for(var i = 0; i < Object.keys(VisViews).length; i++) {  
                  if(project+VisViews[i].view == wishView) {
                      if(logging) log('View found in:' + i);
                      if(timerTout) clearTimeout(timerTout);
                      setState(pfad0 + 'Timer_View_Switch', 0);
                      if(VisViews[i].SWSec !== 0){
                          setState(pfad0 + 'Timer_View_Switch', VisViews[i].SWSec);
                          switchToHomeView();
                      }
                  }
              }
          }
      }
      // #############################################################################
      // #                                                                           #
      // #  Zusatzfunktion um ZusatzDatenpunke zu steuern                            #
      // #                                                                           #
      // #############################################################################
      function additionalActions(dp){
          if(dp == "Wandtablet/System"){
              setState(pfad0 + "Letzte_System_Meldungen_prio", '');
          }
          if(dp == "Wandtablet/Kamera_Bilder_Haustuere"){
              setState(pfad0 + "Tuerklingel_in_Abwesenheit", false);
          }
      }
      // #############################################################################
      // #                                                                           #
      // #  ScreenSaver Funktion zum Durchschalten der Views als Bildschirmschoner   #
      // #                                                                           #
      // #############################################################################
      function screenSaver(){
          svTimer = setTimeout(function() {
              if(getState(pfad0 + 'ScreenSaverActive').val === true){
                  if((new Date().getTime() - getState('vis.0.control.data').lc)/60000 > screenSv_time){
                      setState(pfad0 + 'Auto_Switch_View', true);
                  }
                  else{
                      setState(pfad0 + 'Auto_Switch_View', false);
                  }  
                  screenSaver();  
              }
          }, 60000);
          
      }
       
      // Beobachten des Datenpunktes Screensaver um die Autoview einzuschalten
      on({id:'javascript.0.System.Iobroker.ScreenSaverActive'/*Bildschirmschoner*/, change: "ne"}, function (dp) {
          if(dp.state.val === true){
              screenSaver();
              if(logging) log('Screensaver On');
          }
          else{
              if(svTimer) clearTimeout(svTimer);
              setState(pfad0 + 'Auto_Switch_View', false);
              switchView(project + DefaultView);
          } 
      });
       
       
      // Beobachten des View Datenpunktes für Auswertung
      on({id:"vis.0.control.data", change: "ne"}, function (dp) {
          checkView(dp.state.val);
              // Zusatzfunktion um den Datenpunkt zurück zu setzten
          additionalActions(dp.state.val);
      });
       
       
       
      //Bei aktiver Alarmanlage auf Pin-View umschalten
      on({id: "javascript.0.Alarmanlage.Status.Status"/*Status für Scharfmeldung*/, change: 'any'}, function (dp) {
          if(dp.state.val == 2 || dp.state.val == '2'){
              switchView('Alarmanlage_code');
          }
          else{
              switchView(DefaultView);
          }
      });
       
      //Bei Bewegung auf Kamerabild umschalten
      on({id:"hm-rpc.0.XXXXXXXXXX.1.MOTION"/*Bewegungsmelder.Aussen.Haustuere.XXXXXXXXX:1.MOTION*/, change: 'any'}, function (dp) {
          if(dp.state.val === true ){
               if(getState("javascript.0.Alarmanlage.Status.Status").val != 2 || getState("javascript.0.Alarmanlage.Status.Status").val != '2'){
                 switchView('Kamera_Garage');
               }
               else{
                  switchView('Alarmanlage_code');
               }
          }
      });
       
       
      
      
      PeoplesP 1 Reply Last reply
      0
      • S Solider

        Moin ! 🙂

        Vorweg schonmal Super Arbeit!

        ich häng grad n bissl...
        Ich möchte kein durchschalten der Views, da bei mir der Touchscreen nach 2 min eh ausschaltet. (Hab 1 RPI 4 als "Zentralen Rechner" und 1 RPI3B+ mit 10.1 " Touchscreen als Wandtablet)

        Ich möchte also nur, dass er nach Zeit X zu Homeview zurückkehrt.
        JS macht mir eigentlich weniger Probleme nur ich kann hier nicht ganz auseinanderfriemeln, was jetzt wofür ist. (die Alarmanlagengeschichte hab ich bei mir schon auskommentiert :D)

        Aber irgendwie macht er bisher garnichts...

        Ich könnte ja die nur die Homeview in die slideshow nehmen und dann bildschirmschoner nach 2 minuten. aber das scheint mir eher "gecheatet" im sinne des Scripts 😄
        Best Grüße

        Florian 🙂

        PeoplesP Offline
        PeoplesP Offline
        Peoples
        wrote on last edited by
        #103

        @Solider sagte in [[Vorlage] Automatischer View-Wechsel u. Slideshow](/post

        Ich möchte also nur, dass er nach Zeit X zu Homeview zurückkehrt.

        Du musst eigentlich nur hier:

        var DefaultView = 'Home';                                   // Standard-View
        var project = "Wandtablet";
        

        deine Homeview und den Namen deines Vis-Projekts und hier:

               /* View Name */                  /* Anzeigezeit */   /* In Slideshow anzeigen? */
        
            {'view':'Alarmanlage_code',             'SWSec':180,            'ShowIAV':'no'},
            {'view':'Backup_Konfiguration',         'SWSec':180,            'ShowIAV':'no'},
        

        View ist der Name der View(s) bei denen der "Auto zurück Wechsel" funktionieren soll.
        SWSec ist die Zeit nach der zurück gewechselt wird
        ShowIAV wäre für den Screensaver und in deinem Fall nicht nötig

        Ich beantworte keine Fragen zu Themen via PN

        S 1 Reply Last reply
        0
        • BostilB Bostil

          @Peoples Danke dir! Das war auf jedenfall eines der Probleme! Danke danke 🙂

          Jetzt bleibt nur noch folgende Fehlermeldung, wenn ich über den Schalte den Screensaver aktiviere:
          22:01:25.846 error javascript.0 (1210) at Object.<anonymous> (script.js.common.Viewwechsel:235:9)

          //
          // Seitenwechsel-Script
          // Autor: Peoples
          //
          //
          // Funktionen:  1. Bei Viewwechsel wird geprüft ob eine andere View als Home gewählt ist
          //                 wenn das der Fall ist wird ein Timer gesetzt nach dessen Ablauf wieder zurück
          //                 auf Home gewechselt wird.
          //              2. Wenn die Alarmanlage eingeschalten ist wird die PinEingabeView angezeigt.
          //              3. Bei SystemView läuft kein Timer
          //
          //
          // v2.0.0 - 30.09.2018  Neue Version - Grundaufbau geändert
          // v2.0.1 - 09.03.2019  Slideshow aller gewünschen Views integriert
          // v2.0.2 - 23.03.2019  Zusatzfunktion zum steuern der Sonderdatenpunkte eingebaut
          // v2.0.3 - 28.03.2019  Zahlenwerte durch parseInt konvertiert
          // v2.0.4 - 21.05.2019  Fehlerkorrekturen
          // v2.0.5 - 14.09.2019  AutoViewWechsel als Screensaver möglich
          // *******************************************************************************************************
           
          // -----------------------------------------------------------------------------
          // allgemeine Variablen
          // -----------------------------------------------------------------------------
          var logging = false;                                        // Logging on/off
          var instanz = 'javascript.0';   instanz = instanz + '.';    // 
                                                                      //
          var pfad0 =   'System.Iobroker';      pfad0 = pfad0 + '.';  // Pfad innerhalb der Instanz 
          var timerTout;
          var timerAutoSV;
          var DefaultView = 'Main';                                   // Standard-View
           
          // Aus Datenpunkt vis.0.control.data entnehmen 
          // der Teil vor dem Slash ist der Projektname:
          // "Wandtablet/Home"
          var project = "Vision";     project = project + '/';    // Name des Vis-Projekts
           
          var DisplayTime = '480';                                     // Darstellungszeit der Views bei Autowechsel
          var startView = 1;                                          // Startview bei Autowechsel
          var screenSv_time = 1;                                     // Zeit nach der der ScreenSaver Seitenwechsel angeht in Minuten
           
          //Alle vorhandenen Views
          var VisViews = [
              
                  /* View Name */                  /* Anzeigezeit */   /* In Slideshow anzeigen? */
           
              {'view':'Screensaver1',             'SWSec':180,            'ShowIAV':'yes'},
              {'view':'Screensaver2',         'SWSec':180,            'ShowIAV':'yes'},
              {'view':'Screensaver3',                     'SWSec':180,            'ShowIAV':'yes'},
              {'view':'Screensaver4',                      'SWSec':180,            'ShowIAV':'yes'},
              {'view':'Screensaver5',                     'SWSec':120,            'ShowIAV':'yes'},
              {'view':'Screensaver6',                       'SWSec':60,             'ShowIAV':'yes'},
              {'view':'Screensaver7',            'SWSec':40,             'ShowIAV':'yes'},
              {'view':'Screensaver8',                   'SWSec':180,            'ShowIAV':'yes'},
              {'view':'Screensaver9',                   'SWSec':180,            'ShowIAV':'yes'},
              {'view':'Screensaver10',       'SWSec':90,             'ShowIAV':'yes'},
              {'view':'Main',                         'SWSec':0,              'ShowIAV':'yes'},
              {'view':'Screensaver11',                      'SWSec':90,             'ShowIAV':'yes'},
              {'view':'Screensaver12',                'SWSec':60,             'ShowIAV':'no'},
          
          ];
          // -----------------------------------------------------------------------------
          // Objekte
          // -----------------------------------------------------------------------------
          // Objekt für Alle Automatischen Abläufe
          createState(pfad0 + 'Timer_View_Switch',  {def: '0',type: 'number',name: 'Timer für Wechsel auf DefaultView'});
          createState(pfad0 + 'Auto_Switch_View',  {def: 'false',type: 'boolean',name: 'Alle Views durchlaufen lassen'});
          createState(pfad0 + 'ScreenSaverActive',  {def: 'false',type: 'boolean',name: 'Bildschirmschoner'});
           
           
          if(logging)log("Total "+Object.keys(VisViews).length+" entries");
           
          // $$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$
          // $$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$
          // $$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$
          // $$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$
           
          // #############################################################################
          // #                                                                           #
          // #  Funktion zum automatischen Viewwechsel nach Timerablauf                  #
          // #                                                                           #
          // #############################################################################
           
          function switchToHomeView() {
                  timerTout = setTimeout(function () {
                      var timer = parseInt(getState(pfad0 + 'Timer_View_Switch').val, 10);
                      if (timer > 1) {
                          setState(pfad0 + 'Timer_View_Switch',timer - 1);
                          switchToHomeView();
                      }
                      else{
                          setState(pfad0 + 'Timer_View_Switch', 0);
                          setState('vis.0.control.instance', 'FFFFFFFF'); //getState("vis.0.control.instance").val/*Control vis*/);
                          setState('vis.0.control.data', project + DefaultView);
                          setState('vis.0.control.command', 'changeView');
                      }
                  }, 1000);
          }
           
          // #############################################################################
          // #                                                                           #
          // #  Funktion zum automatisch umlaufenden Viewwechsel                         #
          // #                                                                           #
          // #############################################################################
           
          function autoSwitchView(dspTime,i) {
                  if(i === '') i = 0;
                  if(logging) log(i);
                  if(i < Object.keys(VisViews).length){
                      if(VisViews[i].ShowIAV == 'yes'){
                          timerAutoSV = setTimeout(function () {
                              var timer = parseInt(getState(pfad0 + 'Timer_View_Switch').val, 10);
                              if (timer > 1) {
                                  setState(pfad0 + 'Timer_View_Switch', timer - 1);
                                  autoSwitchView(dspTime, i);
                              }
                              else{
                                      setState(pfad0 + 'Timer_View_Switch', 0);
                                      if(getState(pfad0 + 'Auto_Switch_View').val === true) switchView(project+VisViews[i].view);
                                      startAutoSwitchView(dspTime,(i+1));
                              }
                          }, 1000);
                      }
                      else{
                          startAutoSwitchView(dspTime,(i+1));
                      }
                  }
                  else{
                     startAutoSwitchView(dspTime,startView); 
                  }
          }
           
          // #############################################################################
          // #                                                                           #
          // #  Funktion zum Starten und Stoppen des automatischen Viewwechsel           #
          // #                                                                           #
          // #############################################################################
          function startAutoSwitchView(dspTime,i){
              if(getState(pfad0 + 'Auto_Switch_View').val === true){
                  if(dspTime !== ''){
                      setState(pfad0 + 'Timer_View_Switch',parseInt(dspTime, 10));
                  }
                  else{
                      setState(pfad0 + 'Timer_View_Switch',15);
                  }
                  autoSwitchView(dspTime,i);
              } 
              else{
                  if(timerTout) clearTimeout(timerTout);
                  switchView(project + DefaultView);
                  setStateDelayed(pfad0 + 'Timer_View_Switch',0,2000);
              }
          }
          //
          // Beobachten des View Datenpunktes
          on({id:"javascript.0.System.Iobroker.Auto_Switch_View", change: "ne"}, function (dp) {
          //    if(dp.state.val === true){
                  startAutoSwitchView(DisplayTime,startView);
          //    }
          });
           
          // #############################################################################
          // #                                                                           #
          // #  Funktion zum Scriptbasierten Viewwechsel                                 #
          // #                                                                           #
          // #############################################################################
           
          function switchView(view){
              setState('vis.0.control.instance', 'FFFFFFFF');
              setState('vis.0.control.data', view);
              setState('vis.0.control.command', 'changeView');
          }
           
          // #############################################################################
          // #                                                                           #
          // #  Funktion zum Prüfen der Wunsch View und zum auslesen der Darstellzeit    #
          // #                                                                           #
          // #############################################################################
           
          function checkView(wishView){
              if(logging) log('View to check:'+wishView);
              if(getState(pfad0 + 'Auto_Switch_View').val === false ){
                  for(var i = 0; i < Object.keys(VisViews).length; i++) {  
                      if(project+VisViews[i].view == wishView) {
                          if(logging) log('View found in:' + i);
                          if(timerTout) clearTimeout(timerTout);
                          setState(pfad0 + 'Timer_View_Switch', 0);
                          if(VisViews[i].SWSec !== 0){
                              setState(pfad0 + 'Timer_View_Switch', VisViews[i].SWSec);
                              switchToHomeView();
                          }
                      }
                  }
              }
          }
          // #############################################################################
          // #                                                                           #
          // #  Zusatzfunktion um ZusatzDatenpunke zu steuern                            #
          // #                                                                           #
          // #############################################################################
          function additionalActions(dp){
              if(dp == "Wandtablet/System"){
                  setState(pfad0 + "Letzte_System_Meldungen_prio", '');
              }
              if(dp == "Wandtablet/Kamera_Bilder_Haustuere"){
                  setState(pfad0 + "Tuerklingel_in_Abwesenheit", false);
              }
          }
          // #############################################################################
          // #                                                                           #
          // #  ScreenSaver Funktion zum Durchschalten der Views als Bildschirmschoner   #
          // #                                                                           #
          // #############################################################################
          function screenSaver(){
              svTimer = setTimeout(function() {
                  if(getState(pfad0 + 'ScreenSaverActive').val === true){
                      if((new Date().getTime() - getState('vis.0.control.data').lc)/60000 > screenSv_time){
                          setState(pfad0 + 'Auto_Switch_View', true);
                      }
                      else{
                          setState(pfad0 + 'Auto_Switch_View', false);
                      }  
                      screenSaver();  
                  }
              }, 60000);
              
          }
           
          // Beobachten des Datenpunktes Screensaver um die Autoview einzuschalten
          on({id:'javascript.0.System.Iobroker.ScreenSaverActive'/*Bildschirmschoner*/, change: "ne"}, function (dp) {
              if(dp.state.val === true){
                  screenSaver();
                  if(logging) log('Screensaver On');
              }
              else{
                  if(svTimer) clearTimeout(svTimer);
                  setState(pfad0 + 'Auto_Switch_View', false);
                  switchView(project + DefaultView);
              } 
          });
           
           
          // Beobachten des View Datenpunktes für Auswertung
          on({id:"vis.0.control.data", change: "ne"}, function (dp) {
              checkView(dp.state.val);
                  // Zusatzfunktion um den Datenpunkt zurück zu setzten
              additionalActions(dp.state.val);
          });
           
           
           
          //Bei aktiver Alarmanlage auf Pin-View umschalten
          on({id: "javascript.0.Alarmanlage.Status.Status"/*Status für Scharfmeldung*/, change: 'any'}, function (dp) {
              if(dp.state.val == 2 || dp.state.val == '2'){
                  switchView('Alarmanlage_code');
              }
              else{
                  switchView(DefaultView);
              }
          });
           
          //Bei Bewegung auf Kamerabild umschalten
          on({id:"hm-rpc.0.XXXXXXXXXX.1.MOTION"/*Bewegungsmelder.Aussen.Haustuere.XXXXXXXXX:1.MOTION*/, change: 'any'}, function (dp) {
              if(dp.state.val === true ){
                   if(getState("javascript.0.Alarmanlage.Status.Status").val != 2 || getState("javascript.0.Alarmanlage.Status.Status").val != '2'){
                     switchView('Kamera_Garage');
                   }
                   else{
                      switchView('Alarmanlage_code');
                   }
              }
          });
           
           
          
          
          PeoplesP Offline
          PeoplesP Offline
          Peoples
          wrote on last edited by
          #104

          @Bostil sagte in [Vorlage] Automatischer View-Wechsel u. Slideshow:

          @Peoples Danke dir! Das war auf jedenfall eines der Probleme! Danke danke 🙂

          Jetzt bleibt nur noch folgende Fehlermeldung, wenn ich über den Schalte den Screensaver aktiviere:
          22:01:25.846 error javascript.0 (1210) at Object.<anonymous> (script.js.common.Viewwechsel:235:9)

          Wenn du das Script zweimal startest ist es immernoch so? Bei mir kommt der Fehler nur beim ersten mal starten

          Ich beantworte keine Fragen zu Themen via PN

          1 Reply Last reply
          0
          • BostilB Bostil

            @dos1973 Hi @dos1973 mache ich gerne, sobald das Teil mal einen etwas kompletteren Status erreicht hat. Meine VIS ist sehr an die folgende VIS angelehnt, die ich eins hier und bei Youtube gefunden hatte: https://www.youtube.com/watch?v=znWigptw0GE

            D Offline
            D Offline
            dos1973
            wrote on last edited by
            #105

            @Bostil

            Mich interessiert primär der „Glow“effekt unter den kleinen Kacheln.
            Das ist wahrscheinlich shadow/ inset aber ich bekomme es einfach nicht so hin, bei Dir siehst echt gut aus. Wenn du dass css reinstellen könntest wäre mir bereits sehr geholfen... thx

            BostilB ChaotC 2 Replies Last reply
            0
            • D dos1973

              @Bostil

              Mich interessiert primär der „Glow“effekt unter den kleinen Kacheln.
              Das ist wahrscheinlich shadow/ inset aber ich bekomme es einfach nicht so hin, bei Dir siehst echt gut aus. Wenn du dass css reinstellen könntest wäre mir bereits sehr geholfen... thx

              BostilB Offline
              BostilB Offline
              Bostil
              wrote on last edited by
              #106

              @dos1973 Hi, ich fühle mich in PowerPoint mehr zuhause als in CSS, daher ist alles, was du in meiner Vis als Hintergrund siehst in Power Point ziemlich einfach & schnell "designed" worden und als "img" eingefügt.

              1 Reply Last reply
              0
              • D dos1973

                @Bostil

                Mich interessiert primär der „Glow“effekt unter den kleinen Kacheln.
                Das ist wahrscheinlich shadow/ inset aber ich bekomme es einfach nicht so hin, bei Dir siehst echt gut aus. Wenn du dass css reinstellen könntest wäre mir bereits sehr geholfen... thx

                ChaotC Offline
                ChaotC Offline
                Chaot
                wrote on last edited by
                #107

                @dos1973 Meinst du sowas:
                Glow.png
                Ist Box-shadow

                ioBroker auf NUC unter Proxmox; VIS: 12" Touchscreen und 17" Touch; Lichtsteuerung, Thermometer und Sensoren: Tasmota (39); Ambiente Beleuchtung: WLED (9); Heizung: DECT Thermostate (9) an Fritz 6690; EMS-ESP; 1 Echo V2; 3 Echo DOT; 1 Echo Connect; 2 Echo Show 5; Unifi Ap-Ac Lite.

                1 Reply Last reply
                0
                • PeoplesP Offline
                  PeoplesP Offline
                  Peoples
                  wrote on last edited by
                  #108

                  Ich will keine Spaßbremse sein, aber ihr kommt leicht Thread-Thema ab 🤣

                  Ich beantworte keine Fragen zu Themen via PN

                  D 1 Reply Last reply
                  0
                  • PeoplesP Peoples

                    Ich will keine Spaßbremse sein, aber ihr kommt leicht Thread-Thema ab 🤣

                    D Offline
                    D Offline
                    dos1973
                    wrote on last edited by
                    #109

                    @Peoples
                    Hast recht... sorry

                    1 Reply Last reply
                    0
                    • BoronsbruderB Online
                      BoronsbruderB Online
                      Boronsbruder
                      wrote on last edited by Boronsbruder
                      #110

                      @Peoples

                      Ist es eigentlich Absicht, dass in deinem "Beobachten-Abschnitt" die ID's fix eingetragen sind?

                      // Beobachten des Datenpunktes Screensaver um die Autoview einzuschalten
                      
                      on({id:'javascript.0.System.Iobroker.ScreenSaverActive'/*Bildschirmschoner*/, change: "ne"}, function (dp) {
                      

                      und

                      // Beobachten des View Datenpunktes
                      
                      on({id:"javascript.0.System.Iobroker.Auto_Switch_View", change: "ne"}, function (dp) {
                      
                      //    if(dp.state.val === true){
                      
                              startAutoSwitchView(DisplayTime,startView);
                      
                      //    }
                      

                      Sollte da nicht besser

                      on({id:'javascript.0.' + pfad0 + 'ScreenSaverActive'/*Bildschirmschoner*/, change: "ne"}
                      

                      und

                      on({id:"javascript.0." + pfad0 +"Auto_Switch_View", change: "ne"}
                      

                      stehen?

                      PeoplesP 1 Reply Last reply
                      0
                      • BoronsbruderB Boronsbruder

                        @Peoples

                        Ist es eigentlich Absicht, dass in deinem "Beobachten-Abschnitt" die ID's fix eingetragen sind?

                        // Beobachten des Datenpunktes Screensaver um die Autoview einzuschalten
                        
                        on({id:'javascript.0.System.Iobroker.ScreenSaverActive'/*Bildschirmschoner*/, change: "ne"}, function (dp) {
                        

                        und

                        // Beobachten des View Datenpunktes
                        
                        on({id:"javascript.0.System.Iobroker.Auto_Switch_View", change: "ne"}, function (dp) {
                        
                        //    if(dp.state.val === true){
                        
                                startAutoSwitchView(DisplayTime,startView);
                        
                        //    }
                        

                        Sollte da nicht besser

                        on({id:'javascript.0.' + pfad0 + 'ScreenSaverActive'/*Bildschirmschoner*/, change: "ne"}
                        

                        und

                        on({id:"javascript.0." + pfad0 +"Auto_Switch_View", change: "ne"}
                        

                        stehen?

                        PeoplesP Offline
                        PeoplesP Offline
                        Peoples
                        wrote on last edited by
                        #111

                        @Boronsbruder

                        Da hast du Recht!

                        Ich beantworte keine Fragen zu Themen via PN

                        1 Reply Last reply
                        0
                        • A Andre R.

                          es läuft jetzt durch

                          hab Auto Switch View von true auf false gestellt und wieder zurück jetzt läufts. Es laufen jetzt aber leider alle Views durch auch die auf no stehen.

                          BoronsbruderB Online
                          BoronsbruderB Online
                          Boronsbruder
                          wrote on last edited by
                          #112

                          @Andre-R said in [Vorlage] Automatischer View-Wechsel u. Slideshow:

                          es läuft jetzt durch

                          hab Auto Switch View von true auf false gestellt und wieder zurück jetzt läufts. Es laufen jetzt aber leider alle Views durch auch die auf no stehen.

                          Ich habe auch bei der ersten Inbetriebnahme das Problem gehabt, dass das Skript nicht den Timer startete.

                          Beim Anklicken im Admin ist mir aufgefallen, dass "false" angezeigt wurde, aber das Kästchen angehakt war!
                          Nach dem Hin/Her-Schalten lief das Skript dann...

                          Das könnte an der createState liegen oder? (dass er 'false' als String interpretiert?)

                          Statt

                          createState(pfad0 + 'Auto_Switch_View',  {def: 'false',type: 'boolean',name: 'Alle Views durchlaufen lassen'});
                          

                          besser ( benutze ich gerade)

                          createState(pfad0 + 'Auto_Switch_View',  false , {type: 'boolean',name: 'Alle Views durchlaufen lassen'});
                          

                          Quelle GITHUB

                          oder vielleicht

                          createState(pfad0 + 'Auto_Switch_View',  {def: false,type: 'boolean',name: 'Alle Views durchlaufen lassen'});
                          
                          1 Reply Last reply
                          0
                          • PeoplesP Offline
                            PeoplesP Offline
                            Peoples
                            wrote on last edited by Peoples
                            #113

                            Hatte da nie Probleme, das create State von 2 zu 3 macht in meinen Augen technisch keinen Unterschied.
                            Bei eins könntest du Recht haben war bei mir aber auch egal und funktionierte.
                            Die fehlende Initialisierung des timers beim ersten Lauf könnte ein Problem sein.
                            Ich wollte eh das ganze Script für mehrere Endgeräte umschreiben, bin aber bisher nicht dazu gekommen.

                            Ich beantworte keine Fragen zu Themen via PN

                            1 Reply Last reply
                            0
                            • PeoplesP Peoples

                              @Solider sagte in [[Vorlage] Automatischer View-Wechsel u. Slideshow](/post

                              Ich möchte also nur, dass er nach Zeit X zu Homeview zurückkehrt.

                              Du musst eigentlich nur hier:

                              var DefaultView = 'Home';                                   // Standard-View
                              var project = "Wandtablet";
                              

                              deine Homeview und den Namen deines Vis-Projekts und hier:

                                     /* View Name */                  /* Anzeigezeit */   /* In Slideshow anzeigen? */
                              
                                  {'view':'Alarmanlage_code',             'SWSec':180,            'ShowIAV':'no'},
                                  {'view':'Backup_Konfiguration',         'SWSec':180,            'ShowIAV':'no'},
                              

                              View ist der Name der View(s) bei denen der "Auto zurück Wechsel" funktionieren soll.
                              SWSec ist die Zeit nach der zurück gewechselt wird
                              ShowIAV wäre für den Screensaver und in deinem Fall nicht nötig

                              S Offline
                              S Offline
                              Solider
                              wrote on last edited by
                              #114

                              @Peoples

                              Dann hatte ich ja alles richtig.

                              Ich habs mittlerweile.. Man sollte auch den state "ScreenSaver_Active" auf "true" setzen... 😄
                              Da kann ich mich ja lange wundern, warum nix passiert 😄
                              Danke 🙂

                              PeoplesP 1 Reply Last reply
                              0
                              • S Solider

                                @Peoples

                                Dann hatte ich ja alles richtig.

                                Ich habs mittlerweile.. Man sollte auch den state "ScreenSaver_Active" auf "true" setzen... 😄
                                Da kann ich mich ja lange wundern, warum nix passiert 😄
                                Danke 🙂

                                PeoplesP Offline
                                PeoplesP Offline
                                Peoples
                                wrote on last edited by
                                #115

                                @Solider
                                Das ist eine hervorragende Idee 🤣

                                Ich beantworte keine Fragen zu Themen via PN

                                1 Reply Last reply
                                1
                                • BostilB Offline
                                  BostilB Offline
                                  Bostil
                                  wrote on last edited by Bostil
                                  #116

                                  Habe nun die Vorschläge von Borons auch mal übernommen, aber "ScreenSaverActive" ist auf true, aber in den anderen Datenpunkten passiert nichts und auch der Bildschirmschoner hat noch keine Lust loszulegen.

                                  • muss man hierfür auf einem bestimmten View sein, damit dieser nach 1 Minute (wie in meinem Code) aktiviert wird @Peoples ?
                                  //
                                  // Seitenwechsel-Script
                                  // Autor: Peoples
                                  //
                                  //
                                  // Funktionen:  1. Bei Viewwechsel wird geprüft ob eine andere View als Home gewählt ist
                                  //                 wenn das der Fall ist wird ein Timer gesetzt nach dessen Ablauf wieder zurück
                                  //                 auf Home gewechselt wird.
                                  //              2. Wenn die Alarmanlage eingeschalten ist wird die PinEingabeView angezeigt.
                                  //              3. Bei SystemView läuft kein Timer
                                  //
                                  //
                                  // v2.0.0 - 30.09.2018  Neue Version - Grundaufbau geändert
                                  // v2.0.1 - 09.03.2019  Slideshow aller gewünschen Views integriert
                                  // v2.0.2 - 23.03.2019  Zusatzfunktion zum steuern der Sonderdatenpunkte eingebaut
                                  // v2.0.3 - 28.03.2019  Zahlenwerte durch parseInt konvertiert
                                  // v2.0.4 - 21.05.2019  Fehlerkorrekturen
                                  // v2.0.5 - 14.09.2019  AutoViewWechsel als Screensaver möglich
                                  // *******************************************************************************************************
                                   
                                  // -----------------------------------------------------------------------------
                                  // allgemeine Variablen
                                  // -----------------------------------------------------------------------------
                                  var logging = false;                                        // Logging on/off
                                  var instanz = 'javascript.0';   instanz = instanz + '.';    // 
                                                                                              //
                                  var pfad0 =   'System.Iobroker';      pfad0 = pfad0 + '.';  // Pfad innerhalb der Instanz 
                                  var timerTout;
                                  var timerAutoSV;
                                  var DefaultView = 'Main';                                   // Standard-View
                                   
                                  // Aus Datenpunkt vis.0.control.data entnehmen 
                                  // der Teil vor dem Slash ist der Projektname:
                                  // "Wandtablet/Home"
                                  var project = "Vision";     project = project + '/';    // Name des Vis-Projekts
                                   
                                  var DisplayTime = '480';                                     // Darstellungszeit der Views bei Autowechsel
                                  var startView = 1;                                          // Startview bei Autowechsel
                                  var screenSv_time = 1;                                     // Zeit nach der der ScreenSaver Seitenwechsel angeht in Minuten
                                   
                                  //Alle vorhandenen Views
                                  var VisViews = [
                                      
                                          /* View Name */                  /* Anzeigezeit */   /* In Slideshow anzeigen? */
                                   
                                      {'view':'Screensaver1',             'SWSec':180,            'ShowIAV':'yes'},
                                      {'view':'Screensaver2',         'SWSec':180,            'ShowIAV':'yes'},
                                      {'view':'Screensaver3',                     'SWSec':180,            'ShowIAV':'yes'},
                                      {'view':'Screensaver4',                      'SWSec':180,            'ShowIAV':'yes'},
                                      {'view':'Screensaver5',                     'SWSec':180,            'ShowIAV':'yes'},
                                      {'view':'Screensaver6',                       'SWSec':180,             'ShowIAV':'yes'},
                                      {'view':'Screensaver7',            'SWSec':180,             'ShowIAV':'yes'},
                                      {'view':'Screensaver8',                   'SWSec':180,            'ShowIAV':'yes'},
                                      {'view':'Screensaver9',                   'SWSec':180,            'ShowIAV':'yes'},
                                      {'view':'Screensaver10',       'SWSec':180,             'ShowIAV':'yes'},
                                      {'view':'Main',                         'SWSec':180,              'ShowIAV':'yes'},
                                      {'view':'Screensaver11',                      'SWSec':180,             'ShowIAV':'yes'},
                                      {'view':'Screensaver12',                'SWSec':180,             'ShowIAV':'yes'},
                                  
                                  ];
                                  // -----------------------------------------------------------------------------
                                  // Objekte
                                  // -----------------------------------------------------------------------------
                                  // Objekt für Alle Automatischen Abläufe
                                  createState(pfad0 + 'Timer_View_Switch',  {def: '0',type: 'number',name: 'Timer für Wechsel auf DefaultView'});
                                  createState(pfad0 + 'Auto_Switch_View',  {def: 'false',type: 'boolean',name: 'Alle Views durchlaufen lassen'});
                                  createState(pfad0 + 'ScreenSaverActive',  {def: 'false',type: 'boolean',name: 'Bildschirmschoner'});
                                   
                                   
                                  if(logging)log("Total "+Object.keys(VisViews).length+" entries");
                                   
                                  // $$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$
                                  // $$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$
                                  // $$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$
                                  // $$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$
                                   
                                  // #############################################################################
                                  // #                                                                           #
                                  // #  Funktion zum automatischen Viewwechsel nach Timerablauf                  #
                                  // #                                                                           #
                                  // #############################################################################
                                   
                                  function switchToHomeView() {
                                          timerTout = setTimeout(function () {
                                              var timer = parseInt(getState(pfad0 + 'Timer_View_Switch').val, 10);
                                              if (timer > 1) {
                                                  setState(pfad0 + 'Timer_View_Switch',timer - 1);
                                                  switchToHomeView();
                                              }
                                              else{
                                                  setState(pfad0 + 'Timer_View_Switch', 0);
                                                  setState('vis.0.control.instance', 'FFFFFFFF'); //getState("vis.0.control.instance").val/*Control vis*/);
                                                  setState('vis.0.control.data', project + DefaultView);
                                                  setState('vis.0.control.command', 'changeView');
                                              }
                                          }, 1000);
                                  }
                                   
                                  // #############################################################################
                                  // #                                                                           #
                                  // #  Funktion zum automatisch umlaufenden Viewwechsel                         #
                                  // #                                                                           #
                                  // #############################################################################
                                   
                                  function autoSwitchView(dspTime,i) {
                                          if(i === '') i = 0;
                                          if(logging) log(i);
                                          if(i < Object.keys(VisViews).length){
                                              if(VisViews[i].ShowIAV == 'yes'){
                                                  timerAutoSV = setTimeout(function () {
                                                      var timer = parseInt(getState(pfad0 + 'Timer_View_Switch').val, 10);
                                                      if (timer > 1) {
                                                          setState(pfad0 + 'Timer_View_Switch', timer - 1);
                                                          autoSwitchView(dspTime, i);
                                                      }
                                                      else{
                                                              setState(pfad0 + 'Timer_View_Switch', 0);
                                                              if(getState(pfad0 + 'Auto_Switch_View').val === true) switchView(project+VisViews[i].view);
                                                              startAutoSwitchView(dspTime,(i+1));
                                                      }
                                                  }, 1000);
                                              }
                                              else{
                                                  startAutoSwitchView(dspTime,(i+1));
                                              }
                                          }
                                          else{
                                             startAutoSwitchView(dspTime,startView); 
                                          }
                                  }
                                   
                                  // #############################################################################
                                  // #                                                                           #
                                  // #  Funktion zum Starten und Stoppen des automatischen Viewwechsel           #
                                  // #                                                                           #
                                  // #############################################################################
                                  function startAutoSwitchView(dspTime,i){
                                      if(getState(pfad0 + 'Auto_Switch_View').val === true){
                                          if(dspTime !== ''){
                                              setState(pfad0 + 'Timer_View_Switch',parseInt(dspTime, 10));
                                          }
                                          else{
                                              setState(pfad0 + 'Timer_View_Switch',15);
                                          }
                                          autoSwitchView(dspTime,i);
                                      } 
                                      else{
                                          if(timerTout) clearTimeout(timerTout);
                                          switchView(project + DefaultView);
                                          setStateDelayed(pfad0 + 'Timer_View_Switch',0,2000);
                                      }
                                  }
                                  //
                                  // Beobachten des View Datenpunktes
                                  on({id:"javascript.0.System.Iobroker.Auto_Switch_View", change: "ne"}, function (dp) {
                                   
                                  //    if(dp.state.val === true){
                                   
                                          startAutoSwitchView(DisplayTime,startView);
                                   
                                  //    }
                                  });
                                   
                                  // #############################################################################
                                  // #                                                                           #
                                  // #  Funktion zum Scriptbasierten Viewwechsel                                 #
                                  // #                                                                           #
                                  // #############################################################################
                                   
                                  function switchView(view){
                                      setState('vis.0.control.instance', 'FFFFFFFF');
                                      setState('vis.0.control.data', view);
                                      setState('vis.0.control.command', 'changeView');
                                  }
                                   
                                  // #############################################################################
                                  // #                                                                           #
                                  // #  Funktion zum Prüfen der Wunsch View und zum auslesen der Darstellzeit    #
                                  // #                                                                           #
                                  // #############################################################################
                                   
                                  function checkView(wishView){
                                      if(logging) log('View to check:'+wishView);
                                      if(getState(pfad0 + 'Auto_Switch_View').val === false ){
                                          for(var i = 0; i < Object.keys(VisViews).length; i++) {  
                                              if(project+VisViews[i].view == wishView) {
                                                  if(logging) log('View found in:' + i);
                                                  if(timerTout) clearTimeout(timerTout);
                                                  setState(pfad0 + 'Timer_View_Switch', 0);
                                                  if(VisViews[i].SWSec !== 0){
                                                      setState(pfad0 + 'Timer_View_Switch', VisViews[i].SWSec);
                                                      switchToHomeView();
                                                  }
                                              }
                                          }
                                      }
                                  }
                                  // #############################################################################
                                  // #                                                                           #
                                  // #  Zusatzfunktion um ZusatzDatenpunke zu steuern                            #
                                  // #                                                                           #
                                  // #############################################################################
                                  function additionalActions(dp){
                                      if(dp == "Wandtablet/System"){
                                          setState(pfad0 + "Letzte_System_Meldungen_prio", '');
                                      }
                                      if(dp == "Wandtablet/Kamera_Bilder_Haustuere"){
                                          setState(pfad0 + "Tuerklingel_in_Abwesenheit", false);
                                      }
                                  }
                                  // #############################################################################
                                  // #                                                                           #
                                  // #  ScreenSaver Funktion zum Durchschalten der Views als Bildschirmschoner   #
                                  // #                                                                           #
                                  // #############################################################################
                                  function screenSaver(){
                                      svTimer = setTimeout(function() {
                                          if(getState(pfad0 + 'ScreenSaverActive').val === true){
                                              if((new Date().getTime() - getState('vis.0.control.data').lc)/60000 > screenSv_time){
                                                  setState(pfad0 + 'Auto_Switch_View', true);
                                              }
                                              else{
                                                  setState(pfad0 + 'Auto_Switch_View', false);
                                              }  
                                              screenSaver();  
                                          }
                                      }, 60000);
                                      
                                  }
                                   
                                  // Beobachten des Datenpunktes Screensaver um die Autoview einzuschalten
                                  on({id:'javascript.0.System.Iobroker.ScreenSaverActive'/*Bildschirmschoner*/, change: "ne"}, function (dp) {
                                      if(dp.state.val === true){
                                          screenSaver();
                                          if(logging) log('Screensaver On');
                                      }
                                      else{
                                          if(svTimer) clearTimeout(svTimer);
                                          setState(pfad0 + 'Auto_Switch_View', false);
                                          switchView(project + DefaultView);
                                      } 
                                  });
                                   
                                   
                                  // Beobachten des View Datenpunktes für Auswertung
                                  on({id:"vis.0.control.data", change: "ne"}, function (dp) {
                                      checkView(dp.state.val);
                                          // Zusatzfunktion um den Datenpunkt zurück zu setzten
                                      additionalActions(dp.state.val);
                                  });
                                   
                                   
                                   
                                  //Bei aktiver Alarmanlage auf Pin-View umschalten
                                  on({id: "javascript.0.Alarmanlage.Status.Status"/*Status für Scharfmeldung*/, change: 'any'}, function (dp) {
                                      if(dp.state.val == 2 || dp.state.val == '2'){
                                          switchView('Alarmanlage_code');
                                      }
                                      else{
                                          switchView(DefaultView);
                                      }
                                  });
                                   
                                  //Bei Bewegung auf Kamerabild umschalten
                                  on({id:"hm-rpc.0.XXXXXXXXXX.1.MOTION"/*Bewegungsmelder.Aussen.Haustuere.XXXXXXXXX:1.MOTION*/, change: 'any'}, function (dp) {
                                      if(dp.state.val === true ){
                                           if(getState("javascript.0.Alarmanlage.Status.Status").val != 2 || getState("javascript.0.Alarmanlage.Status.Status").val != '2'){
                                             switchView('Kamera_Garage');
                                           }
                                           else{
                                              switchView('Alarmanlage_code');
                                           }
                                      }
                                  });
                                   
                                   
                                  
                                  
                                  PeoplesP 1 Reply Last reply
                                  0
                                  • BostilB Bostil

                                    Habe nun die Vorschläge von Borons auch mal übernommen, aber "ScreenSaverActive" ist auf true, aber in den anderen Datenpunkten passiert nichts und auch der Bildschirmschoner hat noch keine Lust loszulegen.

                                    • muss man hierfür auf einem bestimmten View sein, damit dieser nach 1 Minute (wie in meinem Code) aktiviert wird @Peoples ?
                                    //
                                    // Seitenwechsel-Script
                                    // Autor: Peoples
                                    //
                                    //
                                    // Funktionen:  1. Bei Viewwechsel wird geprüft ob eine andere View als Home gewählt ist
                                    //                 wenn das der Fall ist wird ein Timer gesetzt nach dessen Ablauf wieder zurück
                                    //                 auf Home gewechselt wird.
                                    //              2. Wenn die Alarmanlage eingeschalten ist wird die PinEingabeView angezeigt.
                                    //              3. Bei SystemView läuft kein Timer
                                    //
                                    //
                                    // v2.0.0 - 30.09.2018  Neue Version - Grundaufbau geändert
                                    // v2.0.1 - 09.03.2019  Slideshow aller gewünschen Views integriert
                                    // v2.0.2 - 23.03.2019  Zusatzfunktion zum steuern der Sonderdatenpunkte eingebaut
                                    // v2.0.3 - 28.03.2019  Zahlenwerte durch parseInt konvertiert
                                    // v2.0.4 - 21.05.2019  Fehlerkorrekturen
                                    // v2.0.5 - 14.09.2019  AutoViewWechsel als Screensaver möglich
                                    // *******************************************************************************************************
                                     
                                    // -----------------------------------------------------------------------------
                                    // allgemeine Variablen
                                    // -----------------------------------------------------------------------------
                                    var logging = false;                                        // Logging on/off
                                    var instanz = 'javascript.0';   instanz = instanz + '.';    // 
                                                                                                //
                                    var pfad0 =   'System.Iobroker';      pfad0 = pfad0 + '.';  // Pfad innerhalb der Instanz 
                                    var timerTout;
                                    var timerAutoSV;
                                    var DefaultView = 'Main';                                   // Standard-View
                                     
                                    // Aus Datenpunkt vis.0.control.data entnehmen 
                                    // der Teil vor dem Slash ist der Projektname:
                                    // "Wandtablet/Home"
                                    var project = "Vision";     project = project + '/';    // Name des Vis-Projekts
                                     
                                    var DisplayTime = '480';                                     // Darstellungszeit der Views bei Autowechsel
                                    var startView = 1;                                          // Startview bei Autowechsel
                                    var screenSv_time = 1;                                     // Zeit nach der der ScreenSaver Seitenwechsel angeht in Minuten
                                     
                                    //Alle vorhandenen Views
                                    var VisViews = [
                                        
                                            /* View Name */                  /* Anzeigezeit */   /* In Slideshow anzeigen? */
                                     
                                        {'view':'Screensaver1',             'SWSec':180,            'ShowIAV':'yes'},
                                        {'view':'Screensaver2',         'SWSec':180,            'ShowIAV':'yes'},
                                        {'view':'Screensaver3',                     'SWSec':180,            'ShowIAV':'yes'},
                                        {'view':'Screensaver4',                      'SWSec':180,            'ShowIAV':'yes'},
                                        {'view':'Screensaver5',                     'SWSec':180,            'ShowIAV':'yes'},
                                        {'view':'Screensaver6',                       'SWSec':180,             'ShowIAV':'yes'},
                                        {'view':'Screensaver7',            'SWSec':180,             'ShowIAV':'yes'},
                                        {'view':'Screensaver8',                   'SWSec':180,            'ShowIAV':'yes'},
                                        {'view':'Screensaver9',                   'SWSec':180,            'ShowIAV':'yes'},
                                        {'view':'Screensaver10',       'SWSec':180,             'ShowIAV':'yes'},
                                        {'view':'Main',                         'SWSec':180,              'ShowIAV':'yes'},
                                        {'view':'Screensaver11',                      'SWSec':180,             'ShowIAV':'yes'},
                                        {'view':'Screensaver12',                'SWSec':180,             'ShowIAV':'yes'},
                                    
                                    ];
                                    // -----------------------------------------------------------------------------
                                    // Objekte
                                    // -----------------------------------------------------------------------------
                                    // Objekt für Alle Automatischen Abläufe
                                    createState(pfad0 + 'Timer_View_Switch',  {def: '0',type: 'number',name: 'Timer für Wechsel auf DefaultView'});
                                    createState(pfad0 + 'Auto_Switch_View',  {def: 'false',type: 'boolean',name: 'Alle Views durchlaufen lassen'});
                                    createState(pfad0 + 'ScreenSaverActive',  {def: 'false',type: 'boolean',name: 'Bildschirmschoner'});
                                     
                                     
                                    if(logging)log("Total "+Object.keys(VisViews).length+" entries");
                                     
                                    // $$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$
                                    // $$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$
                                    // $$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$
                                    // $$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$
                                     
                                    // #############################################################################
                                    // #                                                                           #
                                    // #  Funktion zum automatischen Viewwechsel nach Timerablauf                  #
                                    // #                                                                           #
                                    // #############################################################################
                                     
                                    function switchToHomeView() {
                                            timerTout = setTimeout(function () {
                                                var timer = parseInt(getState(pfad0 + 'Timer_View_Switch').val, 10);
                                                if (timer > 1) {
                                                    setState(pfad0 + 'Timer_View_Switch',timer - 1);
                                                    switchToHomeView();
                                                }
                                                else{
                                                    setState(pfad0 + 'Timer_View_Switch', 0);
                                                    setState('vis.0.control.instance', 'FFFFFFFF'); //getState("vis.0.control.instance").val/*Control vis*/);
                                                    setState('vis.0.control.data', project + DefaultView);
                                                    setState('vis.0.control.command', 'changeView');
                                                }
                                            }, 1000);
                                    }
                                     
                                    // #############################################################################
                                    // #                                                                           #
                                    // #  Funktion zum automatisch umlaufenden Viewwechsel                         #
                                    // #                                                                           #
                                    // #############################################################################
                                     
                                    function autoSwitchView(dspTime,i) {
                                            if(i === '') i = 0;
                                            if(logging) log(i);
                                            if(i < Object.keys(VisViews).length){
                                                if(VisViews[i].ShowIAV == 'yes'){
                                                    timerAutoSV = setTimeout(function () {
                                                        var timer = parseInt(getState(pfad0 + 'Timer_View_Switch').val, 10);
                                                        if (timer > 1) {
                                                            setState(pfad0 + 'Timer_View_Switch', timer - 1);
                                                            autoSwitchView(dspTime, i);
                                                        }
                                                        else{
                                                                setState(pfad0 + 'Timer_View_Switch', 0);
                                                                if(getState(pfad0 + 'Auto_Switch_View').val === true) switchView(project+VisViews[i].view);
                                                                startAutoSwitchView(dspTime,(i+1));
                                                        }
                                                    }, 1000);
                                                }
                                                else{
                                                    startAutoSwitchView(dspTime,(i+1));
                                                }
                                            }
                                            else{
                                               startAutoSwitchView(dspTime,startView); 
                                            }
                                    }
                                     
                                    // #############################################################################
                                    // #                                                                           #
                                    // #  Funktion zum Starten und Stoppen des automatischen Viewwechsel           #
                                    // #                                                                           #
                                    // #############################################################################
                                    function startAutoSwitchView(dspTime,i){
                                        if(getState(pfad0 + 'Auto_Switch_View').val === true){
                                            if(dspTime !== ''){
                                                setState(pfad0 + 'Timer_View_Switch',parseInt(dspTime, 10));
                                            }
                                            else{
                                                setState(pfad0 + 'Timer_View_Switch',15);
                                            }
                                            autoSwitchView(dspTime,i);
                                        } 
                                        else{
                                            if(timerTout) clearTimeout(timerTout);
                                            switchView(project + DefaultView);
                                            setStateDelayed(pfad0 + 'Timer_View_Switch',0,2000);
                                        }
                                    }
                                    //
                                    // Beobachten des View Datenpunktes
                                    on({id:"javascript.0.System.Iobroker.Auto_Switch_View", change: "ne"}, function (dp) {
                                     
                                    //    if(dp.state.val === true){
                                     
                                            startAutoSwitchView(DisplayTime,startView);
                                     
                                    //    }
                                    });
                                     
                                    // #############################################################################
                                    // #                                                                           #
                                    // #  Funktion zum Scriptbasierten Viewwechsel                                 #
                                    // #                                                                           #
                                    // #############################################################################
                                     
                                    function switchView(view){
                                        setState('vis.0.control.instance', 'FFFFFFFF');
                                        setState('vis.0.control.data', view);
                                        setState('vis.0.control.command', 'changeView');
                                    }
                                     
                                    // #############################################################################
                                    // #                                                                           #
                                    // #  Funktion zum Prüfen der Wunsch View und zum auslesen der Darstellzeit    #
                                    // #                                                                           #
                                    // #############################################################################
                                     
                                    function checkView(wishView){
                                        if(logging) log('View to check:'+wishView);
                                        if(getState(pfad0 + 'Auto_Switch_View').val === false ){
                                            for(var i = 0; i < Object.keys(VisViews).length; i++) {  
                                                if(project+VisViews[i].view == wishView) {
                                                    if(logging) log('View found in:' + i);
                                                    if(timerTout) clearTimeout(timerTout);
                                                    setState(pfad0 + 'Timer_View_Switch', 0);
                                                    if(VisViews[i].SWSec !== 0){
                                                        setState(pfad0 + 'Timer_View_Switch', VisViews[i].SWSec);
                                                        switchToHomeView();
                                                    }
                                                }
                                            }
                                        }
                                    }
                                    // #############################################################################
                                    // #                                                                           #
                                    // #  Zusatzfunktion um ZusatzDatenpunke zu steuern                            #
                                    // #                                                                           #
                                    // #############################################################################
                                    function additionalActions(dp){
                                        if(dp == "Wandtablet/System"){
                                            setState(pfad0 + "Letzte_System_Meldungen_prio", '');
                                        }
                                        if(dp == "Wandtablet/Kamera_Bilder_Haustuere"){
                                            setState(pfad0 + "Tuerklingel_in_Abwesenheit", false);
                                        }
                                    }
                                    // #############################################################################
                                    // #                                                                           #
                                    // #  ScreenSaver Funktion zum Durchschalten der Views als Bildschirmschoner   #
                                    // #                                                                           #
                                    // #############################################################################
                                    function screenSaver(){
                                        svTimer = setTimeout(function() {
                                            if(getState(pfad0 + 'ScreenSaverActive').val === true){
                                                if((new Date().getTime() - getState('vis.0.control.data').lc)/60000 > screenSv_time){
                                                    setState(pfad0 + 'Auto_Switch_View', true);
                                                }
                                                else{
                                                    setState(pfad0 + 'Auto_Switch_View', false);
                                                }  
                                                screenSaver();  
                                            }
                                        }, 60000);
                                        
                                    }
                                     
                                    // Beobachten des Datenpunktes Screensaver um die Autoview einzuschalten
                                    on({id:'javascript.0.System.Iobroker.ScreenSaverActive'/*Bildschirmschoner*/, change: "ne"}, function (dp) {
                                        if(dp.state.val === true){
                                            screenSaver();
                                            if(logging) log('Screensaver On');
                                        }
                                        else{
                                            if(svTimer) clearTimeout(svTimer);
                                            setState(pfad0 + 'Auto_Switch_View', false);
                                            switchView(project + DefaultView);
                                        } 
                                    });
                                     
                                     
                                    // Beobachten des View Datenpunktes für Auswertung
                                    on({id:"vis.0.control.data", change: "ne"}, function (dp) {
                                        checkView(dp.state.val);
                                            // Zusatzfunktion um den Datenpunkt zurück zu setzten
                                        additionalActions(dp.state.val);
                                    });
                                     
                                     
                                     
                                    //Bei aktiver Alarmanlage auf Pin-View umschalten
                                    on({id: "javascript.0.Alarmanlage.Status.Status"/*Status für Scharfmeldung*/, change: 'any'}, function (dp) {
                                        if(dp.state.val == 2 || dp.state.val == '2'){
                                            switchView('Alarmanlage_code');
                                        }
                                        else{
                                            switchView(DefaultView);
                                        }
                                    });
                                     
                                    //Bei Bewegung auf Kamerabild umschalten
                                    on({id:"hm-rpc.0.XXXXXXXXXX.1.MOTION"/*Bewegungsmelder.Aussen.Haustuere.XXXXXXXXX:1.MOTION*/, change: 'any'}, function (dp) {
                                        if(dp.state.val === true ){
                                             if(getState("javascript.0.Alarmanlage.Status.Status").val != 2 || getState("javascript.0.Alarmanlage.Status.Status").val != '2'){
                                               switchView('Kamera_Garage');
                                             }
                                             else{
                                                switchView('Alarmanlage_code');
                                             }
                                        }
                                    });
                                     
                                     
                                    
                                    
                                    PeoplesP Offline
                                    PeoplesP Offline
                                    Peoples
                                    wrote on last edited by Peoples
                                    #117

                                    @Bostil
                                    Einer der oben bei dir in der Liste eingetragen ist.
                                    Kann auch gerne Mal Remote drauf schauen wenn du möchtest

                                    Ich beantworte keine Fragen zu Themen via PN

                                    1 Reply Last reply
                                    1
                                    • BostilB Offline
                                      BostilB Offline
                                      Bostil
                                      wrote on last edited by Bostil
                                      #118

                                      Danke @Peoples

                                      MIt dem Code oberhalb gestaltet sich das Verhalten nun folgendermaßen:

                                      1. Schalter für ScreenSaverActive wird auf True gesetzt
                                      2. Damit wird der Timer (TimerViewSwitch) auf 180 Sekunden gesetzt und zählt herunter
                                      3. Mit Ablauf des Timers, schaltet sich auch "AutoSwitchView" parallel auf aktiv und nun ist ein Timer über 480 Sekunden gestartet worden
                                      4. es wurde dann kurzzeitig View "Screensaver2" aufgerufen, Timer sprang auf 480, dann auf 180 und nun ist es einfach zurück auf die Main-View gewechselt, während sich der Timer wieder auf 0 befindet und AutoSwitchView wieder deaktiviert wurde

                                      Sehr seltsam .... ich verzweifle langsam an meinem Script, aber das kann ja nicht soviel anders als eures ticken ... danke.

                                      PeoplesP 1 Reply Last reply
                                      0
                                      • BostilB Bostil

                                        Danke @Peoples

                                        MIt dem Code oberhalb gestaltet sich das Verhalten nun folgendermaßen:

                                        1. Schalter für ScreenSaverActive wird auf True gesetzt
                                        2. Damit wird der Timer (TimerViewSwitch) auf 180 Sekunden gesetzt und zählt herunter
                                        3. Mit Ablauf des Timers, schaltet sich auch "AutoSwitchView" parallel auf aktiv und nun ist ein Timer über 480 Sekunden gestartet worden
                                        4. es wurde dann kurzzeitig View "Screensaver2" aufgerufen, Timer sprang auf 480, dann auf 180 und nun ist es einfach zurück auf die Main-View gewechselt, während sich der Timer wieder auf 0 befindet und AutoSwitchView wieder deaktiviert wurde

                                        Sehr seltsam .... ich verzweifle langsam an meinem Script, aber das kann ja nicht soviel anders als eures ticken ... danke.

                                        PeoplesP Offline
                                        PeoplesP Offline
                                        Peoples
                                        wrote on last edited by Peoples
                                        #119

                                        @Bostil
                                        Was mir auf Anhieb mal ins Auge sticht sind die 480 Sekunden, das würde ja heißen jeder Screensaver wird 8 Minuten angezeigt. Hier habe ich schon mal 25, denn das Bild soll ja wechseln.
                                        Ich vermute dass sich die zwei Timer (Automatisch zurück auf Mainview / Screensaver) überschneiden und so der eine Schaltet bevor der andere "gecleart" wurde ist aber nur eine Vermutung.

                                        Das sind genau die Dinge die erst auftauchen wenn andere die Scripte testen, da ich nie auf die Idee gekommen wäre so lange Wechselzeiten zu machen.
                                        Denke der Fehler liegt hier nicht bei dir sondern wirklich im Script, aber wie gesagt ich muss das eh überarbeiten da mache ich mir mal nen merker dass dies mit abgefragt wird

                                        Ich beantworte keine Fragen zu Themen via PN

                                        BostilB 1 Reply Last reply
                                        0
                                        • PeoplesP Peoples

                                          @Bostil
                                          Was mir auf Anhieb mal ins Auge sticht sind die 480 Sekunden, das würde ja heißen jeder Screensaver wird 8 Minuten angezeigt. Hier habe ich schon mal 25, denn das Bild soll ja wechseln.
                                          Ich vermute dass sich die zwei Timer (Automatisch zurück auf Mainview / Screensaver) überschneiden und so der eine Schaltet bevor der andere "gecleart" wurde ist aber nur eine Vermutung.

                                          Das sind genau die Dinge die erst auftauchen wenn andere die Scripte testen, da ich nie auf die Idee gekommen wäre so lange Wechselzeiten zu machen.
                                          Denke der Fehler liegt hier nicht bei dir sondern wirklich im Script, aber wie gesagt ich muss das eh überarbeiten da mache ich mir mal nen merker dass dies mit abgefragt wird

                                          BostilB Offline
                                          BostilB Offline
                                          Bostil
                                          wrote on last edited by
                                          #120

                                          @Peoples Keine Sorge, alles gut! Halte mich auch gerne an die Spielregeln und setze die Timer etwas runter.

                                          Bei mir sieht das Szenario etwas anders aus insofern, dass ich einfach gerne einen stinknormalen Bildschirmschoner suche, der nach ein paar Minuten lediglich ein paar Views abspielt, die dann ein paar Minuten länger stehen bleiben dürften.

                                          PeoplesP 1 Reply Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          601

                                          Online

                                          32.4k

                                          Users

                                          81.3k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe