Плагин MegaD
-
Главный вопрос, почему больше по вышеуказанной проблеие не кто не пишет? А- Не так настроена конфигурация. Б- Проблемы отсутствуют.
Пользователи IH и Megad, давайте поможем разобраться с этим вопросом. Я завтра вечером еще разУчастник @Erik написал в Плагин MegaD:
Главный вопрос, почему больше по вышеуказанной проблеие не кто не пишет? А- Не так настроена конфигурация. Б- Проблемы отсутствуют.
Пользователи IH и Megad, давайте поможем разобраться с этим вопросом. Я завтра вечером еще раз попробую настроить конфиг.
-
Участник @intrahouse написал в Плагин MegaD:
Участник @Erik написал в Плагин MegaD:
Доказано, что проблема - в плагине последней версии.
Коллега, Вы решили нас потроллить?
Я ведь кажется выше четко написал о дате выхода плагина. Никакого обновления не было больше полугода. Плагин работал, а потом вдруг, неделю назад, начал работать неправильно? Может поискать причину в другом, а не в последней версии?Участник @Erik написал в Плагин MegaD:
Вы от меня многого хотите.
По другому мы не сможем помочь Вам.
Проблема только у Вас. На одном контроллере (другой работает), с одним портом (остальные работают).
Как по Вашему мы должны решать Ваш вопрос?По моему, это вы меня тролите.
Проблема есть только с сервером IH, только с плагином мегад последней версии.
Проявляется у меня на одном порту. На одной меге.
При этом в снифере ничего нет.
Но без сервера IH нет и проблемы.Видимо, смотреть нужно что-то еще. Не только TCP, например.
Если ваши шаги не приносят результатов - это значит, что ваши шаги для этой проблемы не подходят.А идея получить от пользователя причину, и только в этом случае начать что-то делать - желание понятное.
Вы же даже лог изменений плагинов не показываете, чтобы пользователю было хоть немного понятно, где искать.
Могу только сказать, что в версии плагина 1.1.10 ошибка не возникает.
Ищите в том, что меняли.
-
Вчера выполняя указания Dev увидел, что и в версии 1.1.10 порт 16 переключился в режим P.
Это не сказалось на работоспособности потому, что проставился чекбокс рядом с установкой режима.Соответственно, номера версии работающего без ошибки плагина нет.
Но есть такой вопрос. У меня в настройках обоих контроллеров "имя скрипта" пустое, и расширения в плагине тоже не содержат имени скрипта.
Это не может влиять?
-
Имя скрипта MegaD отправляет в запросе перед отправкой параметров (перед знаком вопроса):
То есть:
имя скрипта = megad.php --> запрос будет /megad.php?pt=16
имя скрипта пустое --> запрос будет /?pt=16То есть пустое имя скрипта - это нормальный рабочий вариант
-
Добрый день, можно как то дать запрос на мегу чтобы узнать статус реле, включено или выключено реле? У меня внешние ролокасети на 3 провода (1 общий, 2,3 верх, низ). Хочу что бы Ih помнил статус (последние действие), проверял или реле активно у меня сейчас работает без обратной связи а ето не удобно. У меня реализировано команду устройству.
-
Создайте кнопку.
В ней выбирете "команда плагина", выберите свою мегу и напишите эту команду.
/%pwd%/?cmd=all
вместо pwd - свой пароль на меге.
Кнопка будет обновлять состояния всех каналов этой меги.
-
@Erik у маня созданы ACTOR для каждой ролокасети, можно как то чтобы в ACTORе обновлялось состояние, нету описания на эту тему. Чтобы использовать эти значения в сценарии.
Ну и у меня открытие и закрытие подключено к 2 разных реле через: ```this.pluginCommand({unit:'megad3', command:'/258/?cmd='+jalusi.getParam('point_open')+':1;p200;'+jalusi.getParam('point_open')+':0'});
ну и по аналогии закрытие
Вопрос как мне с 2 реле собрать информацию в одном акторе чтобы видеть последнее состояния с реле, чтобы ІН знал жалюзя сейчас открыта или закрыта, нету обратной связи.скрипт
/** * @name Новый мультисценарий * @desc * @version 4 */ const switch_1 = Device("ActorE","Switch"); const jalusi = Device("ActorD","Actor",[ {"name":"point_open", "note":"Пін відкриття", "type":"number", "val":15}, {"name":"point_close", "note":"Пін закриття", "type":"number", "val":16} ]); startOnChange([switch_1,jalusi]); script({ start() { if(this.isChanged(switch_1)){ this.onSwitch(); } if(this.isChanged(jalusi)){ this.onJalusi(); } }, onSwitch(){ switch(switch_1.value){ case 0: if(jalusi.id === "ACTOR7"){ jalusi.on(); this.pluginCommand({unit:'megad3', command:'/258/?cmd='+jalusi.getParam('point_open')+':1;p200;'+jalusi.getParam('point_open')+':0'}); } if(jalusi.id === "ACTOR8"){ //this.pluginCommand({unit:'megad2', command:'/258/?cmd='+jalusi.getParam('point_open')+':1;p210;'+jalusi.getParam('point_open')+':0'}); } if(jalusi.id === "ACTOR9"){ //this.pluginCommand({unit:'megad2', command:'/258/?cmd='+jalusi.getParam('point_open')+':1;p230;'+jalusi.getParam('point_open')+':0'}); } break; case 1: //this.pluginCommand({unit:'megad3', command:'/258/?cmd='+jalusi.getParam('point_open')+':0;'+jalusi.getParam('point_close')+':0'}); break; case 2: if(jalusi.id === "ACTOR7"){ jalusi.off(); this.pluginCommand({unit:'megad3', command:'/258/?cmd='+jalusi.getParam('point_close')+':1;p200;'+jalusi.getParam('point_close')+':0'}); } if(jalusi.id === "ACTOR8"){ jalusi.off(); this.pluginCommand({unit:'megad2', command:'/258/?cmd='+jalusi.getParam('point_close')+':1;p210;'+jalusi.getParam('point_close')+':0'}); } if(jalusi.id === "ACTOR9"){ this.startTimer('T1', 30, 'turnAllOff'); } break; } this.log('Жалюзі статус : '+switch_1.value+' '+jalusi.id); }, turnAllOff(){ jalusi.off(); this.pluginCommand({unit:'megad2', command:'/258/?cmd='+jalusi.getParam('point_close')+':1;p240;'+jalusi.getParam('point_close')+':0'}); this.exit(); }, onJalusi(){ //this.log(this.isChanged(jalusi)+' 38 line'); if(jalusi.isOn()){ //this.log('jalusi On'); if(jalusi.id === "ACTOR7"){ this.pluginCommand({unit:'megad3', command:'/258/?cmd='+jalusi.getParam('point_open')+':1;p200;'+jalusi.getParam('point_open')+':0'}); } if(jalusi.id === "ACTOR8"){ this.pluginCommand({unit:'megad2', command:'/258/?cmd='+jalusi.getParam('point_open')+':1;p210;'+jalusi.getParam('point_open')+':0'}); } if(jalusi.id === "ACTOR9"){ this.pluginCommand({unit:'megad2', command:'/258/?cmd='+jalusi.getParam('point_open')+':1;p240;'+jalusi.getParam('point_open')+':0'}); } }else{ //this.log('jalusi Off'); if(jalusi.id === "ACTOR7"){ this.pluginCommand({unit:'megad3', command:'/258/?cmd='+jalusi.getParam('point_close')+':1;p200;'+jalusi.getParam('point_close')+':0'}); } if(jalusi.id === "ACTOR8"){ this.pluginCommand({unit:'megad2', command:'/258/?cmd='+jalusi.getParam('point_close')+':1;p210;'+jalusi.getParam('point_close')+':0'}); } if(jalusi.id === "ACTOR9"){ this.pluginCommand({unit:'megad2', command:'/258/?cmd='+jalusi.getParam('point_close')+':1;p240;'+jalusi.getParam('point_close')+':0'}); } } this.exit(); } });
а так в админке http://joxi.ru/DmBRwpQSJvnMNm
-
В этом же скрипте после действия присвойте атуатору нужное значение.
После каждого действия присвоение соответствующего значения.
Актуатор будет всегда иметь значение, соответствующее последнему действию.
-
версию 1.1.14 убрали?
Обновление предлагается на 1.1.13 сегодня.
-
Участник @Erik написал в Плагин MegaD:
версию 1.1.14 убрали?
Версия 1.1.14 была сделана для тестирования и официально еще не публиковалась.
При желании ее можно взять на гитхабе.
-
Значит это нервное уже.
А что в ней нового?
-
@Erik можете подсказать что дописать?
-
После открытия
Actor.On();
после закрытия
Actor.Off();Вместо Actor - название нужного актуатора.
-
Участник @Erik написал в Плагин MegaD:
А что в ней нового?
В версии v1.1.14 изменение только для параметра канала
"Использовать функцию обработки при получении данных от контроллера"Ранее функция была привязана к номеру порта контроллера, теперь - к идентификатору канала, чтобы это работало для расширенных портов (MCP, I2C)
Сегодня на github планируем выложить версию v1.1.15, в которой будет:
-
Решение для одновременной сработки датчиков, подключенных к MCP
(модуль MegaD-16I-XT) -
Возможность обработать в сценарии ответ от контроллера для команды pluginCommand
Также на github выложен список изменений плагина за этот год :
https://github.com/intrahouseio/intraHouse.plugin-MegaD файл CHANGELOG
-
-
@intrapro будет реализована обратная связь (pluginCommand) с ролокасетами? То что я так долго ждал?
-
@amgstone, реализовано получение ответа от контроллера в сценарий:
script({ start() { // Передать запрос на megad1, ответ придет в сценарий (onResponse:'raw') this.pluginCommand({unit:'megad1', command:{url:'/sec/?pt=7&cmd=get', onResponse:'raw'}}, 'getResponse'); // Взвести таймер на случай, если ответа от контроллера нет this.startTimer('T1', 3, 'onTimeout'); }, getResponse(body) { // body this.log('getResponse body= '+body); // Анализируем body .... this.exit(); }, onTimeout() { this.log('Истек таймаут, ответ от megad1 не получен'); this.exit(); } });
Если это поможет, то да
-
@intrapro, так в body будет всего лишь "Done". Какой смысл его анализировать? Собственно, тут написал как правильнее сделать @amgstone
-
@Alex_Jet а у Вас ролета подключена к 2 реле, одно на открытие а второе на закрытие?
-
@amgstone, нет - у меня одно выбирает направление, другое подает питание))). Но от этого суть не меняется.
-
@intrapro, даже не представляю какая полезность будет от доработки по п.2...
А вы мои выкладки тут не анализировали?
И да - для Формулы расчета входного значения нужно добавить конвертацию типа данных чтобы не писать "Number(value)+2".Update: тестируя версию 1.1.14, я на старом форуме в личных сообщениях писал что не работает.