Skip to content
  • Home
  • 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
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. Sayit - Sprachrückmeldung

NEWS

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    17
    1
    3.0k

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

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.4k

Sayit - Sprachrückmeldung

Scheduled Pinned Locked Moved Skripten / Logik
27 Posts 5 Posters 3.4k Views
  • 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.
  • H Offline
    H Offline
    Hicki
    wrote on last edited by
    #15

    Vielen Dank, jetzt ist alles Prima.

    Mich haben die Werte <up>und <down>verwirrt.

    Ich habe mal eine andere Frage: Kann man diese Scripte in einem zusammen fassen? Oder einfacher schreiben?

    Licht an:

    var idSayIt     = "sayit.0.tts.text";               // Hier die entsprechende SayIt Text ID
    var idButton    = "hm-rpc.0.NEQ1660467.2.STATE"; //Objekt
    var lastSay     = null;
    
    // Nach Schalten wird folgender Text gesprochen
    subscribe({id: idButton, val: true}, function (obj) {
             if (!lastSay || ((new Date()).getTime() - lastSay) > 3000) {
                      lastSay = (new Date()).getTime();
                      setState (idSayIt, "de;60;Esstisch - Licht an");
             }
    
            });
    
    

    Licht aus:

    var idSayIt     = "sayit.0.tts.text";               // Hier die entsprechende SayIt Text ID
    var idButton    = "hm-rpc.0.NEQ1660467.2.STATE"; //Objekt
    var lastSay     = null;
    
    // Nach Schalten wird folgender Text gesprochen
    subscribe({id: idButton, val: false}, function (obj) {
             if (!lastSay || ((new Date()).getTime() - lastSay) > 3000) {
                      lastSay = (new Date()).getTime();
                      setState (idSayIt, "de;60;Esstisch - Licht Aus");
             }
    
            });
    
    

    Gruß Andreas</down></up>

    1 Reply Last reply
    0
    • G Offline
      G Offline
      gst666
      wrote on last edited by
      #16

      Kannst Du mir bitte verraten, wofür Du die Zeit in dem Skript verwendest?

      1 Reply Last reply
      0
      • H Offline
        H Offline
        Hicki
        wrote on last edited by
        #17

        @gst666:

        Kannst Du mir bitte verraten, wofür Du die Zeit in dem Skript verwendest? `

        Das habe ich das irgend wo gelesen. Warum und wieso kann ich Dir nicht sagen.

        Dafür bin ich noch zu Neu in der Materie. Deshalb bin ich für jede Hilfe und Erklärung sehr dankbar.

        Gruß Andreas

        1 Reply Last reply
        0
        • G Offline
          G Offline
          gst666
          wrote on last edited by
          #18

          Ohne das Zeitglied könnte die Funktion so aussehen:

          var idSayIt     = "sayit.0.tts.text";               // Hier die entsprechende SayIt Text ID
          var idButton    = "hm-rpc.0.NEQ1660467.2.STATE"; //Objekt
          
          // Nach Schalten wird folgender Text gesprochen
          subscribe({id: idButton, val: any}, function (obj) {
                            if (obj.state.val == true ) {
                                 setState (idSayIt, "de;60;Esstisch - Licht An");
                            } else {
                                 setState (idSayIt, "de;60;Esstisch - Licht Aus");
                            }
                   }
          
          });
          
          

          Das Zeitglied kannst Du natürlich auch wieder einbauen.

          1 Reply Last reply
          0
          • H Offline
            H Offline
            Hicki
            wrote on last edited by
            #19

            Ich danke Dir.

            Welchen Sinn hat das Zeitglied in dem Script?

            1 Reply Last reply
            0
            • G Offline
              G Offline
              gst666
              wrote on last edited by
              #20

              Wenn Du innerhalb einer definierten Zeit mehrfach den Taster drückst (hier 300 Sek), so soll keine erneute Sprachausgabe gemacht werden.

              1 Reply Last reply
              0
              • H Offline
                H Offline
                Hicki
                wrote on last edited by
                #21

                @gst666:

                Wenn Du innerhalb einer definierten Zeit mehrfach den Taster drückst (hier 300 Sek), so soll keine erneute Sprachausgabe gemacht werden. `

                Ahh, dass macht ja zum Teil Sinn.

                Ich danke Dir nochmals für Deine schnelle Hilfe.

                Gruß Andreas

                1 Reply Last reply
                0
                • H Offline
                  H Offline
                  Hicki
                  wrote on last edited by
                  #22

                  Ich habe Dein Script gerade eingebaut.

                  Funktioniert nicht. In der LOG bringt er diese Meldung:

                  • 00:16:38.578 [info] javascript.0 Stop script script.js.common.Couchtisch_-_Licht_an_2(1)
                  00:16:38.616 [info] javascript.0 Start javascript script.js.common.Couchtisch_-_Licht_an_2(1)
                  
                  00:16:38.618 [error] javascript.0 script.js.common.Couchtisch_-_Licht_an_2(1): ReferenceError: any is not defined at script.js.common.Couchtisch_-_Licht_an_2(1):5:31 
                  

                  Gruß Andreas

                  1 Reply Last reply
                  0
                  • H Offline
                    H Offline
                    Hicki
                    wrote on last edited by
                    #23

                    Ich habe das Problem selbst finden können. Hier das korrigierte Script:

                    var idSayIt     = "sayit.0.tts.text";                                   // Hier die entsprechende SayIt Text ID
                    var idButton    = "hm-rpc.0.NEQ1660467.1.STATE";                        // Objekt
                    
                    // Nach Schalten wird folgender Text gesprochen
                    on(idButton, function (obj) {                                           // auf Änderung
                             if (obj.state.val === true ) {                                 // Licht an
                                      setState (idSayIt, "de;60;Couchtisch - Licht an");
                             } else if (obj.state.val === false ) {                         // Licht aus
                                      setState (idSayIt, "de;60;Couchtisch - Licht Aus");
                             }      
                    });
                    
                    

                    Wie baue ich das Zeit-Glied oben wieder ein?

                    if (!lastSay || ((new Date()).getTime() - lastSay) > 3000) {
                                      lastSay = (new Date()).getTime();
                    
                    

                    Gruß Andreas

                    1 Reply Last reply
                    0
                    • H Offline
                      H Offline
                      Hicki
                      wrote on last edited by
                      #24

                      hat keiner eine Idee.

                      1 Reply Last reply
                      0
                      • H Offline
                        H Offline
                        Hicki
                        wrote on last edited by
                        #25
                        var idSayIt     = "sayit.0.tts.text";                                   // Hier die entsprechende SayIt Text ID
                        var idButton    = "hm-rpc.0.NEQ1660467.1.STATE";                        // Objekt
                        
                        // Nach Schalten wird folgender Text gesprochen
                        on(idButton, function (obj) {                                           // auf Änderung
                                 if (obj.state.val === true ) {                                 // Licht an
                                          setState (idSayIt, "de;60;Couchtisch - Licht an");
                                 } else if (obj.state.val === false ) {                         // Licht aus
                                          setState (idSayIt, "de;60;Couchtisch - Licht Aus");
                                 }      
                        });
                        
                        

                        Wie baue ich das Zeit-Glied wieder ein?

                        Zeitglied:

                        if (!lastSay || ((new Date()).getTime() - lastSay) > 3000) {
                                          lastSay = (new Date()).getTime();
                        
                        

                        Kann ich denn überhaut ein Zeitglied in das Script einbauen?

                        Gruß Andreas

                        1 Reply Last reply
                        0
                        • justrJ Offline
                          justrJ Offline
                          justr
                          wrote on last edited by
                          #26
                          var idSayIt     = "sayit.0.tts.text";                                   // Hier die entsprechende SayIt Text ID
                          var idButton    = "hm-rpc.0.NEQ1660467.1.STATE";                        // Objekt
                          var lastSay     = null;
                          
                          // Nach Schalten wird folgender Text gesprochen
                          on(idButton, function (obj) {                                           // auf Änderung
                              if (!lastSay || ((new Date()).getTime() - lastSay) > 3000) {
                                  lastSay = (new Date()).getTime();
                                  if (obj.state.val === true ) {                                 // Licht an
                                      setState (idSayIt, "de;60;Couchtisch - Licht an");
                                  } else if (obj.state.val === false ) {                         // Licht aus
                                      setState (idSayIt, "de;60;Couchtisch - Licht Aus");
                                  }
                              }
                          });
                          
                          1 Reply Last reply
                          0
                          • H Offline
                            H Offline
                            Hicki
                            wrote on last edited by
                            #27

                            Vielen Dank, für Deine Hilfe.

                            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

                            322

                            Online

                            32.7k

                            Users

                            82.3k

                            Topics

                            1.3m

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

                            • Don't have an account? Register

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