Google Home -kontrollerte lysdioder: 8 trinn
Google Home -kontrollerte lysdioder: 8 trinn
Anonim
Google Home -kontrollerte lysdioder
Google Home -kontrollerte lysdioder
Google Home -kontrollerte lysdioder
Google Home -kontrollerte lysdioder

I det siste har jeg hatt mye ledig tid på hendene, så jeg har jobbet med en haug med prosjekter.

Dette prosjektet lar deg kontrollere RGB -lysdioder via Google Home ved hjelp av en Raspberry Pi. Nå er det 3 deler av prosjektet, å sette opp en Raspberry Pi, konfigurere Google Home med en tilpasset kommando ved hjelp av IFTTT, og deretter lage en krets for lysene. Jeg lagde kretsen selv, men jeg vedder på at du kan få noe fra Adafruit som gjør det som trengs.

Materialer til Raspberry Pi Part

  • Raspberry Pi - alle vil fungere, men jeg bruker en Zero
  • Trådløs dongle - hvis Pi ikke har innebygd Wifi
  • Google Home - Valgfritt hvis du har Google Assistant på telefonen

Materialer for kretsdel- Ikke la dette avskrekke deg … Det er ganske enkelt

  • Protoboard
  • Metalltråd
  • LED -stripe
  • 12V strømforsyning - Alt over 2 ampere bør være greit
  • DC Barrel Jack - Samme størrelse som strømforsyningen
  • NPN BJT Power Transistors (x3) - Jeg bruker TIP31C
  • Mann og kvinne Pin Headers - Valgfritt, men anbefales på det sterkeste

Trinn 1: Last ned Express for Pi

Last ned Express for Pi
Last ned Express for Pi

Jeg kommer ikke til å gå i detalj med å sette opp Pi fordi det er så mange opplæringsprogrammer der ute for å sette dem opp.

Det du trenger å gjøre som jeg ikke dekker …

  • Blinkende Raspberry Pi med nyeste Raspbian
  • Sett opp nettverkskortet slik at du får tilgang til internett fra Pi
  • Angi en statisk IP på Raspberry Pi

Nå er det her moroa begynner! Vi må installere nodeJS, npm, express og express-generator.

sudo apt-get oppdatering

sudo apt-get install nodejs npm

Når de er installert, kjører du følgende

npm installer ekspress ekspressgenerator

Express lar deg lage en helt grunnleggende webserver for din Raspberry Pi å bruke. Express-generator genererer bare filer automatisk for en ekspress-server.

Lag en katalog og cd til katalogen. Jeg kalte min piWebpage. Kjør nå følgende (sett på bildet også)

mkdir piWebpage

cd piWebpage express --view = ejs webApp

Dette vil generere en mappe som heter webApp med alle ekspressfilene i den. Hvis du planlegger å gjøre mer med denne nettsiden senere, og du liker PUG, kan du erstatte --view = ejs med --view = pug. Vi kommer ikke til å berøre nettsiden, så for denne applikasjonen spiller det ingen rolle hva vi bruker.

Trinn 2: Oppsett av Pi -server

Flytt til den nye webApp -katalogen.

cd webApp

npm installere

npm install vil ta litt tid fordi det installerer alle avhengighetene for express.

Lim inn setColor.py i webApp -mappen. Denne filen har noen forhåndsinnstillinger for grunnfarger. Legg gjerne til flere som du vil. Området er 0 til 255 hvor 255 er i full farge. På et tidspunkt vil jeg sannsynligvis legge til muligheten til å dempe lysene, men foreløpig er de full lysstyrke.

Gå inn på ruter

cd -ruter

Nå erstatt index.js med filen vedlagt. Dette vil legge til noen linjer for å motta en POST -kommando, som er hva Google Home sender. Fra den POSTEN får vi valgt fargen og ber Pi om å kjøre setColor python -skriptet for å justere lysene.

En siste ting … Gå tilbake til webApp -mappen.

cd ~/piWebpage/webApp

Bruk favorittredigereren til å lime inn og lagre koden nedenfor i webApp.js. Hvor som helst er fint så lenge det er før "module.exports = app;"

// Oppsett LED -maskinvare driverconst {exec} = require ('child_process'); exec ('sudo pigpiod', (err, stdout, stderr) => {if (err) {console.log ('Error loading LED Driver'); return;} else console.log ('LED Driver Successfully Loaded'); });

Som kommentaren sier, er pigpiod maskinvaredriveren for PWM -signaler som vi vil bruke til å justere LED -fargene. Jeg tror den allerede er installert i Raspbian, men hvis ikke …

sudo apt-get install pigpiod

Nå til den virkelige testen! Starter serveren!

DEBUG = webapp:* npm start

Trinn 3: IFTTT -oppsett (utløser)

IFTTT -oppsett (utløser)
IFTTT -oppsett (utløser)
IFTTT -oppsett (utløser)
IFTTT -oppsett (utløser)

IFTTT kan gjøre mye, og jeg vil anbefale å se deg rundt på noen av applikasjonene.

Først må du opprette en konto. Bruk den samme Google -kontoen som er knyttet til Google Home, ellers synkroniseres de ikke sammen. Når du er ferdig og logget inn, klikker du øverst til høyre på IFTTT -siden der den viser navnet ditt og avataren din. Klikk deretter på Ny applett fra rullegardinmenyen.

Hvis du er nysgjerrig, står IFTTT for IF This Then That hvis du ikke la merke til det på skjermen som dukker opp. Så det vi ønsker er If Google Assistant, så Webhook som våre alternativer.

Fortsett ved å klikke +dette som vil laste inn en søkefelt. Skriv inn Google Assistant i søket og klikk på ikonet under søket.

I Velg en utløser velger du det tredje alternativet som heter Si en setning med en tekstingrediens. Nå lar dette deg ha 3 kommandoer som gjør den samme handlingen. Du legger til $ i setningen der du vil nevne fargen. For eksempel, hvis jeg naturligvis ville si Hey Google, Set LEDs Blue (like naturlig som å rope på en enhet kan være), så ville jeg skrevet inn i feltet Set LEDs $. Gjør det for alle tre feltene med forskjellige versjoner av kommandoen.

De 3 jeg brukte var

Lysdioder $

Sett lysdioder $

Still inn LED -farge $

Det siste feltet er hva du vil at Google Home skal svare etter å ha sagt kommandoen din. Det kan være hva du vil, men jeg brukte Angi farge til $. $ Betyr at hun vil gjenta fargen tilbake.

Klikk på Opprett utløser

Trinn 4: IFTTT -oppsett (handling)

IFTTT -oppsett (handling)
IFTTT -oppsett (handling)
IFTTT -oppsett (handling)
IFTTT -oppsett (handling)

Etter å ha klikket på Opprett utløser, laster du tilbake til hvis dette er den visningen, men dette er blitt erstattet med Google Assistant -logoen. Fortsett ved å klikke +det

Det samme som før, der det tar deg til søkefeltet. Skriv inn Webhooks og klikk på webhook -ikonet under søkefeltet. Under Velg handling for Webhooks er det bare ett alternativ, så klikk på Lag en webforespørsel.

Her blir det litt vanskelig. Fordi Google ikke er en annen datamaskin i huset ditt, trenger du din eksterne IP -adresse. Dette vil kreve en viss portvideresending, men vi kommer inn på det senere. For å få din eksterne IP -adresse, gå til

I URL -feltet skriver du inn https://xxx.xxx.xxx.xxx:3000/{{TextField}} (med x -er din eksterne IP -adresse). Hvis du er nysgjerrig, vil TextField ha fargen du valgte når du lager en kommando. Grunnen til at vi bruker 3000 er fordi det er porten Raspberry Pi Express -serveren kjører på. (Du kan endre porten i koden, men vi bruker bare standardinnstillingene for Express)

For metode, velg POST.

For innholdstype, velg tekst/ren.

Skriv inn {{TextField}} for Body

Dere av dere som vet hvordan en POST -kommando fungerer, ville du tro at hvis du analyserer kroppsegenskapen til forespørselen om at du ville få fargen. Av en eller annen grunn blir det aldri lagt noe inn i kroppsfeltet til forespørselen, så jeg analyserer faktisk URL -en for fargen. Håper det blir fikset snart, da det ville forenkle koden min i index.js -ruten. Men jeg går unna.

Til slutt klikker du på Opprett handling og deretter Fullfør på neste side. (Jeg har slått av varsler, men det er preferanse)

Trinn 5: Videresending av porter

Videresending av havner
Videresending av havner
Videresending av havner
Videresending av havner

Det er her ting blir vanskelig å forklare fordi alle rutere er forskjellige …

Nå har vi Google som sender en kommando til huset vårt ved hjelp av port 3000, men den vet ikke hvilken enhet på LAN -en den må gå til. For å bøte på dette må vi videresende port 3000 til den lokale IP -adressen til din Raspberry Pi.

Gå inn på ruteren din med enten 10.0.0.1 eller 192.168.1.1 (jeg har også sett det der det siste sifferet er 254) og finn portvideresending. I portvideresending, på samme måte som bildet, navngir du en ny enhet (IFTTT) og videresender porten (3000) til Pi -IP -adressen (i mitt tilfelle 10.0.0.11).

Lagre den nye innstillingen, start ruteren på nytt og kontroller at Raspberry Pi -serveren din fortsatt kjører. Hvis den ikke kjører, start den på nytt.

Gå tilbake til det praktiske nettstedet https://canyouseeme.org/. Under din IP -adresse har den en portkontroll. Forutsatt at portvideresending er riktig, skriver du inn 3000 og trykker på sjekkporten. Det burde komme tilbake med en suksess.

Trinn 6: Kontroller arbeidet ditt så langt

Sjekker arbeidet ditt så langt
Sjekker arbeidet ditt så langt
Sjekker arbeidet ditt så langt
Sjekker arbeidet ditt så langt

Nå … det øyeblikket du har ventet på … Fortell Google en kommando som blå LED (hvis du fulgte mitt eksempel).

Forutsatt at alt gikk riktig, får du utgangen sett på bildet. Vi har ikke en krets ennå, så alt du ser er tekst på en skjerm. Det er vanligvis et sekund eller to forsinkelser før det behandles fra Google og vises på Pi.

(Gå til neste trinn hvis dette kom ut på samme måte som bildet)

Nå er det et par ting å se på hvis det ikke fungerte …

På bildet er det en linje som sier

POST /farge /blå 200 250,458 ms - 2

200 er den viktige delen. Hvis du ikke ser en 200, så var det en dårlig POST som betyr at serveren din ikke visste hva han skulle gjøre med dataene. Gå tilbake til trinn 2 og sjekk filen index.js.

Også på bildet

stdout: blå

stderr:

Dette er utdataene fra python -filen som kjører lysdiodene. Hvis du ser en feil der, kan det være at du ikke har driveren installert på trinn 2.

Til slutt, hvis ingenting dukket opp i det hele tatt … kan det hende at IFTTT ikke var riktig konfigurert eller ikke klarte å koble til serveren. Gå tilbake til IFTTT -siden, og klikk på Aktivitet i den øverste navigeringslinjen. Der inne kan du se hver gang appen din har kjørt, og hvis det var en feil, kan du se hva den var. Jeg lagde en Google -kommando med Pi -serveren av og fikk feilen i bildet.

Trinn 7: Bygg kretsen

Bygg kretsen
Bygg kretsen
Bygg kretsen
Bygg kretsen
Bygg kretsen
Bygg kretsen

Grunnen til at vi må gjøre dette er fordi Raspberry Pi ikke har nok strøm … Så løsningen er … MER KRAFT (Tim verktøymannen Taylor knurrer i det fjerne). AKA en annen strømforsyning (12V 2A)

Materialer for kretsdel

  • Protoboard
  • Metalltråd
  • RGB LED -stripe
  • 12V strømforsyning - Alt over 2 ampere bør være greit
  • DC Barrel Jack - Samme størrelse som strømforsyningen
  • NPN BJT Power Transistors (x3) - Jeg bruker TIP31C
  • Mannlige og kvinnelige pinhoder

Ved å bruke det praktiske bildet jeg stjal fra interwebs med GPIO på Pi Zero, kan du se GPIO17, GPIO18 og GPIO 27 er like ved siden av hverandre med en GND. Vi kommer til å bruke den firkanten på 4 pins (pins 11, 12, 13, 14).

For det første vil jeg anbefale lodding av mannlige overskrifter på LED -stripen din som vist på bildet (ikke mitt beste arbeid). Dette gjør det enkelt å koble fra hvis du trenger det. Jeg brukte kvinnelige hoder for tilkobling av LED -stripen til protoboardet og mannlige hoder fra protoboardet til Raspberry Pi. (Bruk alltid kvinnelige tilkoblinger for strøm/signalkilde). Du trenger ikke å flytte alle Pi -pinnene ved siden av hverandre som jeg gjorde … Jeg ville bare at det skulle se rent ut, men det var mye arbeid.

Kretsforklaring

For de av dere som ikke er kjent med transistorer, er transistorer i utgangspunktet en digital bryter. GPIO -pinnene fra Pi utløser de tre bryterne (rød, grønn og blå). Når vi ser spesifikt på RØD i kretsdiagrammet, når GPIO_17 er på, "stenger" bryteren som kobler RØD til GND, noe som får de røde lysene til å tenne. Når GPIO_17 slås av, er bryteren åpen, og dermed er lysene slått av.

Base - GPIOer

Samler - Farger (RØD, GRØNN, BLÅ)

Emitter - bakken (av både strømforsyningen og Pi)

Sørg for å koble Pi -bakken til bakken til strømforsyningen. Lysene vil fortsatt fungere, men de vil se veldig svake ut til bakken er tilkoblet.

Jeg har en fjerde transistor utseende enhet på protoboardet mitt. Det er en L7805CV som brukes til å konvertere 12V til 5V, slik at jeg kunne drive Pi på samme krets. Det fungerte, men fortsatte å varme opp, så jeg fjernet tilkoblingene.

Trinn 8: Test det ut

Når du er ferdig med kretsen, starter du Pi på nytt før du foretar tilkoblinger. Dette er fordi pinnene sannsynligvis fortsatt er aktive fra servertesten. Alternativt kan du drepe serveren og pigpiod -tjenesten.

Plugg inn lysdiodene og hopperne fra protoboardet til Pi. Dobbeltsjekk alle tilkoblinger før du gir strøm. Hvis du koblet den feil, kan du steke din Pi (uten trykk).

Sjekkliste

  • Sjekk ledninger
  • Power Pi
  • Strømkrets
  • Start Server (DEBUG = webapp:* npm start mens du er i ~/piWebpage/webApp -katalogen)
  • Be Google gjøre budene dine!

GRATULERER du ikke sprengte noe, og du kan nå kontrollere lysdiodene dine fra Google Home.

Legg igjen kommentarer hvis du har problemer, så skal jeg gjøre mitt beste for å komme tilbake til deg!

Anbefalt: