EAL - Raccolta dati GPS Industry 4.0 su auto Rc: 4 passaggi
EAL - Raccolta dati GPS Industry 4.0 su auto Rc: 4 passaggi
Anonim
EAL - Raccolta dati GPS Industry 4.0 su auto Rc
EAL - Raccolta dati GPS Industry 4.0 su auto Rc
EAL - Raccolta dati GPS Industry 4.0 su auto Rc
EAL - Raccolta dati GPS Industry 4.0 su auto Rc

In questo Instructable parleremo di come configuriamo un modulo GPS su un'auto RC e pubblichiamo i dati raccolti su una pagina Web per un facile monitoraggio. In precedenza abbiamo creato un'istruzione su come abbiamo realizzato la nostra auto RC, che può essere trovata qui. Questo utilizza la stessa build, anche se abbiamo deciso di eliminare i sensori a ultrasuoni e applicare invece il modulo GPS. Nel progetto abbiamo impostato un database che contiene i dati GPS e creato una pagina web in cui i dati possono essere trovati, oltre ad averla applicata a una mappa, in modo da poter vedere dove è stata l'auto. Visita Joerha.dk per visualizzare la pagina web.

Nel diagramma di flusso in alto, puoi vedere una panoramica delle tecnologie che sono state utilizzate in questo progetto. Per ottenere il massimo da questo Instructable, è necessario avere familiarità con alcune, se non tutte, le tecnologie utilizzate. È collegato in base all'utilizzo. Anche avere una comprensione di Github aiuterà, poiché ci siamo collegati ai nostri repository github.

Elenco delle utenze:

  • Github
  • Raspberry PI/Raspbian

    Pitone

  • Nodo.js

    • Express.js
    • Sequelize.js
    • MySQL
  • HTML, CSS, JS

    Bootstrap

Passaggio 1: configurazione del database

Configurazione del database
Configurazione del database

In questo segmento parleremo di come costruiamo il sistema di database da cui vengono estratti i nostri dati GPS. Il database è costruito in MySQL secondo l'immagine sopra, dove abbiamo due tabelle: "Utenti" e "GPSEntries". Negli utenti abbiamo "Id" come chiave primaria. Viene utilizzato come identificatore univoco. "Nome" è il nome dell'utente attualmente connesso. "Apikey" è la chiave univoca fornita all'utente per accedere all'API. "Attivo" serve a verificare se l'utente è attivo, possiamo disattivare l'utente, quindi non può accedere al database. "CreatedAt" e "UpdatedAt" sono creati dal processo che abbiamo usato per costruire il database.

Nella tabella “GPSEntries” abbiamo tutti gli attributi contenenti i dati del modulo GPS. "Time" è l'ora corrente del modulo GPS, la usiamo per mostrare l'ora della pubblicazione. Quindi abbiamo la posizione in coordinate, oltre a "velocità" e "direzione". Abbiamo anche molti attributi di errore, che mostrano se c'è un errore nei dati del GPS, fx nelle coordinate. Li abbiamo aggiunti al database, ma non li mostriamo nella pagina web. "UserId" è una chiave esterna che contiene "id" dalla tabella Users. Viene utilizzato per mostrare quale utente ha pubblicato i dati.

Passaggio 2: API

API
API

In questo segmento parleremo dell'API che controlla il database e vi incolla i dati. L'API Web è costruita con Node.js, che utilizza Express.js e Sequalize.js.

Node.js viene utilizzato per eseguire JavaScript lato server, dove normalmente viene utilizzato principalmente per lo scripting lato client su una pagina Web.

Express.js è il framework che abbiamo utilizzato per creare l'API.

Sequalize.js viene utilizzato per creare i collegamenti tra i dati Gps e gli attributi del database. Usa un metodo chiamato ORM (Object-Relational Mapping) per farlo. Qui è anche dove vengono creati "CreatedAt" e "UpdatedAt" (mostrato nel passaggio 1).

L'API può essere utilizzata visitando api.joerha.dk. Quindi aggiungi /gps all'URL, che mostrerà tutti i dati nel database in formato JSON. Per controllare quante voci desideri, puoi aggiungere /2 (l'utente) e /x (numero di voci) all'URL. Fx api.joerha.dk/gps/2/10 mostrerà le ultime 10 voci. Un outtake dei dati formattati è mostrato nell'immagine sopra.

Il codice può essere trovato qui: Github

Passaggio 3: applicazione GPS/Python

Applicazione GPS/Python
Applicazione GPS/Python
Applicazione GPS/Python
Applicazione GPS/Python
Applicazione GPS/Python
Applicazione GPS/Python

In questo segmento parleremo dello script che viene eseguito sul raspberry e raccoglie i dati GPS e li invia all'API.

Per raccogliere i dati dal GPS stiamo usando un demone chiamato gpsd (Immagine 1). Qui è dove raccogliamo i dati che pubblichiamo nel database e la base per la nostra tabella GPSEntries. Lo script che estrae i dati da gpsd e li invia all'API è scritto in python.

L'applicazione inizializza un thread, quindi può eseguire sia gpsd che il nostro programma contemporaneamente. I dati Gpsd vengono trasmessi continuamente mentre il GPS è attivo (Immagine 2).

Quindi creiamo un ciclo while che invia continuamente il suo carico utile all'API contenente i dati GPS. I dati sono formattati come JSON. Il payload è costituito dagli attributi visti nel GPSD. Il tag.fix agisce come un'istantanea dei dati correnti e lo invia all'API. Questo viene fatto da request.post e utilizza l'URL e la chiave API. Print (r.status_code) viene inviato all'utente per sapere se i dati sono stati trasmessi correttamente. Time.sleep (0,5) è la frequenza con cui vengono pubblicati i dati (Immagine 3)

Il codice può essere trovato qui: Github

Passaggio 4: pagina Web per il progetto

Pagina web per il progetto
Pagina web per il progetto

In questo segmento parleremo di come abbiamo realizzato la nostra pagina web che mostra i dati e altre informazioni sul progetto. Il sito è costruito con HTML, CSS e JS. Per cominciare abbiamo usato Bootstrap 4.0, che è una libreria per HTML, CSS e JS. Viene fornito con molte funzioni che ti aiutano a costruire il tuo sito web. Lo abbiamo usato per la barra di navigazione in alto, così come per l'impostazione di righe e colonne con cui è costruito il sito. Poi abbiamo un altro piccolo script CSS che controlla i colori dello sfondo e delle intestazioni. Inoltre, abbiamo utilizzato una libreria chiamata lightbox, quindi puoi fare clic sulle immagini e si aprono. I contenuti del sito contengono una mappa di google, una tabella di dati, un video dell'auto in azione e un link a questa stessa pagina.

La mappa di google è la più interessante. La mappa viene caricata tramite un'API di Google, in cui viene inserita una chiave API univoca affinché funzioni. I dati vengono trasmessi alla mappa in un intervallo di 500 ms. Abbiamo creato una funzione in cui gli ultimi 100 punti dati nel database sono mostrati come marcatori, così puoi seguire dove è stata l'auto. Questo viene fatto attraverso quella che viene chiamata una chiamata AJAX.

I set di dati nella tabella dei dati GPS vengono richiesti allo stesso modo. Nella tabella puoi vedere le ultime 10 voci, aggiornate in tempo reale quando il GPS è attivo. Recuperiamo i dati dal database in un intervallo di 500 ms.

Il codice può essere trovato qui: Github

Consigliato: