Navigation

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

    NEWS

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

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

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

      Поделитесь кто то скриптом управления шаговым двигателем или ссылкой на форуме где почитать.

      Планирую с MegaESP через драйвер ULN2003.

      Спасибо.

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

        @AvaloncheG:

        Поделитесь кто то скриптом управления шаговым двигателем или ссылкой на форуме где почитать.

        Планирую с MegaESP через драйвер ULN2003.

        Спасибо. `
        А причем тут скрипт? Пиши прошивку для есп, а из иоб будешь задавать только угол поворота или скорость и шаги

        1 Reply Last reply Reply Quote 0
        • S
          spectrekr last edited by

          @AvaloncheG:

          Поделитесь кто то скриптом управления шаговым двигателем или ссылкой на форуме где почитать.

          Планирую с MegaESP через драйвер ULN2003.

          Спасибо. `
          Или посмотрите в сторону прошивки wifi-iot, там шаговый реализован, а с iob можно через mqtt связать.

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

            @instalator:

            А причем тут скрипт? `
            Через скрипт нереально?

            Просто хотелось какой то унификации, и не выделять одно устройство только для двигателя.

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

            Поправьте если ошибаюсь 😃

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

              @AvaloncheG:

              @instalator:

              А причем тут скрипт? `
              Через скрипт нереально?

              Просто хотелось какой то унификации, и не выделять одно устройство только для двигателя.

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

              Поправьте если ошибаюсь 😃 ` а задержки?

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

                @instalator:

                а задержки? `
                1-2 секунды или больше?

                Мне же не робота строить, а клапаны, шторы открыть/закрыть.

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

                  @AvaloncheG:

                  @instalator:

                  а задержки? `
                  1-2 секунды или больше?

                  Мне же не робота строить, а клапаны, шторы открыть/закрыть. `
                  Ага, давай прикинем грубо:

                  Угол одного шага возмем 1.8. Т.е. для одного полного оборота надо 360/1.8 = 200 импульсов.

                  Если у тебя задержка между импульсами 1-2 сек т.е. 1-0,5 Гц. Дальше продолжать?

                  Если хочется управлять ШД надо начать с теории.

                  1 Reply Last reply Reply Quote 0
                  • D
                    DAndre last edited by

                    В Log упало сообщение "Спасайся кто может' …......

                    Нужно включить лампочку по этому сообщению. Как?

                    Может переменная у loga есть на которую можно оформить подписку?

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

                      @DAndre:

                      В Log упало сообщение "Спасайся кто может' …......

                      Нужно включить лампочку по этому сообщению. Как?

                      Может переменная у loga есть на которую можно оформить подписку? `
                      надо просто сообщение это не в лог кидать а в переменную

                      1 Reply Last reply Reply Quote 0
                      • D
                        DAndre last edited by

                        Не ясно я объяснил 😢

                        Пример

                        mysensors.02016-12-09 19:23:06.993 info mysensors.0 Log :TSP:MSG:SEND 0-0-1-1 s=3,c=1,t=2,pt=0,l=1,sg=0,ft=0,st=fail:0

                        если st=fail звоним в колокола.

                        в случае st=ok все ок.

                        Как то так. т.е нужно анализировать служебный Log.

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

                          @DAndre:

                          Не ясно я объяснил 😢

                          Пример

                          mysensors.02016-12-09 19:23:06.993 info mysensors.0 Log :TSP:MSG:SEND 0-0-1-1 s=3,c=1,t=2,pt=0,l=1,sg=0,ft=0,st=fail:0

                          если st=fail звоним в колокола.

                          в случае st=ok все ок.

                          Как то так. т.е нужно анализировать служебный Log. `
                          что такое st?

                          1 Reply Last reply Reply Quote 0
                          • D
                            DAndre last edited by

                            st в логе это предположительно статус передачи команды устройству.

                            но это не так важно, другой пример

                            mysensors.0 2016-12-09 19:57:12.613 info disconnected

                            как организовать реакцию на это сообщение

                            или на вот такое

                            megad.0 2016-12-09 19:54:58.765 warn Got error by request to 192.168.2.14: connect EHOSTUNREACH 192.168.2.14:80

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

                              @DAndre:

                              st в логе это предположительно статус передачи команды устройству.

                              но это не так важно, другой пример

                              mysensors.0 2016-12-09 19:57:12.613 info disconnected

                              как организовать реакцию на это сообщение

                              или на вот такое

                              megad.0 2016-12-09 19:54:58.765 warn Got error by request to 192.168.2.14: connect EHOSTUNREACH 192.168.2.14:80 `
                              ну в таком случае тебе скорее всего надо парсить файл логов используя скрипт и модуль fs

                              1 Reply Last reply Reply Quote 0
                              • D
                                DAndre last edited by

                                Спасибо.

                                Вообщем дело темное 😞

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

                                  @DAndre:

                                  Спасибо.

                                  Вообщем дело темное 😞 `
                                  Да темного нету ничего, главное начать и можно разобраться https://nodejs.org/api/fs.html

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

                                    Установлен драйвер MySQL.

                                    Данные пишутся во внешнюю БД.

                                    Скрипт

                                    ! ` > var mysql = require('mysql');

                                    var connection = mysql.createConnection({

                                    host: '192.168.1.110',

                                    user: 'iobroker',

                                    password: 'iobroker',

                                    database: 'iobroker',

                                    //socketPath: '/var/run/mysqld/mysqld.sock'

                                    });

                                    //создаем подключение к базе

                                    connection.connect(function(err) {

                                    if (err) {

                                    log('error connecting: ' + err.stack);

                                    return;

                                    }

                                    log('connected as id ' + connection.threadId);

                                    }); `

                                    Выдает ошибку:

                                    ! javascript.0 script.js.My.sql: Cannot find module '/opt/iobroker/node_modules/iobroker.javascript/node_modules/mysql' at script.js.My.sql:1:13
                                    ! javascript.0 script.js.My.sql: TypeError: Cannot read property 'createConnection' of undefined at script.js.My.sql:3:23

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

                                      @Artem82:

                                      Установлен драйвер MySQL.

                                      Данные пишутся во внешнюю БД.

                                      Скрипт

                                      ! ` > var mysql = require('mysql');

                                      var connection = mysql.createConnection({

                                      host: '192.168.1.110',

                                      user: 'iobroker',

                                      password: 'iobroker',

                                      database: 'iobroker',

                                      //socketPath: '/var/run/mysqld/mysqld.sock'

                                      });

                                      //создаем подключение к базе

                                      connection.connect(function(err) {

                                      if (err) {

                                      log('error connecting: ' + err.stack);

                                      return;

                                      }

                                      log('connected as id ' + connection.threadId);

                                      }); `

                                      Выдает ошибку:

                                      ! javascript.0 script.js.My.sql: Cannot find module '/opt/iobroker/node_modules/iobroker.javascript/node_modules/mysql' at script.js.My.sql:1:13
                                      ! javascript.0 script.js.My.sql: TypeError: Cannot read property 'createConnection' of undefined at script.js.My.sql:3:23 ` втнастройках js добавь пакет mysql

                                      1 Reply Last reply Reply Quote 0
                                      • S
                                        spectrekr last edited by

                                        @Artem82:

                                        Установлен драйвер MySQL.

                                        Данные пишутся во внешнюю БД.

                                        Скрипт

                                        ! ` > var mysql = require('mysql');

                                        var connection = mysql.createConnection({

                                        host: '192.168.1.110',

                                        user: 'iobroker',

                                        password: 'iobroker',

                                        database: 'iobroker',

                                        //socketPath: '/var/run/mysqld/mysqld.sock'

                                        });

                                        //создаем подключение к базе

                                        connection.connect(function(err) {

                                        if (err) {

                                        log('error connecting: ' + err.stack);

                                        return;

                                        }

                                        log('connected as id ' + connection.threadId);

                                        }); `

                                        Выдает ошибку:

                                        ! javascript.0 script.js.My.sql: Cannot find module '/opt/iobroker/node_modules/iobroker.javascript/node_modules/mysql' at script.js.My.sql:1:13
                                        ! javascript.0 script.js.My.sql: TypeError: Cannot read property 'createConnection' of undefined at script.js.My.sql:3:23 `
                                        Во-первых не установлен модуль mysql для js. В настройках драйвера javascript укажите mysql, драйвер сам установит модуль.

                                        Во-вторых, проще установить драйвер history, у него в настройках указать параметры доступа к базе, после чего можно запросы выполнить через sendto ('history.0', "select…") ;.

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

                                          Повторю вопрос, так как не могу найти решение:

                                          Есть ли возможность подписаться на открытие(загрузку) web-страницы, созданной в vis?

                                          Другими словами как при открытии определённой страницы (/vis/index.html#mypage) принудительно запустить определённую функцию, созданную в "Скриптах" админки ( на стороне сервера)?

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

                                            @andrey99986:

                                            Повторю вопрос, так как не могу найти решение:

                                            Есть ли возможность подписаться на открытие(загрузку) web-страницы, созданной в vis?

                                            Другими словами как при открытии определённой страницы (/vis/index.html#mypage) принудительно запустить определённую функцию, созданную в "Скриптах" админки ( на стороне сервера)? `
                                            А jquery не сработает? .ready

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            363
                                            Online

                                            31.7k
                                            Users

                                            79.8k
                                            Topics

                                            1.3m
                                            Posts

                                            29
                                            358
                                            86681
                                            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