Skip to content
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • 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

  • Default (No Skin)
  • No Skin
Collapse
Logo
  1. ioBroker Community Home
  2. Deutsch
  3. ioBroker Allgemein
  4. IoBroker und Stau- / Verkehrsinformationen

NEWS

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

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    1.8k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    15
    1
    2.0k

IoBroker und Stau- / Verkehrsinformationen

IoBroker und Stau- / Verkehrsinformationen

Scheduled Pinned Locked Moved ioBroker Allgemein
119 Posts 48 Posters 31.9k Views 24 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • ruhr70R Offline
    ruhr70R Offline
    ruhr70
    wrote on last edited by
    #4

    ich war das nicht mit node red und bing.

    bin nur auf den Zug aufgesprungen.

    früher konnte man mit dem kostenlosen api key von google über die Webschnittstellenicht die Stauzeiten abfragen. Habe es vor ein paar Wochen wieder versucht (per Script). Die Zeiten wechseln zwar, aber nur leicht und nicht so, wie bei Google Maps

    Gesendet von iPhone mit Tapatalk

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

    1 Reply Last reply
    0
    • H Offline
      H Offline
      hobbyquaker
      wrote on last edited by
      #5

      @ruhr70:

      früher konnte man mit dem kostenlosen api key von google über die Webschnittstellenicht die Stauzeiten abfragen. Habe es vor ein paar Wochen wieder versucht (per Script). Die Zeiten wechseln zwar, aber nur leicht und nicht so, wie bei Google Maps `

      ich frag die Fahrzeiten nach wie vor bei Google ab. Gibt bei mir realistische Ergebnisse aus. Man muss nur eines beachten: Es reicht nicht aus einfach nur Origin und Destination in die Abfrage zu packen, dann wird der Verkehr nicht (richtig?) berücksichtigt. Man muss eine Zwischenstation ("waypoint") mit einbauen, diese kann aber die gleichen Koordinaten haben wie die Destination. Warum auch immer, das weiss wohl nur Google 😉

      https://maps.googleapis.com/maps/api/directions/json?origin=48.12345,9.1234&destination=48.4567,9.4567&waypoints=via:48.4567,9.4567&mode=driving&language=de-DE&departure_time=now&key=xyz....
      

      2_bildschirmfoto_2016-10-26_um_20.30.27.png

      1 Reply Last reply
      0
      • ruhr70R Offline
        ruhr70R Offline
        ruhr70
        wrote on last edited by
        #6

        @hobbyquaker:

        ich frag die Fahrzeiten nach wie vor bei Google ab. Gibt bei mir realistische Ergebnisse aus. Man muss nur eines beachten: Es reicht nicht aus einfach nur Origin und Destination in die Abfrage zu packen, dann wird der Verkehr nicht (richtig?) berücksichtigt. Man muss eine Zwischenstation ("waypoint") mit einbauen, diese kann aber die gleichen Koordinaten haben wie die Destination. Warum auch immer, das weiss wohl nur Google 😉 `

        hey, super!

        Das probier ich gleich mal aus.

        Wie kommt man darauf? 😮

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

        1 Reply Last reply
        0
        • M Offline
          M Offline
          mctom
          wrote on last edited by
          #7

          Hallo zusammen,

          Vielen Dank für eure Anregungen.

          Jetzt habe ich was zum Nachdenken.

          @ hobbyquaker: hast du ein Script mit dem du die Rückmeldung von Google auswertest?

          Gruß

          Michael

          1 Reply Last reply
          0
          • BluefoxB Offline
            BluefoxB Offline
            Bluefox
            wrote on last edited by
            #8

            @hobbyquaker: Ich sehe, dass du grafana verwendest. Gibt es irgendwo eine Anleitung wie man Grafana aktivieren konnte.

            Ich habe extra influxdb wegen grafana eingebaut, aber grafana ist immer noch nicht da. 😉

            1 Reply Last reply
            0
            • HomoranH Do not disturb
              HomoranH Do not disturb
              Homoran
              Global Moderator Administrators
              wrote on last edited by
              #9

              Vielleicht kann auch apollon77 weiterhelfen

              http://forum.iobroker.net/viewtopic.php … 120#p37118

              Ich bin noch nicht dazu gekommen. :oops:

              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 Reply Last reply
              0
              • M Offline
                M Offline
                mctom
                wrote on last edited by
                #10

                Hallo zusammen,

                so ich habe mich noch einmal ein wenig mit der Google API auseinandergesetzt.

                Ich habe nun ein Script zusammengeschustert mit Informationen aus anderen Beiträgen bei denen auch JSON Files auseinander genommen werden.

                Hier nun das Script:

                var request = require('request');
                var logging = true;
                
                createState('Verkehr.Fahrtzeit', 0, {
                		type: "number",
                        unit: "min"});
                
                function datenlesen() {
                    var link = 'HIER DER GOOGLE LINK';
                    log('Google Daten einlesen');
                    request(link, function (error, response, body) {
                        if (!error && response.statusCode == 200) {
                            var result;
                            try{
                                result = JSON.parse(body);
                
                                if (logging) log('Kein Fehler beim Einlesen Google Daten');
                
                            } catch (e) {
                                log('Parse Fehler (Roofi Modul):' + e);
                            }    
                            if (result) {
                                 var dauerStau_s;
                                 var dauerStau_m;
                                 if (logging) log(result.routes[0].legs[0].duration.text);
                                 if (logging) log(result.routes[0].legs[0].duration_in_traffic.text);
                                 dauerStau_s = result.routes[0].legs[0].duration_in_traffic.value;
                                 dauerStau_m = dauerStau_s / 60;
                                 log(dauerStau_m);
                                setState("javascript.0.Verkehr.Fahrtzeit"/*Verkehr.Fahrtzeit*/,dauerStau_m);
                
                            }
                        } else log('Fehler (Google Daten Abfrage: ' + error);
                    });   // Ende request 
                    log('Google Daten eingelesen');
                }
                
                schedule("*/5 * * * *", datenlesen); 
                
                datenlesen();
                

                Da Script tut zur Zeit das was es soll.

                Vielleicht kann der ein oder andere Experte mal drüber schauen ob hier noch Dinge verbessert werden können.

                Folgende Dinge sind mir aufgefallen:

                • Die Zeiten mit Stau weichen minimal von der Webseite ab.

                • Die Zeiten ohne Stau die Ausgegeben werden weichen deutlich ab. (35min Webseite / 42min über die Schnittstelle) Die Routen habe ich schon kontrolliert hier gibt es keinen Unterschied.

                • Im täglichen Gebrauch ist schwer zu erkennen welche Route Google nutzt.

                So das wars fürs erste. Danke schon einmal für die Hilfe bis hierher.

                Gruß

                Michael

                1 Reply Last reply
                0
                • S Offline
                  S Offline
                  stephan61
                  wrote on last edited by
                  #11

                  Hallo Michael

                  wollte den Script testen bekomme aber folgende Fehlermeldung
                  516_verkehr.png

                  Gruß Stephan

                  1 Reply Last reply
                  0
                  • M Offline
                    M Offline
                    mctom
                    wrote on last edited by
                    #12

                    Hi Stephan,

                    welche Daten hast du denn in deinem Google Link stehen ?

                    Wenn du den Google Link direkt in den Browser eingibst bekommst du dann Json Daten angezeigt ?

                    Gruß

                    MIchael

                    1 Reply Last reply
                    0
                    • S Offline
                      S Offline
                      stephan61
                      wrote on last edited by
                      #13

                      Hallo Michael

                      bekomme im Browser folgende Datei

                      {

                      "destination_addresses" : [ "Darmstadt, Deutschland" ],

                      "origin_addresses" : [ "~~[b]~~Heimatadresse, Deutschland" ],

                      "rows" : [

                      {

                      "elements" : [

                      {

                      "distance" : {

                      "text" : "32,8 km",

                      "value" : 32764

                      },

                      "duration" : {

                      "text" : "34 Minuten",

                      "value" : 2013

                      },

                      "duration_in_traffic" : {

                      "text" : "36 Minuten",

                      "value" : 2151

                      },

                      "status" : "OK"

                      }

                      ]

                      }

                      ],

                      "status" : "OK"

                      }

                      Gruß Stephan

                      EDIT: Privatadresse unkenntlich gemacht. Homoran

                      1 Reply Last reply
                      0
                      • M Offline
                        M Offline
                        mctom
                        wrote on last edited by
                        #14

                        Komisch deine JSON Datei sieht ganz anders aus.

                        Machst du das auch über die Google API ?

                        Ich habe das Script mal auf deine JSON versucht anzupassen.

                        Probier es mal so:

                        var request = require('request');
                        var logging = true;
                        
                        createState('Verkehr.Fahrtzeit', 0, {
                              type: "number",
                                unit: "min"});
                        
                        function datenlesen() {
                            var link = 'HIER DER GOOGLE LINK';
                            log('Google Daten einlesen');
                            request(link, function (error, response, body) {
                                if (!error && response.statusCode == 200) {
                                    var result;
                                    try{
                                        result = JSON.parse(body);
                        
                                        if (logging) log('Kein Fehler beim Einlesen Google Daten');
                        
                                    } catch (e) {
                                        log('Parse Fehler (Roofi Modul):' + e);
                                    }    
                                    if (result) {
                                         var dauerStau_s;
                                         var dauerStau_m;
                                         if (logging) log(result.rows[0].elements[0].duration.text);
                                         if (logging) log(result.rows[0].elements[0].duration_in_traffic.text);
                                         dauerStau_s = result.rows[0].elements[0].duration_in_traffic.value;
                                         dauerStau_m = dauerStau_s / 60;
                                         log(dauerStau_m);
                                        setState("javascript.0.Verkehr.Fahrtzeit"/*Verkehr.Fahrtzeit*/,dauerStau_m);
                        
                                    }
                                } else log('Fehler (Google Daten Abfrage: ' + error);
                            });   // Ende request 
                            log('Google Daten eingelesen');
                        }
                        
                        schedule("*/5 * * * *", datenlesen); 
                        
                        datenlesen();
                        
                        1 Reply Last reply
                        0
                        • S Offline
                          S Offline
                          stephan61
                          wrote on last edited by
                          #15

                          Hallo Michael

                          dein Scipt geht jetzt

                          ich habe folgende api /maps.googleapis.com/maps/api/distancematriX

                          du hattest die API maps.googleapis.com/maps/api/directions

                          werde jetzt mit Notepad ++ und Json viewer die Ausgaben und Scripte vergleichen

                          Danke

                          gibt es eine einfache Lösung das script nur wischen 5 Uhr und 8 Uhr alle 6 Minuten zu starten?

                          hallo Jeeper .at mit welchem Widget hast die Die karte in Vis eingebunden

                          Gruß Stephan

                          1 Reply Last reply
                          0
                          • P Offline
                            P Offline
                            Phantomio
                            wrote on last edited by
                            #16

                            Hallo,

                            @alle Beteiligten vielen Dank für diese Idee / Infos / Script … funktioniert echt super 😄

                            @stephan61

                            evtl. so:

                             schedule("*/6 * * * *", function () {   
                                if (isTimeInRange("05:00:00", "08:00:00")){
                                  // hier das Script rein
                                }
                            });
                            
                            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;
                            }
                            
                            

                            Gruß

                            Phantomio

                            Geräte: CCU2, RaspberryPi2,

                            Adapter: email, feiertage, flot, fritzbox, history, hm-rpc.0, hm-rpc.1 (Für Homematic IP), ical, javascript, sayit, scenes, socketio, sonos, tankerkoenig, telegram, text2command, vis, web, yr

                            1 Reply Last reply
                            0
                            • Jeeper.atJ Offline
                              Jeeper.atJ Offline
                              Jeeper.at
                              wrote on last edited by
                              #17

                              Ich verwende das IFrame Widget.

                              1 Reply Last reply
                              0
                              • B Offline
                                B Offline
                                Brati
                                wrote on last edited by
                                #18

                                @mctom

                                Das Skript läuft auf Anhieb. Ich runde im letzten Schritt noch auf volle Minuten.

                                dauerStau_m = Math.ceil(dauerStau_s / 60);
                                

                                Den tatsächlichen gewählten Weg zu erkennen ist wirklich schwierig. Kann man auch mehr als einen Wegpunkt einfügen?

                                Und wenn es mal länger dauert lasse ich den Wert rot anzeigen (bei Color eintragen):

                                {v:javascript.0.Verkehr.Fahrtzeit; (v>35) ? "red" : "green"}
                                

                                Grüße

                                Brati

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

                                1 Reply Last reply
                                0
                                • P Offline
                                  P Offline
                                  Phantomio
                                  wrote on last edited by
                                  #19

                                  Hey,

                                  hat jemand hierzu eine Idee?

                                  2016-10-31 13:00:01.195 - ^[[31merror^[[39m: uncaught exception: Cannot read property 'value' of undefined

                                  2016-10-31 13:00:01.213 - ^[[31merror^[[39m: TypeError: Cannot read property 'value' of undefined

                                  at Request._callback (script.js.common.GoogleMaps:514:75)

                                  at Request.self.callback (/opt/iobroker/node_modules/iobroker.javascript/node_modules/request/request.js:187:22)

                                  at emitTwo (events.js:87:13)

                                  at Request.emit (events.js:172:7)

                                  at Request. <anonymous>(/opt/iobroker/node_modules/iobroker.javascript/node_modules/request/request.js:1048:10)

                                  at emitOne (events.js:77:13)

                                  at Request.emit (events.js:169:7)

                                  at IncomingMessage. <anonymous>(/opt/iobroker/node_modules/iobroker.javascript/node_modules/request/request.js:969:12)

                                  at emitNone (events.js:72:20)

                                  at IncomingMessage.emit (events.js:166:7)

                                  Das folgende Script (GoogleMaps) läuft seit ein paar Tagen alle 5 Minuten (bislang gab es nur diesen einen Fehler):

                                  var request = require('request');
                                  var logging = false;
                                  
                                  schedule("*/5 * * * *", datenlesenB75); 
                                  datenlesenB75();
                                  schedule("*/5 * * * *", datenlesenA1); 
                                  datenlesenA1();
                                  schedule("*/5 * * * *", datenlesenB75Zurueck); 
                                  datenlesenB75Zurueck();
                                  
                                  createState('Verkehr.FahrtzeitB75', 0, {type: "number", unit: "min"});
                                  createState('Verkehr.KilometerB75', 0, {type: "number", unit: "km"});
                                  createState('Verkehr.FahrtzeitA1',  0, {type: "number", unit: "min"});
                                  createState('Verkehr.KilometerA1', 0, {type: "number", unit: "km"});
                                  createState('Verkehr.FahrtzeitB75Zurueck', 0, {type: "number", unit: "min"});
                                  createState('Verkehr.KilometerB75Zurueck', 0, {type: "number", unit: "km"});
                                  
                                  function datenlesenB75() {
                                      var link = 'https://maps.googleapis.com/maps/api/directions/json?origin=***&destination=***&waypoints=via:***&mode=driving&language=de-DE&departure_time=now&key=AI***';
                                      request(link, function (error, response, body) {
                                          if (!error && response.statusCode == 200) {
                                              var result;
                                              try{
                                                  result = JSON.parse(body);
                                                  if (logging) log('Kein Fehler beim Einlesen Google Daten');
                                              } catch (e) {
                                                  log('Parse Fehler (Roofi Modul):' + e);
                                              }    
                                              if (result) {
                                                  var dauerStau_s;
                                                  var dauerStau_m;
                                                  var KilometerB75;
                                                  var KilometerB75Neu;
                                                  if (logging) log(result.routes[0].legs[0].duration.text);
                                                  if (logging) log(result.routes[0].legs[0].duration_in_traffic.text);
                                                  KilometerB75 = result.routes[0].legs[0].distance.value / 1000;
                                                  KilometerB75Neu = parseFloat(KilometerB75.toFixed(1));
                                                  dauerStau_s = result.routes[0].legs[0].duration_in_traffic.value;
                                                  dauerStau_m = dauerStau_s / 60;  //var res = num.toFixed(2); // gibt 10.00 zurück  //parseFloat(newvalue.toFixed(2));
                                                  dauerStau_m1 = parseFloat(dauerStau_m.toFixed(2));
                                                  setState("javascript.0.Verkehr.KilometerB75",KilometerB75Neu);
                                                  setState("javascript.0.Verkehr.FahrtzeitB75",dauerStau_m1);
                                              }
                                          } else log('Fehler (Google Daten Abfrage: ' + error);
                                      });   // Ende request 
                                  }
                                  
                                  function datenlesenB75Zurueck() {
                                      var link = 'https://maps.googleapis.com/maps/api/directions/json?origin=***&destination=***&waypoints=via:***&mode=driving&language=de-DE&departure_time=now&key=A***';
                                      request(link, function (error, response, body) {
                                          if (!error && response.statusCode == 200) {
                                              var result;
                                              try{
                                                  result = JSON.parse(body);
                                                  if (logging) log('Kein Fehler beim Einlesen Google Daten');
                                              } catch (e) {
                                                  log('Parse Fehler (Roofi Modul):' + e);
                                              }    
                                              if (result) {
                                                  var dauerStau_s;
                                                  var dauerStau_m;
                                                  var KilometerB75Zurueck;
                                                  var KilometerB75ZurueckNeu;
                                                  KilometerB75Zurueck = result.routes[0].legs[0].distance.value / 1000;
                                                  KilometerB75ZurueckNeu = parseFloat(KilometerB75Zurueck.toFixed(1));
                                                  dauerStau_s = result.routes[0].legs[0].duration_in_traffic.value;
                                                  dauerStau_m = dauerStau_s / 60;
                                                  dauerStau_m1 = parseFloat(dauerStau_m.toFixed(2));
                                                  setState("javascript.0.Verkehr.KilometerB75Zurueck",KilometerB75ZurueckNeu);
                                                  setState("javascript.0.Verkehr.FahrtzeitB75Zurueck",dauerStau_m1);
                                              }
                                          } else log('Fehler (Google Daten Abfrage: ' + error);
                                      });   // Ende request 
                                  }
                                  
                                  function datenlesenA1() {
                                      var link = 'https://maps.googleapis.com/maps/api/directions/json?origin=***&destination=***&waypoints=via:***&mode=driving&language=de-DE&departure_time=now&key=A***';
                                      request(link, function (error, response, body) {
                                          if (!error && response.statusCode == 200) { 
                                              var result;
                                              try{
                                                  result = JSON.parse(body);
                                                  if (logging) log('Kein Fehler beim Einlesen Google Daten');
                                              } catch (e) {
                                                  log('Parse Fehler (Roofi Modul):' + e);
                                              }    
                                              if (result) {
                                                  var dauerStau_s;
                                                  var dauerStau_m;
                                                  var KilometerA1;
                                                  var KilometerA1Neu;
                                                  KilometerA1 = result.routes[0].legs[0].distance.value / 1000;
                                                  KilometerA1Neu = parseFloat(KilometerA1.toFixed(1));
                                                  dauerStau_s = result.routes[0].legs[0].duration_in_traffic.value;
                                                  dauerStau_m = dauerStau_s / 60;
                                                  dauerStau_m1 = parseFloat(dauerStau_m.toFixed(2));
                                                  setState("javascript.0.Verkehr.KilometerA1",KilometerA1Neu);
                                                  setState("javascript.0.Verkehr.FahrtzeitA1",dauerStau_m1);
                                              }
                                          } else log('Fehler (Google Daten Abfrage: ' + error);
                                      });   // Ende request 
                                  }
                                  
                                  

                                  Ist im Prinzip ja nicht weiter schlimm. Es ist glaube ich nur nicht so gut, da der Javascript Adapter komplett neu startet und dementsprechend alle Programme ausgeführt werden.

                                  Kann der Fehler im Script abgefangen werden?

                                  Gruß

                                  Phantomio</anonymous></anonymous>

                                  Geräte: CCU2, RaspberryPi2,

                                  Adapter: email, feiertage, flot, fritzbox, history, hm-rpc.0, hm-rpc.1 (Für Homematic IP), ical, javascript, sayit, scenes, socketio, sonos, tankerkoenig, telegram, text2command, vis, web, yr

                                  1 Reply Last reply
                                  0
                                  • ruhr70R Offline
                                    ruhr70R Offline
                                    ruhr70
                                    wrote on last edited by
                                    #20

                                    @hobbyquaker:

                                    @ruhr70:

                                    früher konnte man mit dem kostenlosen api key von google über die Webschnittstellenicht die Stauzeiten abfragen. Habe es vor ein paar Wochen wieder versucht (per Script). Die Zeiten wechseln zwar, aber nur leicht und nicht so, wie bei Google Maps `

                                    ich frag die Fahrzeiten nach wie vor bei Google ab. Gibt bei mir realistische Ergebnisse aus. Man muss nur eines beachten: Es reicht nicht aus einfach nur Origin und Destination in die Abfrage zu packen, dann wird der Verkehr nicht (richtig?) berücksichtigt. Man muss eine Zwischenstation ("waypoint") mit einbauen, diese kann aber die gleichen Koordinaten haben wie die Destination. Warum auch immer, das weiss wohl nur Google 😉 `

                                    Danke!

                                    Funktioniert jetzt auch. Zwischenstation habe ich eingefügt, allerdings nicht getestet, ob der Schritt notwendig ist.

                                    Grundlegender Fehler bei mir war, dass ich duration.text verwendet habe und nicht duration_in.text :shock: :oops:

                                    327_google_maps.jpg

                                    Die Zwischenstation habe ich mittendrin gewählt, damit auch immer die gleiche Route ausgewertet wird. Die Koordinaten für die Zwischenstation erhält man sauber, wenn man einmal das JSON erzeugen lässt, ohne Zwischenstation.

                                    Danke noch einmal 🙂

                                    327_google_maps_2.jpg

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

                                    O 1 Reply Last reply
                                    0
                                    • bahnuhrB Online
                                      bahnuhrB Online
                                      bahnuhr
                                      Forum Testing Most Active
                                      wrote on last edited by
                                      #21

                                      @ruhr70

                                      kannst du mir mal sagen wie du das mit den datenpunkten gemacht hast?

                                      filename="bild1.jpg" index="0">~~


                                      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 Reply Last reply
                                      0
                                      • ruhr70R Offline
                                        ruhr70R Offline
                                        ruhr70
                                        wrote on last edited by
                                        #22

                                        komme heute aus dem Urlaub zurück. Dann poste ich die Infos

                                        Gesendet von iPhone mit Tapatalk

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

                                        1 Reply Last reply
                                        0
                                        • ruhr70R Offline
                                          ruhr70R Offline
                                          ruhr70
                                          wrote on last edited by
                                          #23

                                          @bahnuhr:

                                          @ruhr70

                                          kannst du mir mal sagen wie du das mit den datenpunkten gemacht hast?

                                          bild1.jpg `

                                          Anbei das Skript, mit dem die Datenpunkte abgefragt und erzeugt werden:

                                          ! ````
                                          // 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
                                          ! // Koordinaten für Zwischenpunkte/Waypoints:
                                          // "Die Koordinaten für die Zwischenstation erhält man sauber, wenn man einmal das JSON erzeugen lässt, ohne Zwischenstation."
                                          ! // verwendet globale individuelle globale Funktionen:
                                          // arbeitstag()
                                          // urlaubstag()
                                          // isTimeInRange()
                                          ! var ldebug = false; // lokale Debugausgabe des Skripts true/false
                                          ! var pfad = "Google_Maps.zur_Arbeit."; // Pfad der anzulegenden ioBroker Objekte
                                          ! var stauStufe1AbMinuten = 5;
                                          var stauStufe2AbMinuten = 8;
                                          var stauStufe3AbMinuten = 12;
                                          ! // Standardzeit in Minuten je Route
                                          //var standardMinuten0 = 25;
                                          ! 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";
                                          ! 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('06:20:00', '07:40: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);

                                          ! ````

                                          Die grafische Darstellung erfolgt mit dem Widget "history - sparkline" und dann den Datenpunkt für die Wegezeit, für den History aktiviert sein muss.

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

                                          1 Reply Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

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

                                          596

                                          Online

                                          32.4k

                                          Users

                                          81.3k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe