Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. ioBroker Allgemein
  4. IoBroker und Stau- / Verkehrsinformationen

NEWS

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    11
    1
    331

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    24
    1
    1.5k

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    9.5k

IoBroker und Stau- / Verkehrsinformationen

Geplant Angeheftet Gesperrt Verschoben ioBroker Allgemein
119 Beiträge 48 Kommentatoren 33.4k Aufrufe 24 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • HomoranH Offline
    HomoranH Offline
    Homoran
    Global Moderator Administrators
    schrieb am zuletzt editiert von
    #27

    Die Grafik stellt IMHO die dauer bis zum Ziel in der letzten zeit bis jetzt dar.

    Gruß

    Rainer

    kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

    Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

    der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

    1 Antwort Letzte Antwort
    0
    • ruhr70R Offline
      ruhr70R Offline
      ruhr70
      schrieb am zuletzt editiert von
      #28

      Im Detail ist es folgender Datenpunkt, für den Histroy aktiviert sein muss:

      javascript.1.Google_Maps.zur_Arbeit.Minuten_0

      Das gesamte Widget zum Skript:

      ! ````
      [{"tpl":"tplValueString","data":{"oid":"javascript.1.Google_Maps.zur_Arbeit.Route_0","visibility-cond":"==","visibility-val":1,"test_html":"","html_append":"","gestures-offsetX":0,"gestures-offsetY":0,"html_prepend":"via","signals-cond-0":"==","signals-val-0":true,"signals-icon-0":"/vis/signals/lowbattery.png","signals-icon-size-0":0,"signals-blink-0":false,"signals-horz-0":0,"signals-vert-0":0,"signals-hide-edit-0":false,"signals-cond-1":"==","signals-val-1":true,"signals-icon-1":"/vis/signals/lowbattery.png","signals-icon-size-1":0,"signals-blink-1":false,"signals-horz-1":0,"signals-vert-1":0,"signals-hide-edit-1":false,"signals-cond-2":"==","signals-val-2":true,"signals-icon-2":"/vis/signals/lowbattery.png","signals-icon-size-2":0,"signals-blink-2":false,"signals-horz-2":0,"signals-vert-2":0,"signals-hide-edit-2":false,"visibility-groups-action":"hide"},"style":{"left":"310px","top":"150px","width":"238px","height":"18px","color":"rgb(34, 34, 34)","background":"rgb(204, 204, 204) none repeat scroll 0% 0% / auto padding-box border-box","z-index":"4","text-align":"center"},"widgetSet":"basic"},{"tpl":"tplValueString","data":{"oid":"javascript.1.Google_Maps.zur_Arbeit.Minuten_0","visibility-cond":"==","visibility-val":1,"test_html":"","html_append":" min. ","gestures-offsetX":0,"gestures-offsetY":0,"html_prepend":"","signals-cond-0":"==","signals-val-0":true,"signals-icon-0":"/vis/signals/lowbattery.png","signals-icon-size-0":0,"signals-blink-0":false,"signals-horz-0":0,"signals-vert-0":0,"signals-hide-edit-0":false,"signals-cond-1":"==","signals-val-1":true,"signals-icon-1":"/vis/signals/lowbattery.png","signals-icon-size-1":0,"signals-blink-1":false,"signals-horz-1":0,"signals-vert-1":0,"signals-hide-edit-1":false,"signals-cond-2":"==","signals-val-2":true,"signals-icon-2":"/vis/signals/lowbattery.png","signals-icon-size-2":0,"signals-blink-2":false,"signals-horz-2":0,"signals-vert-2":0,"signals-hide-edit-2":false,"visibility-groups-action":"hide"},"style":{"left":"180px","top":"170px","width":"128px","height":"58px","color":"rgb(34, 34, 34)","background":"rgb(204, 204, 204) none repeat scroll 0% 0% / auto padding-box border-box","z-index":"4","text-align":"center","line-height":"58px","font-size":"30px"},"widgetSet":"basic"},{"tpl":"tplValueString","data":{"oid":"javascript.1.Google_Maps.zur_Arbeit.Staustufe_0","visibility-cond":"==","visibility-val":1,"test_html":"","html_append":"","gestures-offsetX":0,"gestures-offsetY":0,"html_prepend":"Staustufe:","signals-cond-0":"==","signals-val-0":true,"signals-icon-0":"/vis/signals/lowbattery.png","signals-icon-size-0":0,"signals-blink-0":false,"signals-horz-0":0,"signals-vert-0":0,"signals-hide-edit-0":false,"signals-cond-1":"==","signals-val-1":true,"signals-icon-1":"/vis/signals/lowbattery.png","signals-icon-size-1":0,"signals-blink-1":false,"signals-horz-1":0,"signals-vert-1":0,"signals-hide-edit-1":false,"signals-cond-2":"==","signals-val-2":true,"signals-icon-2":"/vis/signals/lowbattery.png","signals-icon-size-2":0,"signals-blink-2":false,"signals-horz-2":0,"signals-vert-2":0,"signals-hide-edit-2":false,"visibility-groups-action":"hide"},"style":{"left":"310px","top":"190px","width":"118px","height":"18px","color":"rgb(34, 34, 34)","background":"rgb(204, 204, 204) none repeat scroll 0% 0% / auto padding-box border-box","z-index":"4","text-align":"center"},"widgetSet":"basic"},{"tpl":"tplHistorySparkLIne","data":{"visibility-cond":"==","visibility-val":1,"aggregate":"max","chartType":"line","points":"400","time_interval":"24 hours","signals-cond-0":"==","signals-val-0":true,"signals-icon-0":"/vis/signals/lowbattery.png","signals-icon-size-0":0,"signals-blink-0":false,"signals-horz-0":0,"signals-vert-0":0,"signals-hide-edit-0":false,"signals-cond-1":"==","signals-val-1":true,"signals-icon-1":"/vis/signals/lowbattery.png","signals-icon-size-1":0,"signals-blink-1":false,"signals-horz-1":0,"signals-vert-1":0,"signals-hide-edit-1":false,"signals-cond-2":"==","signals-val-2":true,"signals-icon-2":"/vis/signals/lowbattery.png","signals-icon-size-2":0,"signals-blink-2":false,"signals-horz-2":0,"signals-vert-2":0,"signals-hide-edit-2":false,"visibility-oid":"","min":"15","max":"45","oid":"javascript.1.Google_Maps.zur_Arbeit.Minuten_0","instance":"sql.0","lineColor":"white","fillColor":"darkgreen","lineWidth":"2","disableTooltips":false,"zeroColor":"#2943c2","visibility-groups-action":"hide"},"style":{"left":"430px","top":"170px","width":"117px","height":"78px","z-index":"2","border-width":"","border-style":"","border-color":"","background-color":"lightgrey","margin-left":"","padding-left":"","padding":"","box-shadow":""},"widgetSet":"history"},{"tpl":"tplValueString","data":{"oid":"javascript.1.Google_Maps.zur_Arbeit.Minuten_0_Deltazeit","visibility-cond":"==","visibility-val":1,"test_html":"","html_append":" min.","gestures-offsetX":0,"gestures-offsetY":0,"html_prepend":"Delta:","signals-cond-0":"==","signals-val-0":true,"signals-icon-0":"/vis/signals/lowbattery.png","signals-icon-size-0":0,"signals-blink-0":false,"signals-horz-0":0,"signals-vert-0":0,"signals-hide-edit-0":false,"signals-cond-1":"==","signals-val-1":true,"signals-icon-1":"/vis/signals/lowbattery.png","signals-icon-size-1":0,"signals-blink-1":false,"signals-horz-1":0,"signals-vert-1":0,"signals-hide-edit-1":false,"signals-cond-2":"==","signals-val-2":true,"signals-icon-2":"/vis/signals/lowbattery.png","signals-icon-size-2":0,"signals-blink-2":false,"signals-horz-2":0,"signals-vert-2":0,"signals-hide-edit-2":false,"visibility-groups-action":"hide"},"style":{"left":"310px","top":"170px","width":"118px","height":"18px","color":"rgb(34, 34, 34)","background":"rgb(204, 204, 204) none repeat scroll 0% 0% / auto padding-box border-box","z-index":"4","text-align":"center"},"widgetSet":"basic"},{"tpl":"tplValueString","data":{"oid":"javascript.1.Google_Maps.zur_Arbeit.Anzahl_Wegpunkte_0","visibility-cond":"==","visibility-val":1,"test_html":"","html_append":"","gestures-offsetX":0,"gestures-offsetY":0,"html_prepend":"Wegpunkte:","signals-cond-0":"==","signals-val-0":true,"signals-icon-0":"/vis/signals/lowbattery.png","signals-icon-size-0":0,"signals-blink-0":false,"signals-horz-0":0,"signals-vert-0":0,"signals-hide-edit-0":false,"signals-cond-1":"==","signals-val-1":true,"signals-icon-1":"/vis/signals/lowbattery.png","signals-icon-size-1":0,"signals-blink-1":false,"signals-horz-1":0,"signals-vert-1":0,"signals-hide-edit-1":false,"signals-cond-2":"==","signals-val-2":true,"signals-icon-2":"/vis/signals/lowbattery.png","signals-icon-size-2":0,"signals-blink-2":false,"signals-horz-2":0,"signals-vert-2":0,"signals-hide-edit-2":false,"visibility-groups-action":"hide"},"style":{"left":"310px","top":"210px","width":"118px","height":"18px","color":"rgb(34, 34, 34)","background":"rgb(204, 204, 204) none repeat scroll 0% 0% / auto padding-box border-box","z-index":"4","text-align":"center"},"widgetSet":"basic"},{"tpl":"tplValueString","data":{"oid":"javascript.1.Google_Maps.zur_Arbeit.skript.status","visibility-cond":"==","visibility-val":1,"test_html":"","html_append":" >","gestures-offsetX":0,"gestures-offsetY":0,"html_prepend":"< ","signals-cond-0":"==","signals-val-0":true,"signals-icon-0":"/vis/signals/lowbattery.png","signals-icon-size-0":0,"signals-blink-0":false,"signals-horz-0":0,"signals-vert-0":0,"signals-hide-edit-0":false,"signals-cond-1":"==","signals-val-1":true,"signals-icon-1":"/vis/signals/lowbattery.png","signals-icon-size-1":0,"signals-blink-1":false,"signals-horz-1":0,"signals-vert-1":0,"signals-hide-edit-1":false,"signals-cond-2":"==","signals-val-2":true,"signals-icon-2":"/vis/signals/lowbattery.png","signals-icon-size-2":0,"signals-blink-2":false,"signals-horz-2":0,"signals-vert-2":0,"signals-hide-edit-2":false,"visibility-groups-action":"hide"},"style":{"left":"180px","top":"230px","width":"128px","height":"18px","color":"rgb(34, 34, 34)","background":"rgb(204, 204, 204) none repeat scroll 0% 0% / auto padding-box border-box","z-index":"4","text-align":"center"},"widgetSet":"basic"},{"tpl":"tplHtml","data":{"visibility-cond":"==","visibility-val":1,"refreshInterval":"0","html":"","gestures-offsetX":0,"gestures-offsetY":0,"signals-cond-0":"==","signals-val-0":true,"signals-icon-0":"/vis/signals/lowbattery.png","signals-icon-size-0":0,"signals-blink-0":false,"signals-horz-0":0,"signals-vert-0":0,"signals-hide-edit-0":false,"signals-cond-1":"==","signals-val-1":true,"signals-icon-1":"/vis/signals/lowbattery.png","signals-icon-size-1":0,"signals-blink-1":false,"signals-horz-1":0,"signals-vert-1":0,"signals-hide-edit-1":false,"signals-cond-2":"==","signals-val-2":true,"signals-icon-2":"/vis/signals/lowbattery.png","signals-icon-size-2":0,"signals-blink-2":false,"signals-horz-2":0,"signals-vert-2":0,"signals-hide-edit-2":false,"visibility-groups-action":"hide"},"style":{"left":"170px","top":"140px","background":"whitesmoke","width":"386px","height":"120px","border-radius":"10px","z-index":"1","overflow-x":""},"widgetSet":"basic"},{"tpl":"tplHtml","data":{"visibility-cond":"==","visibility-val":1,"refreshInterval":"0","html":"Heim -> Arbeit","gestures-offsetX":0,"gestures-offsetY":0,"signals-cond-0":"==","signals-val-0":true,"signals-icon-0":"/vis/signals/lowbattery.png","signals-icon-size-0":0,"signals-blink-0":false,"signals-horz-0":0,"signals-vert-0":0,"signals-hide-edit-0":false,"signals-cond-1":"==","signals-val-1":true,"signals-icon-1":"/vis/signals/lowbattery.png","signals-icon-size-1":0,"signals-blink-1":false,"signals-horz-1":0,"signals-vert-1":0,"signals-hide-edit-1":false,"signals-cond-2":"==","signals-val-2":true,"signals-icon-2":"/vis/signals/lowbattery.png","signals-icon-size-2":0,"signals-blink-2":false,"signals-horz-2":0,"signals-vert-2":0,"signals-hide-edit-2":false,"visibility-groups-action":"hide"},"style":{"left":"180px","top":"150px","background":"darkgrey","width":"126px","height":"18px","z-index":"4","padding-left":"2px","text-align":"center","font-weight":"bold"},"widgetSet":"basic"},{"tpl":"tplValueTimestamp","data":{"oid":"javascript.1.Google_Maps.zur_Arbeit.Minuten_0","g_fixed":false,"g_visibility":false,"g_css_font_text":true,"g_css_background":true,"g_css_shadow_padding":true,"g_css_border":false,"g_gestures":false,"g_signals":false,"visibility-cond":"==","visibility-val":1,"visibility-groups-action":"hide","signals-cond-0":"==","signals-val-0":true,"signals-icon-0":"/vis/signals/lowbattery.png","signals-icon-size-0":0,"signals-blink-0":false,"signals-horz-0":0,"signals-vert-0":0,"signals-hide-edit-0":false,"signals-cond-1":"==","signals-val-1":true,"signals-icon-1":"/vis/signals/lowbattery.png","signals-icon-size-1":0,"signals-blink-1":false,"signals-horz-1":0,"signals-vert-1":0,"signals-hide-edit-1":false,"signals-cond-2":"==","signals-val-2":true,"signals-icon-2":"/vis/signals/lowbattery.png","signals-icon-size-2":0,"signals-blink-2":false,"signals-horz-2":0,"signals-vert-2":0,"signals-hide-edit-2":false,"format_date":"hh:mm:ss"},"style":{"left":"310px","top":"230px","z-index":"4","width":"118px","height":"18px","color":"rgb(34, 34, 34)","text-align":"center","background":"","padding-top":"","margin-top":"","padding":""},"widgetSet":"basic"}]

      
      Dort kann man alle Widgettypen, Formatierungen und verwendete Datenpunkte einsehen.
      
      Version:
      
       ![327_google_maps_zur_arbeit.jpg](/assets/uploads/files/327_google_maps_zur_arbeit.jpg) 
      
      Was ich noch ergänzen muss… Bei Staustufe wird der Hintergrund und die Schriftfarbe entsprechend der Staustufe geändert (noch nicht umgesetzt).
      
      Stufe 0: lime (grün): (keine oder geringe Verzögerung)
      
      Stufe 1: gelb
      
      Stufe 2: orange
      
      Stufe 3: rot

      Adapter: Fritzbox, Unify Circuit
      Skripte: dynamic hue, Bluetooth Scan, Multi-Ereignisliste

      1 Antwort Letzte Antwort
      0
      • ruhr70R Offline
        ruhr70R Offline
        ruhr70
        schrieb am zuletzt editiert von
        #29

        @bahnuhr:

        Das müsste doch die Zeit bis zum Ziel sein. `

        Ja, ist es.

        @bahnuhr:

        Gesucht wird aber doch eine Anzahl von Zeiten um die Grafik aufzubauen. `

        Die Anzahl erhält man über die die aktivierte History beim Datenpunkt, bzw. auf diese History greift das Widget zu.

        Adapter: Fritzbox, Unify Circuit
        Skripte: dynamic hue, Bluetooth Scan, Multi-Ereignisliste

        1 Antwort Letzte Antwort
        0
        • B Offline
          B Offline
          Brati
          schrieb am zuletzt editiert von
          #30

          Noch ein kleiner Tipp, ich habe mir eine Pushnachricht bei Überschreiten einer bestimmten Zeit eingebaut, hat mich schon einmal vor einer Vollsperrung gerettet und kam genau 500m vor der Autobahnauffahrt. Google direkt konnte ich erst nachschauen, nachdem ich mal der Nachricht geglaubt hatte :).

          Vormittags lasse ich den Weg zur Arbeit berechnen und Nachmittags den Rückweg. Einfach den Link je nach Zeit tauschen…

          Grüße

          Brati

          CCU2 - 46 Geräte, ioBroker auf Intel NUC (DN2820FYKH) mit Tab als Frontend, Projekt Gartenhaus mit HM

          1 Antwort Letzte Antwort
          0
          • P Offline
            P Offline
            pix
            schrieb am zuletzt editiert von
            #31

            Hallo,

            auch von mir vielen Dank dafür.

            Lasse auch zu bestimmten Zeiten den Verkehr häufiger neu berechnen. Dazu lasse ich bei verlassen einer Geozone (geofency) prüfen, ob irgendwo Stau ist und mir ggf. eine Meldung pushen.

            Gruß

            Pix

            ioBroker auf Ubuntu in Proxmox (früher Mac mini (bis OS X 10.12.6 Sierra), VIS via iOS; angeschlossen: Homematic CCU2, Homepilot 1, ConBee II, einige Wemos, Sonos, Unifi CK+Protect, Homekit, Homebridge; KEIN blockly! Github-Profil

            1 Antwort Letzte Antwort
            0
            • Holger76H Offline
              Holger76H Offline
              Holger76
              schrieb am zuletzt editiert von
              #32

              @Jeeper.at:

              Ich habe mir einen kostenlosen API-Key bei Google besorgt. Damit kann ich die Verkehrsmeldungen von Google Maps abrufen. Dies mache ich auf einer Webseite welche auf einem Webspace liegt. Diese Webseite binde ich mit einem HTML-Widget in VIS ein.

              Hier ein Screenshot wie es auf meinem IPAD in der Wand aussieht.

              LG

              Günther `

              So eine Karte mit Stauüberblick möchte ich auch gern einbinden(ohne exakte Fahrzeiten von A nach B). Kannst du genauer erklären, wie das mit der Webseite auf dem Webspace funktioniert ?

              Warum gehts nicht einfacher über das google maps widget ? Damit spiele ich schon ein paar Tage, es kommt jedoch lediglich die Meldung im Widget "Hoppla, ein Fehler ist aufgetreten…. "

              NUC8I5BEH (32GB,1TB-SSD) -> Proxmox VM [ioBroker.Pro auf Debian]+[InfluxDB/Grafana]+[AdGuard]+[ Rasp.matic] + [Conbee3] +[Graylog]+[Octopi]
              NUC6CAYH (16GB) [Proxmox Backup Server]+[OMV]

              1 Antwort Letzte Antwort
              0
              • C Offline
                C Offline
                csamaggi
                schrieb am zuletzt editiert von
                #33

                Erst einmal Danke für dieses Script, habe es auch direkt versucht aber ich bekomme im Log Fehlermeldungen und kann nicht ganz nach vollziehen warum.

                LOG

                host.ioBroker-Masterserver	2017-02-12 01:17:46.175	error	instance system.adapter.javascript.0 terminated with code 0 (OK)
                javascript.0	2017-02-12 01:17:45.972	error	at Timer.listOnTimeout (timers.js:92:15)
                javascript.0	2017-02-12 01:17:45.972	error	at ontimeout [as _onTimeout] (timers.js:209:34)
                javascript.0	2017-02-12 01:17:45.972	error	at null. (/opt/iobroker/node_modules/iobroker.javascript/javascript.js:2062:44)
                javascript.0	2017-02-12 01:17:45.972	error	at Object.main (script.js.SayIt.Stauwarner-Nina:227:9)
                javascript.0	2017-02-12 01:17:45.972	error	ReferenceError: isTimeInRange is not defined
                javascript.0	2017-02-12 01:17:45.949	error	uncaught exception: isTimeInRange is not defined
                

                Script

                // Stauberechnung per Google Maps
                //
                // Beschreibung der API: https://developers.google.com/maps/documentation/directions/intro?hl=de#traffic-model
                // API-Key: https://console.developers.google.com/apis/dashboard?project=iobroker-privat&duration=PT1H
                
                //Infos : http://forum.iobroker.net/viewtopic.php?f=8&t=4019&p=38235#p38226
                
                // verwendet globale individuelle globale Funktionen:
                // arbeitstag()
                // urlaubstag()
                // isTimeInRange()
                
                var ldebug              = false; // lokale Debugausgabe des Skripts true/false
                
                var pfad                = "Google_Maps.zur_Arbeit_Nina.";    // Pfad der anzulegenden ioBroker Objekte
                
                var stauStufe1AbMinuten = 5;
                var stauStufe2AbMinuten = 8;
                var stauStufe3AbMinuten = 12;
                
                // Standardzeit in Minuten je Route
                //var standardMinuten0     = 25;
                
                var origin              = "53.29788,10,10.3747713"; // Koordinaten Startadresse
                var via                 = "53.2479342,10.4136992"; // Koordinaten Wegepunkt, um die Route zu bestimmen
                var destination         = "53.2436383,10.4103484"; // Koordinaten Zieladresse
                
                var apikey              = "**********************************"; (Mein Key wurde eingetragen)
                
                var request = require("request");
                
                var myJson = {};
                
                var idUrl                       = pfad + "skript.url";
                var idJson                      = pfad + "skript.ergebnis_json";
                var idStatus                    = pfad + "skript.status";
                
                var idMinuten_0                 = pfad + "Minuten_0";
                var idMinuten_0_durchschnitt    = pfad + "Minuten_0_Durchschnitt";
                var idMinuten_0_delta           = pfad + "Minuten_0_Deltazeit";
                var idRoute_0                   = pfad + "Route_0";             // Routenbezeichnung von Google Maps
                var idStau_0                    = pfad + "Stau_0";              // boolean
                var idStaustufe_0               = pfad + "Staustufe_0";         // Wert von (0-3)
                var idAnzahlWaypoints           = pfad + "Anzahl_Wegpunkte_0";  // ANzahl der Wegpunkte der aktuellen Route
                
                function createAllStates(){
                
                    createState(idMinuten_0, 0, {
                        name: 'Route 0 Minuten aktuell zum Ziel',
                        desc: 'Route 0 Minuten aktuell zum Ziel',
                        type: 'number',
                        role: 'value',
                        unit: 'min'
                    });
                
                    createState(idMinuten_0_durchschnitt, 0, {
                        name: 'Route 0 Minuten im Durchschnitt zum Ziel',
                        desc: 'Route 0 Minuten im Durchschnitt zum Ziel',
                        type: 'number',
                        role: 'value',
                        unit: 'min'
                    });
                
                    createState(idMinuten_0_delta, 0, {
                        name: 'Route 0 Minuten Delta gegenüber dem Durchschnitt',
                        desc: 'Route 0 Minuten Delta gegenüber dem Durchschnitt',
                        type: 'number',
                        role: 'value',
                        unit: 'min'
                    });
                
                    createState(idRoute_0, "init", {
                        name: 'Bezeichnung der Route 0',
                        desc: 'Bezeichnung der Route 0 von Google Maps',
                        type: 'string',
                        role: 'value',
                        unit: ''
                    });
                
                    createState(idStau_0, false, {
                        name: 'Stau auf Route 0 (boolean)',
                        desc: 'Stau auf Route 0 (boolean)',
                        type: 'boolean',
                        role: 'value',
                        unit: ''
                    });
                
                    createState(idStaustufe_0, 0, {
                        name: 'Staustufe auf Route 0 (0-3)',
                        desc: 'Staustufe (0 kein Stau bis 3 starker Stau) auf Route 0',
                        type: 'number',
                        role: 'value',
                        unit: ''
                    });
                
                    createState(idAnzahlWaypoints, 0, {
                        name: 'Aktuelle Anzahl der Wegpunkte für die Route',
                        desc: 'Aktuelle Anzahl der Wegpunkte für die Route',
                        type: 'number',
                        role: 'value',
                        unit: ''
                    });
                
                    createState(idUrl, "", {
                        name: 'url der Abfrage zur Google',
                        desc: 'url der Abfrage zur Google',
                        type: 'string',
                        role: 'value',
                        unit: ''
                    });    
                
                    createState(idJson, "", {
                        name: 'Ergebnis der Abfrage von Google',
                        desc: 'Ergebnis der Abfrage von Google (json)',
                        type: 'string',
                        role: 'value',
                        unit: ''
                    });    
                
                    createState(idStatus, "", {
                        name: 'Status der Abfrage zur Google',
                        desc: 'Status der Abfrage zur Google',
                        type: 'string',
                        role: 'value',
                        unit: ''
                    });    
                
                }
                
                function parseJson(text) {
                    if (text === "") return {};
                    try {
                        json = JSON.parse(text);
                    } catch (ex) {
                        json = {};
                    }
                    if(!json) json = {};
                    return json;
                }
                
                function readJson(url, callback) {
                    request(url, function (err, state, body){
                        if (body) {
                            var json = parseJson(body);
                            callback(null, json);
                        } else {
                            var error = "(" + err + ") ERROR bei Abfrage von: " + url;
                            log(error, "warn");  
                            callback(error, null);
                        }
                    });
                }
                
                var url = 'https://maps.googleapis.com/maps/api/directions/json'
                            + '?origin=' + origin
                            + '&waypoints=via:' + via
                            + '&destination=' + destination 
                            + '&departure_time=now'
                //            + '&sensor=false'
                //            + '&alternatives=true'
                            + '&mode=driving'         // driving = default
                            + '&language=de-DE'
                            + '&key=' + apikey;
                
                function main() {
                    if (ldebug) log("url: " + url);
                    setState(idUrl,url);
                    readJson(url, function(err,json) {
                        if(!err) {
                            myJson = json;
                            if (ldebug) log("json:" + JSON.stringify(myJson));
                            setState(idJson,JSON.stringify(myJson));
                
                            if(myJson.status == "OK") {
                                log("Anzahl Wegepunkte: " + myJson.routes[0].legs[0].steps.length);
                
                                var minuten0 = Math.ceil(myJson.routes[0].legs[0].duration_in_traffic.value / 60);
                                var minuten0_durchschnitt = Math.ceil(myJson.routes[0].legs[0].duration.value / 60);
                                var stau0 = false;
                                var staustufe0 = 0;
                                var delta = minuten0 - minuten0_durchschnitt;
                
                                if (delta >= stauStufe1AbMinuten) {stau0 = true; staustufe0 = 1}
                                if (delta >= stauStufe2AbMinuten) {staustufe0 = 2}
                                if (delta >= stauStufe3AbMinuten) {staustufe0 = 3}
                
                                setState(idMinuten_0                ,minuten0);                 // aktuelle Dauer der Route
                                setState(idMinuten_0_durchschnitt   ,minuten0_durchschnitt);    // durchschnittliche Dauer der Route
                                setState(idMinuten_0_delta          ,delta);                    // Delta Aktuell im Vergleich zum Durchschnitt
                                setState(idRoute_0                  ,myJson.routes[0].summary); // Bezeichnung Route als Text
                                setState(idStau_0                   ,stau0);                    // Boolean
                                setState(idStaustufe_0              ,staustufe0);
                                setState(idAnzahlWaypoints          ,myJson.routes[0].legs[0].steps.length);
                
                            } else {
                
                            log("Kein gültiger Status Google Maps: " + myJson.status);
                
                            }
                        setState(idStatus,myJson.status);
                
                        } else {
                            log("Fehler beim Auslesen des JSON. Keine Daten erhalten.","warn");
                            myJson = {};
                        }
                    });
                
                    // ACHTUNG !!!! Individuelle Anpassung ruhr70
                    // verkleinert den Abfrageintervall an einen Arbeitstag im Zeitraum vor dem Losfahren
                    // globale Funktionen notwendig:
                    // arbeitstag()
                    // urlaubstag()
                    // isTimeInRange()
                    if (isTimeInRange('05:00:00', '06:00:00')) {
                        if (arbeitstag() && !urlaubstag()) {
                            setTimeout(main,90*1000); // alle 90 Sekunden, 1.5 Minuten abfragen 
                        }
                    }
                
                }
                
                schedule("*/10 * * * *", function () { // alle 10 Minuten die Werte abfragen
                    main();
                });
                
                createAllStates(); 
                // Beim Skriptstart die Werte abfragen
                setTimeout(main,1000);
                

                Hoffe ihr habt da eine Idee

                MFG Maggi

                1 Antwort Letzte Antwort
                0
                • bahnuhrB Online
                  bahnuhrB Online
                  bahnuhr
                  Forum Testing Most Active
                  schrieb am zuletzt editiert von
                  #34

                  oben im Script steht:

                  // verwendet globale individuelle globale Funktionen:

                  // arbeitstag()

                  // urlaubstag()

                  // isTimeInRange()

                  Hast du diese ?


                  Wenn ich helfen konnte, dann Daumen hoch (Pfeil nach oben)!
                  Danke.
                  gute Forenbeiträge: https://forum.iobroker.net/topic/51555/hinweise-f%C3%BCr-gute-forenbeitr%C3%A4ge
                  ScreenToGif :https://www.screentogif.com/downloads.html

                  1 Antwort Letzte Antwort
                  0
                  • C Offline
                    C Offline
                    csamaggi
                    schrieb am zuletzt editiert von
                    #35

                    Hmm ah dass hatte ich nicht gesehen.

                    Was genau muss da denn rein?

                    MFG Maggi

                    1 Antwort Letzte Antwort
                    0
                    • ruhr70R Offline
                      ruhr70R Offline
                      ruhr70
                      schrieb am zuletzt editiert von
                      #36

                      Du kannst den Part im Skript ausklammern oder löschen:

                      if (isTimeInRange('05:00:00', '06:00:00')) {
                              if (arbeitstag() && !urlaubstag()) {
                                  setTimeout(main,90*1000); // alle 90 Sekunden, 1.5 Minuten abfragen 
                              }
                          }
                      

                      Der Part Steuer für mich individuell, dass in der Zeit, bevor ich normalerweise losfahre, die Stauinfos öfter abgerufen werden.

                      In der Zeit zwischen 05:00 und 06:00 Uhr, an einem Arbeitstag und wenn es kein Urlaubstag ist, wird die Stauinfo alle 1,5 Minuten aktualisiert.

                      Erläuterungen:

                      Globale Skripte/Funktionen werden bei Skripte i Ordner "global" abgelegt und stehen dann in allen anderen Skripten zur Verfügung.

                      Technisch gesehen werden alle globalen Skripte vor allen anderen Skripten reimkopiert.

                      Das Skript mit der Funktion isTimeInRange() findest Du hier im Forum.

                      Oder auf der Webseite: http://www.iobroker.net/?page_id=3708&lang=de

                      Die Funktionen arbeitstag() und urlaubstag() sind Mini-Skripte, die bei mir die Variable aus der CCU2 auslesen (über hm-rega) und dann als true oder false zurückgehen. So kann ich in allen Skripten z.B. arbeitstag() verwenden, um auf einen Arbeitstag zu prüfen. Sollte die Logik später über ioBroker realisiert werden, brauche ich nur die globale Funktion anzupassen.

                      So kurz sieht es aus:

                      function arbeitstag() {
                          return getState('hm-rega.0.2722').val;
                      }
                      
                      function urlaubstag() {
                          return getState("hm-rega.0.5541"/*Urlaub*/).val;
                      }
                      

                      327_globale_skripte.jpg

                      Adapter: Fritzbox, Unify Circuit
                      Skripte: dynamic hue, Bluetooth Scan, Multi-Ereignisliste

                      1 Antwort Letzte Antwort
                      0
                      • bahnuhrB Online
                        bahnuhrB Online
                        bahnuhr
                        Forum Testing Most Active
                        schrieb am zuletzt editiert von
                        #37
                        Das Skript mit der Funktion isTimeInRange() findest Du hier im Forum.
                        Oder auf der Webseite: http://www.iobroker.net/?page_id=3708&lang=de
                        

                        Auf der Webseite steht immer noch das falsche Script (anstatt time wird date dargestellt)

                        Sollte man vielleicht mal bereinigen (hab ich schon öfters angemerkt).

                        mfg


                        Wenn ich helfen konnte, dann Daumen hoch (Pfeil nach oben)!
                        Danke.
                        gute Forenbeiträge: https://forum.iobroker.net/topic/51555/hinweise-f%C3%BCr-gute-forenbeitr%C3%A4ge
                        ScreenToGif :https://www.screentogif.com/downloads.html

                        1 Antwort Letzte Antwort
                        0
                        • ruhr70R Offline
                          ruhr70R Offline
                          ruhr70
                          schrieb am zuletzt editiert von
                          #38

                          OK, gar nicht drauf geachtet… Eine Aufgabe für @Homoran ;-)

                          Dann das Skript, welches ich hier aus dem Forum kopiert hatte:

                          ! function currentDate() { var d = new Date(); return new Date(d.getFullYear(), d.getMonth(), d.getDate()); } function addTime(strTime) { var time = strTime.split(':'); var d = currentDate(); d.setHours(time[0]); d.setMinutes(time[1]); d.setSeconds(time[2]); return d; } function isTimeInRange(strLower, strUpper) { var now = new Date(); var lower = addTime(strLower); var upper = addTime(strUpper); var inRange = false; if (upper > lower) { // opens and closes in same day inRange = (now >= lower && now <= upper) ? true : false; } else { // closes in the following day inRange = (now >= upper && now <= lower) ? false : true; } return inRange; } !

                          Adapter: Fritzbox, Unify Circuit
                          Skripte: dynamic hue, Bluetooth Scan, Multi-Ereignisliste

                          1 Antwort Letzte Antwort
                          0
                          • HomoranH Offline
                            HomoranH Offline
                            Homoran
                            Global Moderator Administrators
                            schrieb am zuletzt editiert von
                            #39

                            @bahnuhr:

                            Sollte man vielleicht mal bereinigen (hab ich schon öfters angemerkt). `
                            ich hab das korrigierte nicht mehr gefunden :oops:

                            Das von ruhr70 zitierte ist es, oder?

                            Gruß

                            Rainer

                            kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

                            Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                            der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

                            1 Antwort Letzte Antwort
                            0
                            • bahnuhrB Online
                              bahnuhrB Online
                              bahnuhr
                              Forum Testing Most Active
                              schrieb am zuletzt editiert von
                              #40

                              ja, das ist das richtige.

                              Sieht bei mir genauso aus.

                              mfg

                              Dieter


                              Wenn ich helfen konnte, dann Daumen hoch (Pfeil nach oben)!
                              Danke.
                              gute Forenbeiträge: https://forum.iobroker.net/topic/51555/hinweise-f%C3%BCr-gute-forenbeitr%C3%A4ge
                              ScreenToGif :https://www.screentogif.com/downloads.html

                              1 Antwort Letzte Antwort
                              0
                              • HomoranH Offline
                                HomoranH Offline
                                Homoran
                                Global Moderator Administrators
                                schrieb am zuletzt editiert von
                                #41

                                Bitte kontrollieren!

                                http://www.iobroker.net/?page_id=3708&lang=de

                                Danke

                                Rainer

                                kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

                                Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                                der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

                                1 Antwort Letzte Antwort
                                0
                                • bahnuhrB Online
                                  bahnuhrB Online
                                  bahnuhr
                                  Forum Testing Most Active
                                  schrieb am zuletzt editiert von
                                  #42

                                  ja, passt.

                                  alles gut.


                                  Wenn ich helfen konnte, dann Daumen hoch (Pfeil nach oben)!
                                  Danke.
                                  gute Forenbeiträge: https://forum.iobroker.net/topic/51555/hinweise-f%C3%BCr-gute-forenbeitr%C3%A4ge
                                  ScreenToGif :https://www.screentogif.com/downloads.html

                                  1 Antwort Letzte Antwort
                                  0
                                  • C Offline
                                    C Offline
                                    csamaggi
                                    schrieb am zuletzt editiert von
                                    #43

                                    Ich hab das nun ausgeklammert bekomme aber im Log folgende Meldung.

                                    javascript.0 2017-02-12 12:20:01.298	info	script.js.SayIt.Stauwarner-Nina: Kein gültiger Status Google Maps: NOT_FOUND
                                    

                                    Weiss nun nicht genau wo hier das Problem liegt.

                                    MFG Maggi

                                    1 Antwort Letzte Antwort
                                    0
                                    • ruhr70R Offline
                                      ruhr70R Offline
                                      ruhr70
                                      schrieb am zuletzt editiert von
                                      #44

                                      @csamaggi:

                                      Ich hab das nun ausgeklammert bekomme aber im Log folgende Meldung.

                                      javascript.0 2017-02-12 12:20:01.298	info	script.js.SayIt.Stauwarner-Nina: Kein gültiger Status Google Maps: NOT_FOUND
                                      

                                      Weiss nun nicht genau wo hier das Problem liegt.

                                      MFG Maggi `

                                      Du hast hier Deine Daten eingetragen?:

                                      var origin              = "51.4711123,6.4711123"; // Koordinaten Startadresse
                                      var via                 = "51.4711123,6.4711123"; // Koordinaten Wegepunkt, um die Route zu bestimmen
                                      var destination         = "51.4711123,6.4711123"; // Koordinaten Zieladresse
                                      
                                      var apikey              = "xxxxxxxxxxxxxxxxxxxxxxxxxxxx";
                                      

                                      Dein eigener Google-API-Key?

                                      Deine drei Koordinaten?

                                      Adapter: Fritzbox, Unify Circuit
                                      Skripte: dynamic hue, Bluetooth Scan, Multi-Ereignisliste

                                      1 Antwort Letzte Antwort
                                      0
                                      • C Offline
                                        C Offline
                                        csamaggi
                                        schrieb am zuletzt editiert von
                                        #45

                                        Habe den Fehler gefunden bei den Koordinaten hatte ich einen Fehler nun geht es.

                                        MFG Maggi

                                        1 Antwort Letzte Antwort
                                        0
                                        • S Offline
                                          S Offline
                                          Sven2013
                                          schrieb am zuletzt editiert von
                                          #46

                                          Hey Leute,

                                          vielen Dank für das tolle Skript. Es funktioniert auf Anhieb.

                                          Kann ich mir auch die Route auf einer Karte anzeigen lassen um zu sehen wo Google mich her schickt?

                                          Gruß Sven

                                          1 Antwort Letzte Antwort
                                          0
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate
                                          FAQ Cloud / IOT
                                          HowTo: Node.js-Update
                                          HowTo: Backup/Restore
                                          Downloads
                                          BLOG

                                          366

                                          Online

                                          32.5k

                                          Benutzer

                                          81.7k

                                          Themen

                                          1.3m

                                          Beiträge
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Anmelden

                                          • Du hast noch kein Konto? Registrieren

                                          • Anmelden oder registrieren, um zu suchen
                                          • Erster Beitrag
                                            Letzter Beitrag
                                          0
                                          • Home
                                          • Aktuell
                                          • Tags
                                          • Ungelesen 0
                                          • Kategorien
                                          • Unreplied
                                          • Beliebt
                                          • GitHub
                                          • Docu
                                          • Hilfe