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. Русский
  3. ioBroker
  4. Скрипты
  5. ioBroker скрипты
  6. Вопросы по написанию скриптов

NEWS

  • Monatsrückblick Januar/Februar 2026 ist online!
    BluefoxB
    Bluefox
    18
    1
    660

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

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

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

Scheduled Pinned Locked Moved ioBroker скрипты
358 Posts 29 Posters 116.1k 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.
  • I Offline
    I Offline
    instalator
    wrote on last edited by
    #189

    @creo:

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

    Высокий уровень Децибел вреден для здоровья!

    http://blog.instalator.ru/

    1 Reply Last reply
    0
    • BluefoxB Offline
      BluefoxB Offline
      Bluefox
      wrote on last edited by
      #190

      @creo:

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

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

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

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

      1 Reply Last reply
      0
      • C Offline
        C Offline
        creo
        wrote on last edited by
        #191

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

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

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

        1 Reply Last reply
        0
        • I Offline
          I Offline
          instalator
          wrote on last edited by
          #192

          @creo:

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

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

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

          Высокий уровень Децибел вреден для здоровья!

          http://blog.instalator.ru/

          1 Reply Last reply
          0
          • C Offline
            C Offline
            creo
            wrote on last edited by
            #193

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

            1 Reply Last reply
            0
            • C Offline
              C Offline
              creo
              wrote on last edited by
              #194

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

              1 Reply Last reply
              0
              • I Offline
                I Offline
                instalator
                wrote on last edited by
                #195

                @creo:

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

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

                Высокий уровень Децибел вреден для здоровья!

                http://blog.instalator.ru/

                1 Reply Last reply
                0
                • A Offline
                  A Offline
                  andrey99986
                  wrote on last edited by
                  #196

                  Написал на 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
                  0
                  • BluefoxB Offline
                    BluefoxB Offline
                    Bluefox
                    wrote on last edited by
                    #197

                    @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
                    0
                    • C Offline
                      C Offline
                      creo
                      wrote on last edited by
                      #198

                      @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
                      0
                      • BluefoxB Offline
                        BluefoxB Offline
                        Bluefox
                        wrote on last edited by
                        #199

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

                        1 Reply Last reply
                        0
                        • C Offline
                          C Offline
                          creo
                          wrote on last edited by
                          #200

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

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

                          1 Reply Last reply
                          0
                          • BluefoxB Offline
                            BluefoxB Offline
                            Bluefox
                            wrote on last edited by
                            #201

                            А ты можешь встроить вот такой лог?

                            log('svetOn: ' + getState('svetOn').val + ', p1_Движение_гостинная: ' + obj.state.val + '[ack: ' + obj.state.ack + '], onSensor: ' + getState('onSensor').val);
                            
                            
                            1 Reply Last reply
                            0
                            • C Offline
                              C Offline
                              creo
                              wrote on last edited by
                              #202
                              megad-1	2016-09-20 23:48:16.125	info	try to control megad.1.p10_Свет_гостинная with 0
                              javascript-0	2016-09-20 23:48:11.215	info	script.js.common.test_on: svetOn: 3, p1_Движение_гостинная: false[ack: true], onSensor: 1
                              megad-1	2016-09-20 23:48:11.134	info	try to control megad.1.p10_Свет_гостинная with 255
                              
                              1 Reply Last reply
                              0
                              • I Offline
                                I Offline
                                instalator
                                wrote on last edited by
                                #203

                                @creo:

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

                                Т.е проблема не в скрипта

                                Высокий уровень Децибел вреден для здоровья!

                                http://blog.instalator.ru/

                                1 Reply Last reply
                                0
                                • C Offline
                                  C Offline
                                  creo
                                  wrote on last edited by
                                  #204

                                  ну как же проблема не в скрипте когда срабатывает конкретная секция, о чем пишет в лог? может и не в скрипте проблема, может глубже. но я не понимаю куда дальше смотреть

                                  1 Reply Last reply
                                  0
                                  • I Offline
                                    I Offline
                                    instalator
                                    wrote on last edited by
                                    #205

                                    @creo:

                                    ну как же проблема не в скрипте когда срабатывает конкретная секция, о чем пишет в лог? может и не в скрипте проблема, может глубже. но я не понимаю куда дальше смотреть `
                                    Так я понимаю что скрипт стопали, а свет все равно мигал? Причем тут скрипт тогда? И как он выдает данные в лог если он остановлен?

                                    Высокий уровень Децибел вреден для здоровья!

                                    http://blog.instalator.ru/

                                    1 Reply Last reply
                                    0
                                    • C Offline
                                      C Offline
                                      creo
                                      wrote on last edited by
                                      #206

                                      Совершенно на оборот. если остановить скрипт то ничего не включается.

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

                                      Два сообщения вверх есть лог сработки каждые 30 сек

                                      1 Reply Last reply
                                      0
                                      • BluefoxB Offline
                                        BluefoxB Offline
                                        Bluefox
                                        wrote on last edited by
                                        #207

                                        Может так. А код для включения от выключателя существует? Примерно, как вторая часть у моего скрипта?

                                        var timer;
                                        
                                        on({id: "megad.1.p1_Движение_гостинная"/*Движение_гостинная*/, change: 'ne'}, function (obj) {
                                            if (!obj.state.ack) return; // this shoould not happen
                                        
                                        	var svetOn   = parseInt(getState('svetOn').val)   || 0;
                                        	var onSensor = parseInt(getState('onSensor').val) || 0;
                                        	var isMotion = obj.newState.val === 'true' || obj.newState.val === true || obj.newState.val === '1' || obj.newState.val === 1;
                                        	log('svetOn: ' + svetOn + ', p1_Движение_гостинная: ' + isMotion + '[ack: ' + obj.state.ack + '], onSensor: ' + onSensor);
                                        	// svetOn: 3, p1_Движение_гостинная: false[ack: true], onSensor: 1
                                        
                                        	// if motion and sensor enabled and light is OFF or switched on by motion detector
                                            if (isMotion && onSensor === 1 && (svetOn === 0 || svetOn === 3)) {
                                        
                                        		// Output of brightness in kitchen. Just for debug
                                        		log(getState('megad.1.p10_Свет_гостинная'/*Свет_гостинная*/).val);
                                        
                                        		// if light was off => we switch the light on because of motion detector. Start timer		
                                        		setState("megad.1.p10_Свет_гостинная"/*Свет_гостинная*/, 255);
                                        		setState('svetOn', 3);
                                        		log("Включен свет по движению");
                                        
                                        		// start timer for 5 seconds to switch the light off
                                        		log('запускаем таймер отключения на 30000\. старый стираем');	
                                        		if (timer) clearTimeout(timer);
                                        		timer = setTimeout(function() {
                                        			timer = null;
                                        			setState("megad.1.p10_Свет_гостинная"/*Свет_гостинная*/, 0);
                                        			setState('svetOn', 0);
                                        		    log("выкл свет по таймеру");		   
                                        		}, 5000);
                                            }
                                        });
                                        
                                        on({id: "megad.1.px_выключатель света", change: 'ne'}, function (obj) {
                                        	// manual mode => ignore motion timer
                                        	if (timer) clearTimeout(timer);
                                        	timer = null;
                                        
                                        	var obj.state.val = obj.newState.val === 'true' || obj.newState.val === true || obj.newState.val === '1' || obj.newState.val === 1;
                                        
                                        	if (obj.state.val) {
                                        		// somebody pressed on button => switch the light on
                                        		setState("megad.1.p10_Свет_гостинная"/*Свет_гостинная*/, 255);
                                        		setState('svetOn', 1);
                                        	} else {
                                        		// somebody pressed off button => switch the light off
                                        		setState("megad.1.p10_Свет_гостинная"/*Свет_гостинная*/, 0);
                                        		setState('svetOn', 0);
                                        	}
                                        });
                                        
                                        
                                        1 Reply Last reply
                                        0
                                        • C Offline
                                          C Offline
                                          creo
                                          wrote on last edited by
                                          #208

                                          Вс равно блин каждые 30 сек зажигается свет:

                                          16:02:24.820	[info]	javascript.0 script.js.common.test_on: svetOn: 0, p1_Движение_гостинная: true[ack: true], onSensor: 1
                                          16:02:24.820	[info]	javascript.0 script.js.common.test_on: 0
                                          16:02:24.820	[info]	javascript.0 script.js.common.test_on: Включен свет по движению
                                          16:02:24.820	[info]	javascript.0 script.js.common.test_on: запускаем таймер отключения на 30000\. старый стираем
                                          16:02:24.926	[info]	javascript.0 script.js.common.test_on: svetOn: 3, p1_Движение_гостинная: false[ack: true], onSensor: 1
                                          16:02:29.821	[info]	javascript.0 script.js.common.test_on: выкл свет по таймеру
                                          16:02:54.836	[info]	javascript.0 script.js.common.test_on: svetOn: 0, p1_Движение_гостинная: true[ack: true], onSensor: 1
                                          16:02:54.836	[info]	javascript.0 script.js.common.test_on: 0
                                          16:02:54.836	[info]	javascript.0 script.js.common.test_on: Включен свет по движению
                                          16:02:54.836	[info]	javascript.0 script.js.common.test_on: запускаем таймер отключения на 30000\. старый стираем
                                          16:02:54.922	[info]	javascript.0 script.js.common.test_on: svetOn: 3, p1_Движение_гостинная: false[ack: true], onSensor: 1
                                          16:02:59.843	[info]	javascript.0 script.js.common.test_on: выкл свет по таймеру
                                          
                                          1 Reply Last reply
                                          0

                                          Hello! It looks like you're interested in this conversation, but you don't have an account yet.

                                          Getting fed up of having to scroll through the same posts each visit? When you register for an account, you'll always come back to exactly where you were before, and choose to be notified of new replies (either via email, or push notification). You'll also be able to save bookmarks and upvote posts to show your appreciation to other community members.

                                          With your input, this post could be even better 💗

                                          Register Login
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          533

                                          Online

                                          32.7k

                                          Users

                                          82.6k

                                          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