Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Русский
    3. ioBroker
    4. Скрипты
    5. ioBroker скрипты
    6. Вопросы по написанию скриптов

    NEWS

    • Monatsrückblick - April 2025

    • Minor js-controller 7.0.7 Update in latest repo

    • Save The Date: ioBroker@Smart Living Forum Solingen, 14.06.

    Вопросы по написанию скриптов

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

      Пытаюсь написать скрипт включения света, все вроде работает но он сам по себе включается каждые 30сек (я так понимаю время опроса Меги) как это обойти?

      сам скрипт:

      on({id: "megad.1.p1_Движение_гостинная"/*Движение_гостинная*/, change: 'ne'}, function (obj) {
              if (getState('onSensor').val === 1 && getState('svetOn').val === 0){
                  log(getState('svetOn').val);
                      clearTimeout(timer);
                      var lux_kitchen = getState("megad.1.p10_Свет_гостинная"/*Свет_гостинная*/).val;
                      log(lux_kitchen);
                          if (getState('svetOn').val === 0){flag_motion_kitchen = true;}
                          if (flag_motion_kitchen){
                              log('запускаем таймер отключения на 30000');
                              timer = setTimeout(function() {
                                  setState("megad.1.p10_Свет_гостинная"/*Свет_гостинная*/, 0);
                                  flag_motion_kitchen = false;
                                  setState('svetOn',0);
                                 log("выкл свет по таймеру");
                              },
                              30000
                          );}
                          if (obj.newState.val === true && flag_motion_kitchen){
                              setState("megad.1.p10_Свет_гостинная"/*Свет_гостинная*/, 255);
                              setState('svetOn',3);
                              log("вкл свет");
                          }
              }
      });
      
      1 Reply Last reply Reply Quote 0
      • Bluefox
        Bluefox last edited by

        @creo:

        Пытаюсь написать скрипт включения света, все вроде работает но он сам по себе включается каждые 30сек (я так понимаю время опроса Меги) как это обойти?

        сам скрипт:

        on({id: "megad.1.p1_Движение_гостинная"/*Движение_гостинная*/, change: 'ne'}, function (obj) {
                if (getState('onSensor').val === 1 && getState('svetOn').val === 0){
                    log(getState('svetOn').val);
                        clearTimeout(timer);
                        var lux_kitchen = getState("megad.1.p10_Свет_гостинная"/*Свет_гостинная*/).val;
                        log(lux_kitchen);
                            if (getState('svetOn').val === 0){flag_motion_kitchen = true;}
                            if (flag_motion_kitchen){
                                log('запускаем таймер отключения на 30000');
                                timer = setTimeout(function() {
                                    setState("megad.1.p10_Свет_гостинная"/*Свет_гостинная*/, 0);
                                    flag_motion_kitchen = false;
                                    setState('svetOn',0);
                                   log("выкл свет по таймеру");
                                },
                                30000
                            );}
                            if (obj.newState.val === true && flag_motion_kitchen){
                                setState("megad.1.p10_Свет_гостинная"/*Свет_гостинная*/, 255);
                                setState('svetOn',3);
                                log("вкл свет");
                            }
                }
        });
        ```` `  
        

        Просто добавь первой строчкой

        перед "if (getState('onSensor').val ==…."

        if (obj.state.ack) return;
        
        
        1 Reply Last reply Reply Quote 0
        • C
          creo last edited by

          теперь скрипт дальше чем if (obj.state.ack) return; не отрабатывает&

          Даже при приходящем событии о смене статуса

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

            @creo:

            теперь скрипт дальше чем if (obj.state.ack) return; не отрабатывает&

            Даже при приходящем событии о смене статуса А что говорит на первой строкой > console.log(typeof getState('onSensor').val) `
            Поменяй === на ==

            1 Reply Last reply Reply Quote 0
            • C
              creo last edited by

              я сделал так:

              var timer;
              var flag_motion_kitchen = false;
              on({id: "megad.1.p1_Движение_гостинная"/*Движение_гостинная*/, change: 'ne'}, function (obj) {
                  console.log("до");
                  if (obj.state.ack) return;
                  console.log("после");
                  if (getState('onSensor').val === 1 && getState('svetOn').val === 0){
                      log(getState('svetOn').val);
                          clearTimeout(timer);
                          var lux_kitchen = getState("megad.1.p10_Свет_гостинная"/*Свет_гостинная*/).val;
                          log(lux_kitchen);
                              if (getState('svetOn').val === 0){flag_motion_kitchen = true;}
                              if (flag_motion_kitchen){
                                  log('запускаем таймер отключения на 30000');
                                  timer = setTimeout(function() {
                                      setState("megad.1.p10_Свет_гостинная"/*Свет_гостинная*/, 0);
                                      flag_motion_kitchen = false;
                                      setState('svetOn',0);
                                     log("выкл свет по таймеру");
                                  },
                                  30000
                              );}
                              if (obj.newState.val === true && flag_motion_kitchen){
                                  setState("megad.1.p10_Свет_гостинная"/*Свет_гостинная*/, 255);
                                  setState('svetOn',3);
                                  log("вкл свет хуй знает");
                              }
                  }
              });
              

              console.log("после"); - не работает

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

                Удали if (obj.state.ack) return;

                я понял, что ты на движение среагировать хочешь.

                Просто замени === на ==

                1 Reply Last reply Reply Quote 0
                • C
                  creo last edited by

                  Но ведь на сколько я понимаю разница в операторах только в варианте сравнения типов?

                  1 Reply Last reply Reply Quote 0
                  • C
                    creo last edited by

                    Вариант с заменой === на == не помог. Все равно самопроизвольно через каждые 30 сек свет зажигается. Какие есть ещё варианты?

                    1 Reply Last reply Reply Quote 0
                    • I
                      instalator last edited by

                      @creo:

                      Вариант с заменой === на == не помог. Все равно самопроизвольно через каждые 30 сек свет зажигается. Какие есть ещё варианты? `
                      Самопроизвольно он включается потому что объект обновляется каждые 30 секунд

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

                        @creo:

                        Вариант с заменой === на == не помог. Все равно самопроизвольно через каждые 30 сек свет зажигается. Какие есть ещё варианты? `
                        Значит ты шлёшь каждые 30 секунд "1".

                        Так чего же удивляться?

                        Выведи значение в лог

                        console.log(typeof getState('onSensor').val + ' - ' + getState('onSensor').val);

                        1 Reply Last reply Reply Quote 0
                        • C
                          creo last edited by

                          Так он и должен срабатывать, я тогда не пойму почему если я подписался на событие датчика движения

                          on({id: "megad.1.p1_Движение_гостинная"/*Движение_гостинная*/, change: 'ne'}, function (obj) {
                          

                          почему он вызывается каждые 30 сек даже когда не приходит ни какого события от самого датчика (когда событие приходит срабатывает как нужно)

                          1 Reply Last reply Reply Quote 0
                          • I
                            instalator last edited by

                            @creo:

                            Так он и должен срабатывать, я тогда не пойму почему если я подписался на событие датчика движения

                            on({id: "megad.1.p1_Движение_гостинная"/*Движение_гостинная*/, change: 'ne'}, function (obj) {
                            

                            почему он вызывается каждые 30 сек даже когда не приходит ни какого события от самого датчика (когда событие приходит срабатывает как нужно) ` значит прилетают разные состояния, выведи в лог и помониторь

                            1 Reply Last reply Reply Quote 0
                            • C
                              creo last edited by

                              В логе событий нет ничего кроме фактически движения (когда оно есть)

                              1 Reply Last reply Reply Quote 0
                              • C
                                creo last edited by

                                так как? вариантов больше нет?

                                1 Reply Last reply Reply Quote 0
                                • I
                                  instalator last edited by

                                  @creo:

                                  так как? вариантов больше нет? `
                                  Скрипт не работает пока нет изменений на megad.1.p1_Движение_гостинная,

                                  так что самопроизвольно он мигает видимо по другой причине. Попробуй останови скрипт.

                                  1 Reply Last reply Reply Quote 0
                                  • A
                                    andrey99986 last edited by

                                    Написал на Blockly программу, первая строка кода:

                                    on({id: 'javascript\\.0\\.gsm7_1_статус', change: "any"}, function (obj) {
                                    

                                    Этот код не срабатывает, наверно из-за неверного экранирования точек.

                                    На js программа работает с таким кодом:

                                    on({id: "javascript.0.gsm7_1_статус", change: "any"}, function (obj) {
                                    
                                    1 Reply Last reply Reply Quote 0
                                    • Bluefox
                                      Bluefox last edited by

                                      @andrey99986:

                                      Написал на Blockly программу, первая строка кода:

                                      on({id: 'javascript\\.0\\.gsm7_1_статус', change: "any"}, function (obj) {
                                      

                                      Этот код не срабатывает, наверно из-за неверного экранирования точек.

                                      На js программа работает с таким кодом:

                                      on({id: "javascript.0.gsm7_1_статус", change: "any"}, function (obj) {
                                      ```` `  
                                      

                                      На гите поправлено. Сегодня вечером будет исправление. Думаю.

                                      1 Reply Last reply Reply Quote 0
                                      • C
                                        creo last edited by

                                        @instalator:

                                        @creo:

                                        так как? вариантов больше нет? `
                                        Скрипт не работает пока нет изменений на megad.1.p1_Движение_гостинная,

                                        так что самопроизвольно он мигает видимо по другой причине. Попробуй останови скрипт. `

                                        Не, остановка не помогает. И мигает он четко каждые 30 сек:

                                        ! ` > 22:10:37.074 [info] javascript.0 script.js.common.test_on: 0

                                        22:10:37.074 [info] javascript.0 script.js.common.test_on: 0

                                        22:10:37.074 [info] javascript.0 script.js.common.test_on: запускаем таймер отключения на 30000

                                        22:10:37.074 [info] javascript.0 script.js.common.test_on: вкл свет

                                        22:10:42.066 [info] javascript.0 script.js.common.test_on: выкл свет по таймеру

                                        22:11:07.067 [info] javascript.0 script.js.common.test_on: 0

                                        22:11:07.067 [info] javascript.0 script.js.common.test_on: 0

                                        22:11:07.067 [info] javascript.0 script.js.common.test_on: запускаем таймер отключения на 30000

                                        22:11:07.067 [info] javascript.0 script.js.common.test_on: вкл свет

                                        22:11:12.068 [info] javascript.0 script.js.common.test_on: выкл свет по таймеру

                                        22:11:37.058 [info] javascript.0 script.js.common.test_on: 0

                                        22:11:37.059 [info] javascript.0 script.js.common.test_on: 0

                                        22:11:37.059 [info] javascript.0 script.js.common.test_on: запускаем таймер отключения на 30000

                                        22:11:37.059 [info] javascript.0 script.js.common.test_on: вкл свет

                                        22:11:42.058 [info] javascript.0 script.js.common.test_on: выкл свет по таймеру

                                        22:12:07.063 [info] javascript.0 script.js.common.test_on: 0

                                        22:12:07.063 [info] javascript.0 script.js.common.test_on: 0

                                        22:12:07.063 [info] javascript.0 script.js.common.test_on: запускаем таймер отключения на 30000

                                        22:12:07.063 [info] javascript.0 script.js.common.test_on: вкл свет

                                        22:12:12.059 [info] javascript.0 script.js.common.test_on: выкл свет по таймеру

                                        22:12:37.060 [info] javascript.0 script.js.common.test_on: 0

                                        22:12:37.060 [info] javascript.0 script.js.common.test_on: 0

                                        22:12:37.060 [info] javascript.0 script.js.common.test_on: запускаем таймер отключения на 30000

                                        22:12:37.060 [info] javascript.0 script.js.common.test_on: вкл свет

                                        22:12:42.059 [info] javascript.0 script.js.common.test_on: выкл свет по таймеру `

                                        Еще раз код:

                                        Переменные

                                        svetOn (1 = если свет был включен с кнопки)

                                        onSensor (1 = если включено использование датчика движения)

                                        ! ````
                                        var timer;
                                        var flag_motion_kitchen = false;
                                        on({id: "megad.1.p1_Движение_гостинная"/Движение_гостинная/, change: 'ne'}, function (obj) {
                                        //if (obj.state.ack) return;
                                        if (getState('onSensor').val == 1 && getState('svetOn').val === 0){
                                        log(getState('svetOn').val);
                                        clearTimeout(timer);
                                        var lux_kitchen = getState("megad.1.p10_Свет_гостинная"/Свет_гостинная/).val;
                                        log(lux_kitchen);
                                        if (getState('svetOn').val == "0"){flag_motion_kitchen = true;}
                                        if (flag_motion_kitchen === true){
                                        log('запускаем таймер отключения на 30000');
                                        timer = setTimeout(function() {
                                        setState("megad.1.p10_Свет_гостинная"/Свет_гостинная/, 0);
                                        flag_motion_kitchen = false;
                                        setState('svetOn',0);
                                        log("выкл свет по таймеру");
                                        },
                                        5000
                                        );}
                                        if (obj.newState.val === true && flag_motion_kitchen){
                                        setState("megad.1.p10_Свет_гостинная"/Свет_гостинная/, 255);
                                        setState('svetOn',3);
                                        log("вкл свет хуй знает");
                                        }
                                        }
                                        });

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

                                          > Не, остановка не помогает.
                                          Это не скрипт. Ищи ошибку в другом месте

                                          1 Reply Last reply Reply Quote 0
                                          • C
                                            creo last edited by

                                            Это конечно прикольно, но я не далекий от написания кода. Каждые 30 сек срабатывает подписка на событие датчика движения. но сам датчик молчит.более я не знаю откуда еще он может вызываться

                                            Где еще можно посмотреть?

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            1.0k
                                            Online

                                            31.6k
                                            Users

                                            79.4k
                                            Topics

                                            1.3m
                                            Posts

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