Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Русский
    3. ioBroker
    4. ioBroker драйвера
    5. Драйвер sayit

    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.

    Драйвер sayit

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

      @spectrekr:

      У меня Cubietruck. Это мои настройки, воспроизводит и по 2, и по 3 записи подряд. `
      Но ведь судя по объяснению автора
      @Bluefox:

      Длительность извещения - через сколько секунд после начала вступительного звука (извещения - например ТаДа) начать воспроизводить фразу.

      0 - значит сразу начать с текста и ТаДа не проигрывать. Хотя на некоторых системах может проиграться только ТаДа. `
      В вашей ситуации голосовое сообщение будет проиграно через 15 секунд после начала вступительного звука, т.е появится большая пауза между вступлением и самим сообщением.

      И это не объясняет занятость устройства при произнесении нескольких фраз.

      Попробовал настройки spectrekr, отрабатывает вступительный звук, и через 10 секунд идет фраза. Т.е очень долгая пауза. Но ошибками сыпать перестала. Насчет нескольких фраз подряд буду пробовать позже

      1 Reply Last reply Reply Quote 0
      • K
        kID last edited by

        Ну чтож…

        Попробовал несколько фраз, запустив скрипт

         var idSayIt = "sayit.0.tts.text";
            {
        setState (idSayIt, 'Прогноз погоды на сегодня: '+getState("forecast.today").val);
        setState (idSayIt, 'Прогноз погоды на завтра: '+getState("forecast.tomorrow").val);
        setState (idSayIt, 'Прогноз погоды на послезавтра: '+getState("forecast.dayAfterTomorrow").val);
            }
        

        Получил следующие ошибки.
        265__________2015-10-06_20.33.06.png
        Понял что у драйвера нет буфера на входе - то о чем просил electric69 в первом посте этой темы.

        Соответственно нужно контролировать переменную sayit.0.tts.playing и запускать следующую фразу только после установки ее в false.

        Я пока так делать не умею 😞

        Покажите пожалуйста пример.

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

          Получить значение````
          getState('sayit.0.tts.playing').val

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

            @kID:

            Ну чтож…

            Попробовал несколько фраз, запустив скрипт

             var idSayIt = "sayit.0.tts.text";
                {
            setState (idSayIt, 'Прогноз погоды на сегодня: '+getState("forecast.today").val);
            setState (idSayIt, 'Прогноз погоды на завтра: '+getState("forecast.tomorrow").val);
            setState (idSayIt, 'Прогноз погоды на послезавтра: '+getState("forecast.dayAfterTomorrow").val);
                }
            

            Получил следующие ошибки.
            filename="Скриншот 2015-10-06 20.33.06.png" index="0">~~
            Понял что у драйвера нет буфера на входе - то о чем просил electric69 в первом посте этой темы.

            Соответственно нужно контролировать переменную sayit.0.tts.playing и запускать следующую фразу только после установки ее в false.

            Я пока так делать не умею 😞

            Покажите пожалуйста пример. `
            Я так понимаю с последним обновление должно быть исправлено, сам не проверял еще.

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

              @spectrekr:

              Получить значениеgetState('sayit.0.tts.playing').val, а дальше или через условие, или через цикл ждать. `
              Ни в коем случае не через цикл. Это не ардуино.

              В последней версии javascript появилось:

              setState (idSayIt, 'Прогноз погоды на сегодня: '+getState("forecast.today").val,);
              setStateDelayed (idSayIt, 'Прогноз погоды на завтра: '+getState("forecast.tomorrow").val,10000);
              setStateDelayed (idSayIt, 'Прогноз погоды на послезавтра: '+getState("forecast.dayAfterTomorrow").val, 20000);
              
              
              1 Reply Last reply Reply Quote 0
              • V
                vtec last edited by

                У меня у одного sayit после обновления по три раза говорит?

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

                  Заметил в логе ощибки

                  ! host-Server-PC 2015-10-27 10:06:10 error instance system.adapter.sayit.0 terminated with code 6 (uncaught exception)
                  ! TypeError: 2015-10-27 10:06:09 error at Timer.listOnTimeout [as ontimeout] (timers.js:112:15)
                  ! TypeError: 2015-10-27 10:06:09 error at null._onTimeout (C:\ioBroker\node_modules\iobroker.js-controller\lib\adapter.js:1911:34)
                  ! TypeError: 2015-10-27 10:06:09 error at Adapter.emit (events.js:98:17)
                  ! TypeError: 2015-10-27 10:06:09 error at Adapter.sayLastGeneratedText (C:\ioBroker\node_modules\iobroker.sayit\main.js:27:13)
                  ! TypeError: 2015-10-27 10:06:09 error at sayIt (C:\ioBroker\node_modules\iobroker.sayit\main.js:1037:13)
                  ! TypeError: 2015-10-27 10:06:09 error at getLength (C:\ioBroker\node_modules\iobroker.sayit\main.js:172:23)
                  ! TypeError: 2015-10-27 10:06:09 error at C:\ioBroker\node_modules\iobroker.sayit\main.js:1038:51
                  ! TypeError: 2015-10-27 10:06:09 error at Object.sayItWindows [as func] (C:\ioBroker\node_modules\iobroker.sayit\main.js:766:9)
                  ! TypeError: 2015-10-27 10:06:09 error at sayItSystem (C:\ioBroker\node_modules\iobroker.sayit\main.js:698:21)
                  ! TypeError: 2015-10-27 10:06:09 error Cannot call method 'platform' of undefined
                  ! uncaught 2015-10-27 10:06:09 error exception: Cannot call method 'platform' of undefined

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

                    Поправил. Спасибо.
                    5278_unbenannt.png

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

                      Добрался я до sayit наконец то, но не тут то было, драйвер не работает

                      ! sayit.0 2015-11-01 22:27:55 error TypeError: Cannot call method 'exec' of undefined at sayItSystem (C:\ioBroker\node_modules\iobroker.sayit\main.js:733:37) at Object.sayItWindows [as func] (C:\ioBroker\node_modules\iobroker.sayit\main.js:767:9) at C:\ioBroker\node_modules\iobroker.sayit\main.js:1042:51 at getLength (C:\ioBroker\node_modules\iobroker.sayit\main.js:172:23) at sayIt (C:\ioBroker\node_modules\iobroker.sayit\main.js:1041:13) at Adapter.sayLastGeneratedText (C:\ioBroker\node_modules\iobroker.sayit\main.js:27:13) at Adapter.emit (events.js:98:17) at null._onTimeout (C:\ioBroker\node_modules\iobroker.js-controller\lib\adapter.js:1911:34) at Timer.listOnTimeout [as ontimeout] (timers.js:112:15)
                      ! sayit.0 2015-11-01 22:27:55 error uncaught exception: Cannot call method 'exec' of undefined

                      ! host-Server-PC 2015-11-01 22:22:53 error instance system.adapter.sayit.0 terminated with code 6 (uncaught exception)
                      ! TypeError: 2015-11-01 22:22:53 error at Timer.listOnTimeout [as ontimeout] (timers.js:112:15)
                      ! TypeError: 2015-11-01 22:22:53 error at null._onTimeout (C:\ioBroker\node_modules\iobroker.js-controller\lib\adapter.js:1911:34)
                      ! TypeError: 2015-11-01 22:22:53 error at Adapter.emit (events.js:98:17)
                      ! TypeError: 2015-11-01 22:22:53 error at Adapter.sayLastGeneratedText (C:\ioBroker\node_modules\iobroker.sayit\main.js:27:13)
                      ! TypeError: 2015-11-01 22:22:53 error at sayIt (C:\ioBroker\node_modules\iobroker.sayit\main.js:1041:13)
                      ! TypeError: 2015-11-01 22:22:53 error at getLength (C:\ioBroker\node_modules\iobroker.sayit\main.js:172:23)
                      ! TypeError: 2015-11-01 22:22:53 error at C:\ioBroker\node_modules\iobroker.sayit\main.js:1042:51
                      ! TypeError: 2015-11-01 22:22:53 error at Object.sayItWindows [as func] (C:\ioBroker\node_modules\iobroker.sayit\main.js:767:9)
                      ! TypeError: 2015-11-01 22:22:53 error at sayItSystem (C:\ioBroker\node_modules\iobroker.sayit\main.js:733:37)
                      ! TypeError: 2015-11-01 22:22:53 error Cannot call method 'exec' of undefined
                      ! uncaught 2015-11-01 22:22:52 error exception: Cannot call method 'exec' of undefined

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

                        @instalator:

                        Добрался я до sayit наконец то, но не тут то было, драйвер не работает

                        ! sayit.0 2015-11-01 22:27:55 error TypeError: Cannot call method 'exec' of undefined at sayItSystem (C:\ioBroker\node_modules\iobroker.sayit\main.js:733:37) at Object.sayItWindows [as func] (C:\ioBroker\node_modules\iobroker.sayit\main.js:767:9) at C:\ioBroker\node_modules\iobroker.sayit\main.js:1042:51 at getLength (C:\ioBroker\node_modules\iobroker.sayit\main.js:172:23) at sayIt (C:\ioBroker\node_modules\iobroker.sayit\main.js:1041:13) at Adapter.sayLastGeneratedText (C:\ioBroker\node_modules\iobroker.sayit\main.js:27:13) at Adapter.emit (events.js:98:17) at null._onTimeout (C:\ioBroker\node_modules\iobroker.js-controller\lib\adapter.js:1911:34) at Timer.listOnTimeout [as ontimeout] (timers.js:112:15)
                        ! sayit.0 2015-11-01 22:27:55 error uncaught exception: Cannot call method 'exec' of undefined

                        ! host-Server-PC 2015-11-01 22:22:53 error instance system.adapter.sayit.0 terminated with code 6 (uncaught exception)
                        ! TypeError: 2015-11-01 22:22:53 error at Timer.listOnTimeout [as ontimeout] (timers.js:112:15)
                        ! TypeError: 2015-11-01 22:22:53 error at null._onTimeout (C:\ioBroker\node_modules\iobroker.js-controller\lib\adapter.js:1911:34)
                        ! TypeError: 2015-11-01 22:22:53 error at Adapter.emit (events.js:98:17)
                        ! TypeError: 2015-11-01 22:22:53 error at Adapter.sayLastGeneratedText (C:\ioBroker\node_modules\iobroker.sayit\main.js:27:13)
                        ! TypeError: 2015-11-01 22:22:53 error at sayIt (C:\ioBroker\node_modules\iobroker.sayit\main.js:1041:13)
                        ! TypeError: 2015-11-01 22:22:53 error at getLength (C:\ioBroker\node_modules\iobroker.sayit\main.js:172:23)
                        ! TypeError: 2015-11-01 22:22:53 error at C:\ioBroker\node_modules\iobroker.sayit\main.js:1042:51
                        ! TypeError: 2015-11-01 22:22:53 error at Object.sayItWindows [as func] (C:\ioBroker\node_modules\iobroker.sayit\main.js:767:9)
                        ! TypeError: 2015-11-01 22:22:53 error at sayItSystem (C:\ioBroker\node_modules\iobroker.sayit\main.js:733:37)
                        ! TypeError: 2015-11-01 22:22:53 error Cannot call method 'exec' of undefined
                        ! uncaught 2015-11-01 22:22:52 error exception: Cannot call method 'exec' of undefined `

                        Заработал, нужно было выбрать System а стоял Windows engine

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

                          Вопрос к Bluefox.

                          Может добавить в драйвер возможность задать время задержки перед дин дон?

                          Смысл в том что сделал усилитель D класса на микрушке, так вот у него есть логический вход FADE, т.е. при подачи управляющего сигнала он плавно включает громкость (примерно 2 сек.) и так же после снятия управляющего сигнала плавно убавляет громкость до 0 (чтобы небыло шума в динамиках при простое).

                          И кстати sayit.0.tts.playing у меня работает не корректно, менят статус через секунды 3 на false, хотя фраза еще произносится.

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

                            instalator, а если пнутьв скрипте включение усилка выдержать паузу потом сказать фразу.

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

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

                              @aurodionov:

                              instalator, а если пнутьв скрипте включение усилка выдержать паузу потом сказать фразу.

                              я к тому что-бы задержку сделать не в драйвере а в скрипте. `
                              А как ты угадаешь когда будет что то говорить? делать вывод каждый раз добавляя в скриптах задержку?

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

                                @instalator:

                                Нак FADE чем то же дёргаете перед тем как сказать фразу.

                                Получается дёрнули FADE->pause->seyit. Или не?

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

                                  @aurodionov:

                                  @instalator:

                                  Нак FADE чем то же дёргаете перед тем как сказать фразу.

                                  Получается дёрнули FADE->pause->seyit. Или не?

                                  Fade дергаю sayit.0.tts.playing `

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

                                    @instalator:

                                    Fade дергаю sayit.0.tts.playing `
                                    Под линуксом sayit.0.tts.playing вроде не работает, или я не понял как пользоватся

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

                                      @aurodionov:

                                      @instalator:

                                      Fade дергаю sayit.0.tts.playing Под линуксом sayit.0.tts.playing вроде не работает, или я не понял как пользоватся
                                      У меня винда.

                                      Bluefox.

                                      Драйвер сегодня стал проговаривать любую фразу по два раза. В логе ошибок нет

                                      ! sayit.0 2015-11-03 18:34:09 info sayit.0 saying: 1
                                      ! sayit.0 2015-11-03 18:34:07 info sayit.0 saying: 1
                                      ! sayit.0 2015-11-03 18:34:05 info sayit.0 saying: C:\ioBroker\node_modules\iobroker.sayit/gong.mp3
                                      ! sayit.0 2015-11-03 18:34:05 info sayit.0 saying: C:\ioBroker\node_modules\iobroker.sayit/gong.mp3

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

                                        пока не знаю почему. Перезапусти iobroker

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

                                          @instalator:

                                          Вопрос к Bluefox.

                                          Может добавить в драйвер возможность задать время задержки перед дин дон?

                                          Смысл в том что сделал усилитель D класса на микрушке, так вот у него есть логический вход FADE, т.е. при подачи управляющего сигнала он плавно включает громкость (примерно 2 сек.) и так же после снятия управляющего сигнала плавно убавляет громкость до 0 (чтобы небыло шума в динамиках при простое).

                                          И кстати sayit.0.tts.playing у меня работает не корректно, менят статус через секунды 3 на false, хотя фраза еще произносится. `
                                          Слишком специфичный случай. Вот если бы пришёл pul reuquest, я бы подумал..

                                          Вставь в файл дин дон 2 секунды тишины в начале.

                                          1 Reply Last reply Reply Quote 0
                                          • V
                                            vtec last edited by

                                            То же иногда встречается проговаривание по 2-а раза. Тоже не пойму почему.

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            749
                                            Online

                                            31.6k
                                            Users

                                            79.4k
                                            Topics

                                            1.3m
                                            Posts

                                            16
                                            178
                                            47694
                                            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