Bringebærtank med webgrensesnitt og videostreaming: 8 trinn (med bilder)
Bringebærtank med webgrensesnitt og videostreaming: 8 trinn (med bilder)
Anonim
Bringebærtank med webgrensesnitt og videostreaming
Bringebærtank med webgrensesnitt og videostreaming

Vi skal se hvordan jeg har fått til en liten WiFi -tank, som er i stand til fjernkontroll og videostreaming.

Dette er ment å være opplæring som krever grunnleggende kunnskap om elektronisk programmering og programvare. Av denne grunn har jeg valgt et tankchassisett (i stedet for å skrive det ut med 3D -skriver, kan det være en senere oppgradering) og totalt 6 komponenter inkludert batterier. På programvaresiden kan du følge trinn for trinn installasjonsprosessen og programmeringen holdes på et minimum, en grunnleggende kunnskap om bringebær ting kan hjelpe.

Jeg har estimert 12 timers arbeid fra 0 til tank som er klar til å kjøre. Total kostnad på 70 € for alle komponenter.

Trinn 1: BOM

BOM
BOM
BOM
BOM
BOM
BOM
BOM
BOM

1 - DIY RC Robot Chassis Tank - 32 (€)

www.banggood.com/DIY-RC-Robot-Chassis-Tan…

1 - Dual Channel L298N DC Motor Driver Board - 1, 39 (€)

www.banggood.com/Dual-Channel-L298N-DC-Mo…

1 - Raspberry Pi Zero W Starter Kit - 26 (€)

amzn.eu/1ugAaMP

1 - 16 GB SD -kort - 5, 50 (€)

www.gearbest.com/memory-cards/pp_337819.h…

1 - Raspberry Pi 5MP kameramodul webkamera for Model Zero - 8 (€)

www.gearbest.com/raspberry-pi/pp_612249.h…

1 - Power Bank 5V

1 - 9v batteri

Dupont -kontakt for blandet brødbrett

Mus, tastatur, skjerm eller TV for bringebæroppsett (valgfritt, bare for å gjøre det første oppsettet enklere)

Trinn 2: Spesifikasjoner for hovedkomponenter

Motor

JGA25-370 DC girmotor

Denne motoren har en D-formet utgangsaksel.

Spesifikasjoner

· Driftsspenning: mellom 6 V og 18 V

· Nominell spenning: 12 V

· Friløpshastighet ved 12 V: 399 o / min

· Friløpsstrøm ved 12 V: 50 mA

· Stallstrøm ved 12V: 1200 mA

· Stopp dreiemoment ved 12V: 2,2 kg.cm

· Utvekslingsforhold: 1:21

· Reduktorstørrelse: 19 mm

· Vekt: 84 g

Dual Channel L298N DC Motor Driver Board

Dobbel H-bros motordriver, kan kjøre to likestrømsmotorer eller en 4-leder tofaset trinnmotorer. Innebygd TSD, for å beskytte mot motorstall.

Spesifikasjoner

· Modul forsyningsspenning: DC 2V-10V

· Signalinngangsspenning: DC 1,8-7V

· Enkel arbeidsstrøm: 1,5A

· Toppstrøm opptil 2,5A

· Lav standby -strøm (mindre enn 0,1 uA)

· Innebygd felles ledningskrets, inngangsterminalen er ledig, motoren fungerer ikke

· Størrelse: 24,7 x 21 x 7 mm

Trinn 3: KOBLING

KOBLING
KOBLING
KOBLING
KOBLING

Dette blir den siste ledningen, men VENT, før vi må installere noen

programvare, og det er en god idé å teste den med enklere ledninger når de er klare som kommer tilbake hit.

Vi trenger to forskjellige strømkilder, en for motoren og en for bringebæret.

Motordriveren Dual Channel L298N DC Motor Driver Board (maks inngangsspenning DC 2V-10V) drives av 9V-batteriet og Raspberry Pi bruker standard 5V USB-akkumulator.

GND -pinnen til motordriveren kobles til batteriet minus og Raspberry Pi (GND). GPIO -pinnene på Raspberry Pi er koblet til motordriveren som bord.

Trinn 4: FORBEREDE RASPBERRY O. S

Dette er en standard installasjon for Raspbian operativsystem, du finner

mye detaljert opplæring som søker på nettet, i utgangspunktet er trinnene:

1. Last ned iso RASPBIAN STRETCH WITH DESKTOP fra

2. Formater et 16 GB SD -kort, jeg har brukt SD -formater

3. Brenn. IMG -fil, jeg har brukt Win32DiskImager

Nå er bringebæret ditt klart til oppstart, koble det til en USB -strømkilde (5V, 2A) og forbered deg på første oppstart. Du kan gjøre det på to måter ved å bruke eksterne enheter som mus, tastatur og skjerm eller ved hjelp av PC -en og en ekstern tilkobling til Raspberry. Det er mye opplæring om dette, den ene er:

Trinn 5: HVORDAN KONTROLLERER DU WIFI -TANKEN MED NODE. JS OG WEBSOCKET. IO

SLIK KONTROLLERER DU WIFI -TANKEN MED NODE. JS OG WEBSOCKET. IO
SLIK KONTROLLERER DU WIFI -TANKEN MED NODE. JS OG WEBSOCKET. IO

Nå har vi en ny installasjon av vår bringebærmikro -PC klar til å kjøre jobben vår, så … hva bruker vi for å sende kommandoer til tanken?

Python er et veldig brukervennlig språk som vanligvis brukes til å kjøre Rapsberry -prosjektsand, som enkelt kan brukes også til å samhandle med Rapsberry input- og output pins (GPIO)

Men målet mitt var å koble tanken til wi-fi fra hvilken som helst enhet (PC, mobiltelefon, nettbrett …) ved å bruke en vanlig nettleser og også streame video fra den. Så, glem Python for nå, og la oss fortsette NODE. JS og SOCKET. IO.

NODE.js

Node.js (https://github.com/nodejs/node/wiki) er et serverprogram med åpen kildekode basert på js -språk. Siden jeg bruker Raspberry Pi Zero (ARMv6 CPU) kan vi ikke bruke den automatiske installasjonsprosessen (beregnet for ARMv7 CPU), og vi må gjøre det manuelt:

Last ned Nodejs lokalt, (jeg har brukt 7.7.2 versjon for ARMv6, sjekk andre versjoner her

pi@bringebær: ~ $ wget

nodejs.org/dist/v7.7.2/node-v7.7.2-linux-…

Når du er ferdig, trekker du ut den komprimerte filen:

pi@bringebær: ~ $ tar -xzf node-v7.7.2-linux-armv6l.tar.gz

Kopier og installer filene i /user /local

pi@bringebær: ~ $ sudo cp -R node-v7.7.2-linux-armv6l/*/usr/local/

Legg til stedet der vi installerer nodejs til banen, rediger ".profile" -fil:

pi@bringebær: ~ $ nano ~/.profil

Legg til følgende linje på slutten av filen, lagre og avslutt

PATH = $ PATH:/usr/local/bin

Fjern den nedlastede filen:.

pi@bringebær: ~ $ rm ~/node-v7.7.2-linux-armv6l.tar.gz

pi@bringebær: ~ $ rm -r ~/node-v7.7.2-linux-armv6l

Skriv inn følgende kommandoer for å kontrollere nodejs -installasjonen:

pi@bringebær: ~ $ node -v

pi@bringebær: ~ $ npm -v

Du bør lese v7.7.2 og v4.1.2 som svar.

Hvis alt gikk bra, kan du opprette en ny mappe for å være vert for nodejs -filene dine:

pi@bringebær: ~ $ mkdir nodehome

Flytt inn i ny mappe:

pi@bringebær: ~ $ cd nodehome

Installer tilleggsmodul som kreves for å administrere GPIO på den mest grunnleggende måten, PÅ og AV:

pi@bringebær: ~ $ npm installer onoff

Nå er det på tide å teste vårt første prosjekt “Blink.js”, resultatet blir… en blinkende LED

pi@bringebær: ~ $ nano blink.js

Lim inn følgende kode, lagre og avslutt:

var Gpio = require ('onoff'). Gpio; // inkludere onoff

var LED = ny Gpio (3, 'out'); // bruk GPIO 3

var blinkInterval = setInterval (blinkLED, 250);

// blink LED hver 250 ms

funksjon blinkLED () {// funksjon for å begynne å blinke

hvis

(LED.readSync () === 0) {// sjekk pin -tilstanden, hvis tilstanden er 0 (eller av)

LED.writeSync (1);

// sett pin -tilstand til 1 (slå på LED)

} annet {

LED.writeSync (0);

// sett pin -tilstanden til 0 (slå av LED -en)

}

}

function endBlink () {// funksjon for å slutte å blinke

clearInterval (blinkInterval); // Stopp blinkintervaller

LED.writeSync (0); // Slå av LED -en

LED.unexport (); // Ueksporter GPIO til gratis ressurser

}

setTimeout (endBlink, 5000); // slutte å blinke etter 5 sekunder

Koble til en LED, en motstand (200 ohm) som vist i skjemaet og kjør prosjektet:

pi@bringebær: ~ $ node blink.js

Noden er klar.

SOCKET. IO

WebSocket er en datakommunikasjonsprotokoll, basert på TCP -tilkobling, den gir en programmerer for å lage en server og klient. Klienten kobler seg til serveren og sender og mottar meldinger til og fra serveren. WebSocket -implementering for Node.js kalles Socket.io (https://socket.io/).

Installer socket.io:

pi@bringebær: ~ $ npm installer socket.io -lagre

Flytt inne i nodejs hjem, opprettet tidligere:

pi@bringebær: ~ $ cd nodehome

Og lag en ny mappe "offentlig":

pi@bringebær: ~ $ mkdir public

Lag en ny nettserver, kall den "webserver.js"

pi@bringebær: ~ $ nano webserver.js

Lim inn følgende kode, lagre og avslutt:

var http = require ('http'). createServer (handler); // krever http -server, og opprett server med funksjonsbehandler ()

var fs = krever ('fs'); // krever filsystemmodul

http.listen (8080); // lytt til port 8080

funksjonsbehandler (req, res) {// opprett server

fs.readFile (_ dirname + '/public/index.html', function (err, data) {// read

filindeks.html i offentlig mappe

hvis (feil) {

res.writeHead (404, {'Content-Type': 'text/html'}); // display 404 on error

returner res.end ( 404 Ikke

Funnet );

}

res.writeHead (200, {'Content-Type': 'text/html'}); // skrive HTML

res.write (data); // skrive data

fra index.html

returnere res.end ();

});

}

Denne webserveren vil lytte til bringebærporten 8080 og gi fil for enhver webklient som kobler den til. Nå må vi lage noe å være vert for og tilby våre kunder: Flytt inne i "offentlig" mappe: pi@raspberry: ~ $ cd public

Lag en ny html -fil “index.html”:

pi@bringebær: ~ $ nano index.html

Lim inn koden fra vedlagte "HelloWorld.txt", lagre og avslutt.

Flytt inne i nodejs -mappen "nodehome":

pi@bringebær: ~ $ cd nodehome

Start HTTP -webserver:

pi@bringebær: ~ $ node webserver.js

Åpne nettstedet i en nettleser ved å bruke https:// Raspberry_IP: 8080/(erstatt Raspberry_IP med din IP)

Trinn 6: LEGG TIL VIDEO STREAMING -KAPASJON

Det er forskjellige måter å implementere videostreaming på en bringebær, den enkleste

slik jeg har funnet ut til nå, er det at god ytelse og kan integreres i et webgrensesnitt er basert på prosjektet fra Miguel Mota:

miguelmota.com/blog/raspberry-pi-camera-bo…

Takk Miguel! Fra bloggen hans er dette trinnene:

Installer komponentene libjpeg8 og cmake:

pi@bringebær: ~ $ sudo apt-get install libjpeg8

pi@bringebær: ~ $ sudo apt-get install libjpeg8-dev

pi@bringebær: ~ $ sudo apt-get install cmake

Last ned mjpg-streamer med raspicam-plugin:

pi@bringebær: ~ $ git klon

github.com/jacksonliam/mjpg-streamer.git ~/mjpg-streamer

Endre katalog:

pi@bringebær: ~ $ cd ~/mjpg-streamer/mjpg-streamer-eksperimentell

Kompilere:

pi@bringebær: ~ $ gjør alt rent

Erstatt gammel mjpg-streamer:

pi@bringebær: ~ $ sudo rm -rf /opt /-j.webp

pi@bringebær: ~ $ sudo mv ~/mjpg-streamer/mjpg-streamer-eksperimentell

/opt/mjpg-streamer

pi@bringebær: ~ $ sudo rm -rf ~/mjpg -streamer

Lag en ny “start_stream.sh” -fil, kopier og lim inn fra vedlagte “start_stream.txt” -fil.

Gjør det kjørbart (lag skallskript):

pi@bringebær: ~ $ chmod +x start_stream.sh

Start streaming av server:

pi@bringebær: ~ $./start_stream.sh

Åpne nettstedet i en nettleser ved å bruke https:// Raspberry_IP: 9000 (erstatt Raspberry_IP med din IP)

Trinn 7: TANKPROGRAM

Alt er klart, nå må vi lage vår webside for å kontrollere tanken (index.html) og vår webserver for å lytte til kommandoene våre (webserver.js). Så, bare erstatt filene som er sett til nå (bare eksempler for å teste systemet) med den vedlagte webserver.txt og index.txt.

Trinn 8: START KONTROLLGRensesnittet OG STREAMING SERVER

START KONTROLLGRensesnittet OG STREAMING SERVER
START KONTROLLGRensesnittet OG STREAMING SERVER

For å starte tjenestene, åpne to terminalvinduer og kjør disse kommandoene:

node nodehome/webserver.js

./nodehome/start_stream.sh

Åpne nettstedet i en nettleser ved å bruke https:// Raspberry_IP: 8080 (erstatt Raspberry_IP med din IP)

Anbefalt: