Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Blockly
    5. Alexa Lautstärkesteuerung via Blockly sehr unzuverlässig

    NEWS

    • Wir empfehlen: Node.js 22.x

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker goes Matter ... Matter Adapter in Stable

    Alexa Lautstärkesteuerung via Blockly sehr unzuverlässig

    This topic has been deleted. Only users with topic management privileges can see it.
    • dslraser
      dslraser Forum Testing Most Active @n3ucr0n last edited by

      @n3ucr0n sagte in Alexa Lautstärkesteuerung via Blockly sehr unzuverlässig:

      @padrino

      Das hier ist einer der DP:

      {
        "_id": "0_userdata.0.Lautstärke.Esszimmer_Laut",
        "type": "state",
        "common": {
          "name": "Esszimmer Laut",
          "role": "",
          "type": "number",
          "min": 0,
          "max": 100,
          "read": true,
          "write": true
        },
        "native": {},
        "from": "system.adapter.admin.0",
        "user": "system.user.admin",
        "ts": 1604914774298,
        "acl": {
          "object": 1636,
          "owner": "system.user.admin",
          "ownerGroup": "system.group.administrator",
          "state": 1636
        }
      }
      

      Beschrieben habe ich die Datenpunkte händisch. Aktuell werden die auch nicht gesteuert bzw. verändert sondern sind starr.

      mach mal eine passende role rein.
      z.B.
      "role": "level.volume",

      1 Reply Last reply Reply Quote 1
      • N
        n3ucr0n @Ahnungsbefreit last edited by

        @ahnungsbefreit
        Hast Du ein (einfaches) Beispiel für mich, an dem ich mir den Gedanken mal näher führen kann?

        @dslraser
        Gute Idee! Werde ich testen! Das Thema mit der Verzögerung hat leider noch keinen Erfolg gebracht. Die Theorie dahinter leuchtet mir ein, daher werde ich die Verzögerung auch drin lassen, aber es werden noch immer die Lautstärken unzuverlässig geschaltet. Die Idee mit der Rolle wird heute noch umgesetzt.

        A 1 Reply Last reply Reply Quote 0
        • apollon77
          apollon77 @padrino last edited by

          @padrino sagte in Alexa Lautstärkesteuerung via Blockly sehr unzuverlässig:

          b) gibt es ein offizielles Limit in Zahlen?

          Nicht wirklich ... experimentieren

          1 Reply Last reply Reply Quote 0
          • N
            n3ucr0n @apollon77 last edited by

            @apollon77 said in Alexa Lautstärkesteuerung via Blockly sehr unzuverlässig:

            Das Problem ist sehr einfach: Zu viel und zu schnell.
            Amazon hat "rate Limits" definiert - bedeutet das nur eine definierte Anzahl an Kommandos in einer bestimmten Zeit durch gehen ... sonst gibt es einen Fehler.

            Du sendest 11 Kommandos quasi zur gleichen zeit raus ... das ist zuviel. Versuch mal ob Dir gruppen helfen.

            Oh hatte Deinen Beitrag oben überlesen, bitte entschuldigung.

            Funktioniert der Workaround mit dem Setzen von Verzögerunden (jeder Block 1 Sekunde nach dem Vorherigen) oder ist das nicht zielführend?

            Den Tipp mit den Gruppen werde ich testen.

            1 Reply Last reply Reply Quote 0
            • A
              Ahnungsbefreit @n3ucr0n last edited by

              @n3ucr0n Ungetestet und nur ein Teil der Logik aus Deinem Script, sollte aber reichen, um das Prinzip zu verdeutlichen:
              ee2f83fe-09c1-4e10-903d-65f419b91168-image.png

              Wenn Du dann noch Gruppen verwendest, um alle Echos, die gleich gesteuert werden, zusammenzufassen, wird das sehr übersichtlich...

              BananaJoe 1 Reply Last reply Reply Quote 0
              • BananaJoe
                BananaJoe Most Active @Ahnungsbefreit last edited by

                @ahnungsbefreit

                Ich meine das Skript ist so nicht richtig. Er wird die beiden Echos setzen und bei jedem das delay warten.

                Wenn er in der Liste 10 Stück hat wir der die Befehle für die 10 hintereinander abfeuern , die werden den Delay warten dann aber trotzdem alle quasi zu gleichen zeit ausgeführt. Denn das Skript warten bei einem Delay nicht auf diesen sondern macht sofort weiter, der Schreibe Befehl macht das warten dann im Hintergrund.
                Ich nehme deshalb "pause" um die Zeit zwischen 2 Zugriffen zu bremsen

                A 1 Reply Last reply Reply Quote 0
                • A
                  Ahnungsbefreit @BananaJoe last edited by Ahnungsbefreit

                  @bananajoe Ich denke, da liegst Du falsch. Genau für solche Zwecke gibt es den Parameter "Verzögerung in ms" . Damit wird der Wert eben genau nach Ablauf der Verzögerung gesetzt.

                  "Pause" sollte man wirklich nur im absoluten Notfall verwenden, ich habe in allen meinen Scripten keine einzige Pause drin und es funktioniert.

                  BananaJoe 1 Reply Last reply Reply Quote 0
                  • BananaJoe
                    BananaJoe Most Active @Ahnungsbefreit last edited by

                    @ahnungsbefreit sagte in Alexa Lautstärkesteuerung via Blockly sehr unzuverlässig:

                    @bananajoe Ich denke, da liegst Du falsch. Genau für solche Zwecke gibt es den Parameter "Verzögerung in ms" . Damit wird der Wert eben genau nach Ablauf der Verzögerung gesetzt.

                    "Pause" sollte man wirklich nur im absoluten Notfall verwenden, ich habe in allen meinen Scripten keine einzige Pause drin und es funktioniert.

                    Dann erkläre mir mal das:
                    029b13fe-0ff8-4709-a5aa-44c5d1cd01cb-image.png
                    bc903cc4-ee79-493d-b33e-c8a744c95d13-image.png :

                    Delay.gif

                    Die müssten dann ja im Abstand von 1 Sekunde an-- und ausgehen, und nicht alle auf einmal.

                    A 1 Reply Last reply Reply Quote 0
                    • A
                      Ahnungsbefreit @BananaJoe last edited by

                      @bananajoe Nein, denn Du hast ja überall 1000 ms Verzögerung drin. In meinem Script zähle in jedem Schleifendurchgang die Verzögerung um 500 ms hoch. Also

                      1. mit 0 ms,
                      2. mit 500 ms,
                      3. mit 1000 ms und so weiter.
                      BananaJoe 1 Reply Last reply Reply Quote 0
                      • BananaJoe
                        BananaJoe Most Active @Ahnungsbefreit last edited by

                        @ahnungsbefreit jetzt habe ich deine Methode verstanden. In der Tat elegant, das Script ist schnell fertig und bereit für den nächsten Aufruf.

                        Wäre jetzt interessant wie en Befehlen setStateDelayed und await wait die Verzögerung umgesetzt wurde um zu sehen was die Folgen/Unterschiede sind.
                        Gibt es die Quellen dazu irgendwo? Mein erster Googleversuch war nicht erfolgreich

                        A 1 Reply Last reply Reply Quote 0
                        • A
                          Ahnungsbefreit @BananaJoe last edited by

                          @bananajoe Guckst Du hier: (https://gist.github.com/AlCalzone/d14b854b69ce5e8a03718336cc650a95#)

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

                          Support us

                          ioBroker
                          Community Adapters
                          Donate

                          791
                          Online

                          32.0k
                          Users

                          80.5k
                          Topics

                          1.3m
                          Posts

                          blockly
                          7
                          31
                          1692
                          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