NEWS
Вопросы по написанию скриптов
-
Здравствуйте! Подскажите возможный ли написать скрипт для Megad на диммирование.
Пробовал делать так:
__on({id: 'megad.0.p0_Кнопка_long', change: 'any'}, function (obj) {
if(getState("megad.0.p0_Кнопка_long").val === true)
{
while(true)
{
if(getState("megad.0.p0_Кнопка_long").val ===true)
{
setState("megad.0.p10_Свет",getState("megad.0.p10_Свет").val+15);
}
else break;
}
}
});__
драйвер висни, возможно не правильно написал или есть какие то другие способы, не через циклы?
То есть пока кнопка нажата то увеличивать яркость?
Да верно, пока зажата кнопка увеличивается яркость, может функция готовая есть )?
-
Здравствуйте! Подскажите возможный ли написать скрипт для Megad на диммирование.
Пробовал делать так:
__on({id: 'megad.0.p0_Кнопка_long', change: 'any'}, function (obj) {
if(getState("megad.0.p0_Кнопка_long").val === true)
{
while(true)
{
if(getState("megad.0.p0_Кнопка_long").val ===true)
{
setState("megad.0.p10_Свет",getState("megad.0.p10_Свет").val+15);
}
else break;
}
}
});__
драйвер висни, возможно не правильно написал или есть какие то другие способы, не через циклы?
То есть пока кнопка нажата то увеличивать яркость?
Да верно, пока зажата кнопка увеличивается яркость, может функция готовая есть )? `
var changeTimer; var direction = 10; function startChange(isIncrease) { direction = isIncrease ? 10: -10; // change value every 300ms by 10 till button is pressed changeTimer = setInterval(function () { var val = getState("megad.0.p10_Свет").val; val += direction; if (val < 0) val = 0; if (val > 255) val = 255; setState("megad.0.p10_Свет", val); }, 300); } function stopChange() { if (changeTimer) { clearInterval(changeTimer); changeTimer = null; } } on({id: 'megad.0.p0_Кнопка_long', change: 'any'}, function (obj) { if (obj.state.val === true) { startChange(true); // increment } else { stopChange(); } }); on({id: 'megad.0.p1_Кнопка_long', change: 'any'}, function (obj) { if (obj.state.val === true) { startChange(false); // decrement } else { stopChange(); } });
-
Надо просто написать скрипт в javascript драйвере и подписаться на vis.0.control.command
И если значение changedView то что то сделать. Если непонятно, то завтра за компьютером могу скрипт накидать `
Как подписаться на открытие конкретной страницы?function myfunction() { // } function start() { on({id: 'vis.0.control.command', change: 'any'}, function (obj) { if (obj.state.val == 'changedView' ) { myfunction(); } }); } start;
-
Надо просто написать скрипт в javascript драйвере и подписаться на vis.0.control.command
И если значение changedView то что то сделать. Если непонятно, то завтра за компьютером могу скрипт накидать
Как подписаться на открытие конкретной страницы?
function myfunction() { // } function start() { on({id: 'vis.0.control.command', change: 'any'}, function (obj) { if (obj.state.val == 'changedView' ) { myfunction(); } }); } start();
Скобки надо поставить при вызове функции.
-
Скобки надо поставить при вызове функции. `
Спасибо, а как подписаться на открытие конкретной страницы? -
Данный код при разницы времени больше 5 минут между текущим временем и временем обновления данных, вешает сервер, и через полминуты сервер остается с 3% оперативки, далее не отвечает вообще.
Код не полный, ниже еще функция sendMessage();, но она точно не влияет. Все работало, пока цикл while не написал.
Моя логика какая- считываем данные, если данные старее чем 5 минут, то обновляем запрос setTimeout (600, pusk()); После запроса считываем опять время полученное от сервера Apple, через драйвер find-my-iphone.
! on({id: 'javascript.0.find_my_iphone.irina', change: 'any'}, function (obj) {
! var date = new Date();//
! var time = date.getTime(); // время в миллисикунндах от 1970 года
! var timeStamp = getState("find-my-iphone.0.iPhone_Ira.timeStamp").val; // время последнего обновления данных в миллисикунндах от 1970 года
! var diftime = time - timeStamp;
! while (diftime > 300000) { //1000 - секунда 60000 - минута 1800000 - 30 минут - стоит 5 минут = 300000
! timeStamp = getState("find-my-iphone.0.iPhone_Ira.timeStamp").val;
! diftime = time - timeStamp;
! log ('while '+diftime);
! setTimeout (600, pusk()); //именно ира
! }
! if (obj.newState.val === true || obj.newState.val === 'true'){
! setState('javascript.0.find_my_iphone.irina', 'false');
! setState("find-my-iphone.0.refresh", true);
! sendMessage();
! }
! });
! function pusk() {
! setState("find-my-iphone.0.iPhone_Ira.refresh", true); //именно ира
! } -
Скобки надо поставить при вызове функции.
Спасибо, а как подписаться на открытие конкретной страницы?
function myfunction() { // } function start() { on({id: 'vis.0.control.command', change: 'any'}, function (obj) { if (obj.state.val == 'changedView' ) { if (getState('vis.0.control.data').val === 'страница') myfunction(); } }); } start();
-
Столкнулся с проблемой. При попытке использовать getState, драйвер выдаёт ошибку.
Пробую как в примерах
!
При этом драйвер начинает ругаться!
Пробую с колбеком,и в нём менять значение
!
Но если добавить вывод в лог, в колбеке, то работает
!
Если сделать так
t = setInterval(function () { console.log(getState('javascript.0.temp', function (err, state){}).val); }, 1000);
То в лог сыпятся ошибки
!
Где допускаю ошибку? Гугл толком не помог.
Заранее спасибо
-
Столкнулся с проблемой. При попытке использовать getState, драйвер выдаёт ошибку.
Пробую как в примерах
Где допускаю ошибку? Гугл толком не помог.
Заранее спасибо `
А почему не так?
setInterval(function () { console.log(getState('javascript.0.temp').val); }, 1000);
Хотя и так работает.
var t; t = setInterval(function() { console.log(getState("mqtt.0.SpectreKr.podval.signaling").val) }, 18000);
Может интервал сильно маленький?
-
Попробовал ваш вариант
Независимо от интервала, в логе сообщение
14:55:00.860 [error] javascript.0 script.js.Скрипт1: Cannot use sync getState, use callback instead getState("javascript.0.temp", function (err, state){});
И драйвер выдаёт в лог целый ворох ошибок, так же как и раньше
Server-Izzm 2017-02-16 14:55:00.894 error instance system.adapter.javascript.0 terminated with code 0 (OK) javascript.0 2017-02-16 14:55:00.862 info terminating javascript.0 2017-02-16 14:55:00.854 error at Timer.listOnTimeout (timers.js:92:15) javascript.0 2017-02-16 14:55:00.854 error at wrapper [as _onTimeout] (timers.js:279:11) javascript.0 2017-02-16 14:55:00.854 error at ontimeout [as _repeat] (timers.js:263:34) javascript.0 2017-02-16 14:55:00.854 error at null. (/opt/iobroker/node_modules/iobroker.javascript/javascript.js:2044:44) javascript.0 2017-02-16 14:55:00.854 error at Object. (script.js.Скрипт1:2:46) javascript.0 2017-02-16 14:55:00.854 error TypeError: Cannot read property 'val' of undefined javascript.0 2017-02-16 14:55:00.848 error uncaught exception: Cannot read property 'val' of undefined javascript.0 2017-02-16 14:55:00.837 error script.js.Скрипт1: Cannot use sync getState, use callback instead getState("javascript.0.temp", function (err, state){});
-
А вообще этот объект существует? В нем какие-то данные есть?
-
Попробовал ваш вариант
Независимо от интервала, в логе сообщение
14:55:00.860 [error] javascript.0 script.js.Скрипт1: Cannot use sync getState, use callback instead getState("javascript.0.temp", function (err, state){});
И драйвер выдаёт в лог целый ворох ошибок, так же как и раньше
Server-Izzm 2017-02-16 14:55:00.894 error instance system.adapter.javascript.0 terminated with code 0 (OK) javascript.0 2017-02-16 14:55:00.862 info terminating javascript.0 2017-02-16 14:55:00.854 error at Timer.listOnTimeout (timers.js:92:15) javascript.0 2017-02-16 14:55:00.854 error at wrapper [as _onTimeout] (timers.js:279:11) javascript.0 2017-02-16 14:55:00.854 error at ontimeout [as _repeat] (timers.js:263:34) javascript.0 2017-02-16 14:55:00.854 error at null. (/opt/iobroker/node_modules/iobroker.javascript/javascript.js:2044:44) javascript.0 2017-02-16 14:55:00.854 error at Object. (script.js.Скрипт1:2:46) javascript.0 2017-02-16 14:55:00.854 error TypeError: Cannot read property 'val' of undefined javascript.0 2017-02-16 14:55:00.848 error uncaught exception: Cannot read property 'val' of undefined javascript.0 2017-02-16 14:55:00.837 error script.js.Скрипт1: Cannot use sync getState, use callback instead getState("javascript.0.temp", function (err, state){}); ```` `
var t; t = setInterval(function() { var v = getState('javascript.0.temp').val; log(v); }, 2000);
-
Вариант, но смысл добавлять еще переменную? И так прекрасно выводит.
-
Читаю другое свойство, которое точно существует
!
Код взял из сообщения instalator.var t; t = setInterval(function() { var v = getState('javascript.0.RealTemp.temp').val; log(v); }, 2000);
Вывод в лог в редакторе скриптов
19:30:57.235 [info] javascript.0 Start javascript script.js.script 19:30:57.235 [info] javascript.0 script.js.script: setInterval(ms=2000) 19:30:57.236 [info] javascript.0 script.js.script: registered 0 subscriptions and 0 schedules 19:30:59.255 [error] javascript.0 script.js.script: Cannot use sync getState, use callback instead getState("javascript.0.RealTemp.temp", function (err, state){});
В глобальном логе
Server-Izzm 2017-02-16 19:30:59.273 info Restart adapter system.adapter.javascript.0 because enabled host.Server-Izzm 2017-02-16 19:30:59.273 error instance system.adapter.javascript.0 terminated with code 0 (OK) javascript.0 2017-02-16 19:30:59.257 info terminating javascript.0 2017-02-16 19:30:59.248 error at Timer.listOnTimeout (timers.js:92:15) javascript.0 2017-02-16 19:30:59.248 error at wrapper [as _onTimeout] (timers.js:279:11) javascript.0 2017-02-16 19:30:59.248 error at ontimeout [as _repeat] (timers.js:263:34) javascript.0 2017-02-16 19:30:59.248 error at null. (/opt/iobroker/node_modules/iobroker.javascript/javascript.js:2044:44) javascript.0 2017-02-16 19:30:59.248 error at Object. (script.js.script:4:67) javascript.0 2017-02-16 19:30:59.248 error TypeError: Cannot read property 'val' of undefined javascript.0 2017-02-16 19:30:59.242 error uncaught exception: Cannot read property 'val' of undefined javascript.0 2017-02-16 19:30:59.233 error script.js.script: Cannot use sync getState, use callback instead getState("javascript.0.RealTemp.temp", function (err, state){});
-
Читаю другое свойство, которое точно существует
! Gate8.PNG
Код взял из сообщения instalator.var t; t = setInterval(function() { var v = getState('javascript.0.RealTemp.temp').val; log(v); }, 2000);
Вывод в лог в редакторе скриптов
19:30:57.235 [info] javascript.0 Start javascript script.js.script 19:30:57.235 [info] javascript.0 script.js.script: setInterval(ms=2000) 19:30:57.236 [info] javascript.0 script.js.script: registered 0 subscriptions and 0 schedules 19:30:59.255 [error] javascript.0 script.js.script: Cannot use sync getState, use callback instead getState("javascript.0.RealTemp.temp", function (err, state){});
В глобальном логе
Server-Izzm 2017-02-16 19:30:59.273 info Restart adapter system.adapter.javascript.0 because enabled host.Server-Izzm 2017-02-16 19:30:59.273 error instance system.adapter.javascript.0 terminated with code 0 (OK) javascript.0 2017-02-16 19:30:59.257 info terminating javascript.0 2017-02-16 19:30:59.248 error at Timer.listOnTimeout (timers.js:92:15) javascript.0 2017-02-16 19:30:59.248 error at wrapper [as _onTimeout] (timers.js:279:11) javascript.0 2017-02-16 19:30:59.248 error at ontimeout [as _repeat] (timers.js:263:34) javascript.0 2017-02-16 19:30:59.248 error at null. (/opt/iobroker/node_modules/iobroker.javascript/javascript.js:2044:44) javascript.0 2017-02-16 19:30:59.248 error at Object. (script.js.script:4:67) javascript.0 2017-02-16 19:30:59.248 error TypeError: Cannot read property 'val' of undefined javascript.0 2017-02-16 19:30:59.242 error uncaught exception: Cannot read property 'val' of undefined javascript.0 2017-02-16 19:30:59.233 error script.js.script: Cannot use sync getState, use callback instead getState("javascript.0.RealTemp.temp", function (err, state){}); ```` `
А так?
var t; t = setInterval(function() { getState("javascript.0.RealTemp.temp", function (err, state){ log(JSON.stringify(state)); }); }, 2000);
-
Вывод в лог. У state в val есть нужное значение.
19:56:08.143 [info] javascript.0 Start javascript script.js.script 19:56:08.144 [info] javascript.0 script.js.script: setInterval(ms=2000) 19:56:08.144 [info] javascript.0 script.js.script: registered 0 subscriptions and 0 schedules 19:56:10.147 [info] javascript.0 script.js.script: {"val":24.5,"ack":true,"ts":1487264169069,"q":0,"from":"system.adapter.javascript.0","lc":1487263250738}
И так работает
var t; var vv; t = setInterval(function() { getState("javascript.0.RealTemp.temp", function (err, state){ log(JSON.stringify(state.val)); vv=state.val; }); log(vv); }, 2000);
20:05:09.423 [info] javascript.0 Start javascript script.js.script 20:05:09.424 [info] javascript.0 script.js.script: setInterval(ms=2000) 20:05:09.424 [info] javascript.0 script.js.script: registered 0 subscriptions and 0 schedules 20:05:11.424 [info] javascript.0 script.js.script: undefined 20:05:11.426 [info] javascript.0 script.js.script: 24.5 20:05:13.429 [info] javascript.0 script.js.script: 24.5 20:05:13.432 [info] javascript.0 script.js.script: 24.5
-
В настройках javascript есть свойство - Оптимизация состояний. Если убрать его, то getState (bla).val заработает.
-
Пытаюсь из строки выбрать IP адрес, сделал регулярное выражение и парсю строку.
!
var reg_ip = new RegExp ('(([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])\.){3}([1-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-4])'); var ip; var str = "first L2TP UDP packet received from 217.15.203.52"; //var str = "error: WARNING: cannot find message with id = 27946818"; ip = reg_ip.exec(str); if(ip){ log("IP: " + ip[0]); } !
Из первой строки выводит только первые две декты IP, а из второй все число, хотя на IP оно и близко не похоже. -
Будь проще
var str = "first L2TP UDP packet received from 217.15.203.52"; var ip = str.match(/\b(\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3})\b/); if(ip){ log("IP: " + ip[1]); }
-
Большое спасибо.
А то я уже такие костыли понастроил.