Kontrollere 7-segmenters LED-skjerm ved hjelp av ESP8266 webserver: 8 trinn (med bilder)
Kontrollere 7-segmenters LED-skjerm ved hjelp av ESP8266 webserver: 8 trinn (med bilder)
Anonim
Kontrollere 7-segmenters LED-skjerm ved hjelp av ESP8266 webserver
Kontrollere 7-segmenters LED-skjerm ved hjelp av ESP8266 webserver

Mitt prosjekt har en Nodemcu ESP8266 som styrer en 7-segmenters skjerm gjennom http-serveren ved hjelp av html-skjema.

Trinn 1: OM DETTE PROJEKTET

Det er et IOT -prosjekt utviklet ved bruk av ESP8266 (NodeMCU) wifi -modul. Motivet for prosjektet er å lage en webserver på modulen som kan være vert for flere klienter over nettverket. Her er grunnleggende kunnskap om html og javaScript nødvendig for å forstå prosjektet mitt. Noen forhåndstemaer som jeg vil diskutere her angående ESP8266 og javaScript er:

1. Last opp filer på SPIFFS i ESP8266 for å bruke disse filene mer effektivt i arduino -koden.

2. Nettlagring ved hjelp av javaScript

SPIFFS

Hittil har vi alltid tatt med HTML -en for nettsidene våre som strenglitteraler i skissen vår. Dette gjør koden vår veldig vanskelig å lese, og du kommer til å gå tom for minne ganske raskt.

SPIFFS er et lett filsystem for mikrokontrollere med en SPI-flashbrikke. Den innebygde flash-brikken til ESP8266 har god plass til nettsidene dine, spesielt hvis du har 1 MB, 2 MB eller 4 MB versjon. Du kan forstå hvordan du legger til verktøy i arduino -programvaren for å laste opp filer til SPIFFS ved å følge lenken:

I dette prosjektet har jeg 2 html -filer og en javascript -fil. Alle disse filene lastes opp til SPIFFS atskilt fra skissen slik at endringen i disse filene er uavhengig av hovedskissen.

Begge html -filene hentes av preparFile () som vist nedenfor:

void preparFile () {

bool ok = SPIFFS.begin (); hvis (ok) {File f = SPIFFS.open ("/index.html", "r"); Fil f1 = SPIFFS.open ("/index1.html", "r"); data = f.readString (); data1 = f1.readString (); f.close (); f1.close (); } else Serial.println ("Fant ingen slik fil."); }

mens javascript -filen leses ved hjelp av loadScript () som vist nedenfor:

void loadScript (strengbane, strengtype) {

if (SPIFFS.exists (path)) {File file = SPIFFS.open (path, "r"); server.streamFile (fil, type); }}

LOKAL LAGRING FOR WEB -SØKNADER

Du kan forstå hvordan du bruker forskjellige objekter og metoder for lokal lagring i HTML5 ved å bruke javascript fra følgende artikkel: https://diveintohtml5.info/storage.html. Jeg vil diskutere bruken av lokal lagring i prosjektet mitt i arbeidsdelen.

Trinn 2: Maskinvare nødvendig

NodeMCU ESP8266 12E Wifi -modul

Loddefritt brødbrett

Jumper wire

7 segmentvisning (vanlig katode)

1K ohm motstand

Mikro-USB-kabel (for tilkobling av NodeMCU til datamaskinen)

Trinn 3: Krets og tilkoblinger

Krets og tilkoblinger
Krets og tilkoblinger

Tilkoblingene er veldig enkle. I kretsdiagrammet ovenfor er pins av nodemcu koblet på følgende måte:

En D1

B D2

C D3

D D4

E D6

F D7

G D8

hvor A, B, C, D, E & F er segmentene i 7Segment Display

. Ignorer DP for 7 -segmentet Display. Ikke koble den til pin D5 på ESP

Trinn 4: ARBEID

JOBBER
JOBBER

Som diskutert tidligere har vi to html -filer. En av dem er root -html -siden som ble kalt da ESP8266 -serveren mottok "/" dvs. Hvis URI '/' blir forespurt, bør serveren svare med en HTTP -statuskode på 200 (Ok) og deretter sende et svar med "indeksen". html "-fil.

Den andre html -filen vil bli sendt når klienten ber om fra rotsiden ved å sende inn en innspill på skjemaet. Så snart, serveren får inngangen POSTET fra skjemaet, den sammenligner den med fast strengverdi og sender den andre html -siden som svar.

if (server.arg ("nam") == "0") {server.send (200, "text/html", data1); sevenSeg (0); }

Siden html for andre side ikke er definert i skissen, så her refererer vi til "data1" som allerede er lest html -kodene ved hjelp av SPIFFS.readString ()

Fil f1 = SPIFFS.open ("/index1.html", "r"); data1 = f1.readString ();

Her kalles sevenSeg () også med et argument "0" slik at det kan brukes til å vise "0" ved å slå forskjellige segmenter PÅ og AV. Her gjorde jeg navnet på fuction selvforklarende, dvs. onA () vil slå på A -segmentet på 7 seg -displayet på brødbrettet, på samme måte vil A slå det av.

Så, i dette tilfellet for å vise "0", må vi bytte alt segment bortsett fra G (DP ignoreres da det ikke er koblet til noen pinne av ESP8266). Så min funksjon ser ut som:

hvis (num == 0) {onA (); onB (); onC (); onD (); en(); onF (); offG (); }

Trinn 5: HTML- og JAVASCRIPT -KODE

HTML & JAVASCRIPT KODE
HTML & JAVASCRIPT KODE

Index.html har et lerret med 7 segmentvisning i av -modus og skjema under den. Dette ser du etter å ha åpnet den:

Hvis vi ønsker å bruke nettsiden vår uten ESP8266, vil det være mulig ved å endre lenken i handlingsattributtet til skjemaet ditt. For øyeblikket er dette lenken i aksjon:

Her kan du se at koblingen i aksjon er den samme ip -adressen som er tildelt nodeMCU etter tilkobling til hvilken som helst wifi (eller hotspot). Skjemaetiketten etter justering ser slik ut:

Her bruker jeg nettleseren i nettleseren til å lagre inngangsverdien til brukeren slik at verdien som er angitt i index.html lagres i nettleseren lokalt (som informasjonskapsel). Denne verdien hentes av index1.html og tallet vises på 7 -segmentet på html -lerret. Du kan forstå denne fremgangsmåten ved å følge videoen:

video_attach

Trinn 6: NØKKELNOTER

Dette prosjektet vil fungere med nodemcu hvis du tar vare på følgende punkter:

1. Lenken i handlingsattributtet til root -html -filen skal være "https:// (IP på seriell skjerm eller IP tilordnet ESP)/send".

2. Bruk siste versjon av nettleseren som støtter html5 og nye koder og funksjonalitet.

3. SPIFFS fungerer bare hvis index.html, index1.html og main.js er satt sammen i datamappen. Du kan klone kodefilen fra min github

Trinn 7: KODE

KODE
KODE

Dette er depotkoblingen til koden til prosjektet mitt. Hvis du jobber med SPIFFS i ESP8266, kan du forstå hvorfor jeg har plassert html- og javascript -filene i datamappen. Bruk det som det er det.

GitHub Repository Link

Trinn 8: Videoopplæring

Hvis det hjelper, må du abonnere