Sadržaj:
- Korak 1: Instalirajte Linux na Raspberry Pi
- Korak 2: Instalirajte Python 3
- Korak 3: Postavite modul štapića
- Korak 4: Postavljanje CLI -ja SmartThings
- step 5: improve response
- step 6: make smartwand execute on raspberry pi bootup
Video: SmartWand: 6 koraka
2024 Autor: John Day | [email protected]. Zadnja promjena: 2024-01-30 09:34
Ovaj projekt ima za cilj dobiti Python skriptu za kontrolu Smartthings -a s Kano štapićem za kodiranje kao ulazom.
Moje kćeri (8 i 12) velike su obožavateljice Harryja Pottera i za Božić su dobile Kano štapić za kodiranje. Aplikacija za kodiranje Kano je super i zabavljaju se s njom. Izvrstan alat za uvođenje koncepata kodiranja.
Imamo i malo kućne automatizacije posute po cijeloj kući SmartThings, Phillips Hue, Logitech Harmony hub, itd … Oni su neizbježno došli do točke u kojoj su željeli palicom paliti svjetla za božićno drvce te su počeli uvoditi termine poput Lumosa i Nox na mene. Zvučalo je kao zabavan izazov pa sam se prihvatio.
Morao sam ići s Linux OS -om jer je kritični element (Bluepy python knjižnica za spajanje na štapić Bluetooth) dostupan samo na Linux platformama. U svakom slučaju zgodno sa stajališta da na kraju poželite pokrenuti ovo na Raspberry Pi.
Ovdje postoje dvije glavne reference, bez kojih to nikada ne bih mogao učiniti.
Hvala GammaGames za stvaranje i dijeljenje python skripte za čitanje Kano štapića za kodiranje.
github.com/GammaGames/kano-wand-demos/blob…
i
Zahvaljujući rllynchu za stvaranje i dijeljenje python skripte za sučelje naredbenog retka SmartThings.
github.com/rllynch/smartthings_cli
Kako bih ovo zadržao netaknutim, kopirat ću većinu koraka u ovaj Instructable kako bih uhvatio sve izmjene koje su mi bile potrebne da bi mogao raditi na svom postavljanju.
Evo što će vam trebati:
- Harry Potter Kano Kit za kodiranje (https://www.amazon.com/Kano-Harry-Potter-Coding-Ki…
- OS temeljen na Linuxu (pokrenuo sam ga s VirtualBox -om, zatim instaliran na Raspberry Pi)
- Bluetooth USB adapter (koristio sam Kensington Bluetooth 4.0 USB adapter)
- Internet veza (Za RPi sam koristio Edimax USB WiFi adapter koji sam imao iz prethodnog projekta)
Korak 1: Instalirajte Linux na Raspberry Pi
Slijedite donje veze da biste instalirali Linux OS na Raspberry Pi. Koristio sam Raspbian Stretch sa stolnim računalom i preporučenim softverom i bljesnuo s Etcherom.
www.raspberrypi.org/learning/software-guid…
Nakon što dovršite instalaciju i imate Linux naredbeni redak, dobra je praksa pokrenuti sljedeće dvije naredbe kako biste bili sigurni da je sve ažurirano.
sudo apt-get ažuriranje
sudo apt-get nadogradnja
Upišite sljedeće na sučelje naredbenog retka da biste pokrenuli korisničko sučelje radne površine.
sudo startx
Sljedeća stvar koju trebate postaviti je internetska veza kako biste mogli pristupiti repo -ovima i slično za instaliranje daljnjeg softvera. Internet veza će također biti potrebna za pristup SmartThings API -ju. Slijedite ove upute za povezivanje. Prilično ravno s radne površine. Koristio sam USB adapter za WiFi koji sam imao u blizini.
www.raspberrypi.org/learning/software-guid…
Alternativno Raspberry Pi -u, mogli biste upotrijebiti drugo postojeće računalo za dvostruko pokretanje Linux OS -a zajedno sa svojim postojećim OS -om (bolno jer morate ponovno pokrenuti sustav za prebacivanje s jednog na drugi) ili pokrenuti instancu Linux OS -a na VirtualBox. Kako bi ovaj projekt prvo počeo funkcionirati, instalirao sam Debian Stretch s Raspberry Pi radnom površinom u virtualni okvir pomoću ovog vodiča:
thepi.io/how-to-run-raspberry-pi-desktop-o…
(Napomena: Imao sam jako puno vremena kad sam pravilno instalirao Guest Addons prema gore navedenim uputama. Nikada nisam uspio prerezati i zalijepiti između hosta i klijenta, što bi bilo lijepo, ali uspio sam ažurirati rezoluciju za korištenje moja puna veličina monitora. Ovo je bio niz rupa za google rabit koje ovdje neću dokumentirati.)
Korak 2: Instalirajte Python 3
Python3 bi već trebao biti instaliran s Raspian Stretch -om.
Korak 3: Postavite modul štapića
Slijedite ovaj vodič koji je izradio GammaGames
Prvo sam morao prijeći u drugi direktorij prije nego što sam klonirao kano_wand repo, inače ga moja python skripta nije mogla pronaći. Vjerojatno sam mogao ažurirati neke reference puta u nekoj datoteci, ali nisam se u to upuštao.
cd /usr/local/lib/python3.5/dist-paketi
git klon
sudo pip3 instalirati bluepy moosegesture
Morao sam koristiti sudo da bih dobio odgovarajuća dopuštenja. Također sam morao koristiti sljedeće naredbe umjesto da instaliram numpy, iz bilo kojeg razloga, pip nije mogao raditi. Možda je to bio još jedan problem sa stazom, ali ovo mi je uspjelo pa sam krenuo s tim:
sudo apt-get install python3-numpy
Na kraju, kako bih dobio odgovarajuća dopuštenja za izvršavanje bluepy iz skripte python, pronašao sam ovu naredbu.
sudo setcap 'cap_net_raw, cap_net_admin+eip' /usr/local/lib/python3.5/dist-packages/bluepy/bluepy-helper
To je sve što je potrebno za pokretanje naše skripte. Ostatak vodiča kroz GammaGames prolazi kroz korake korak po korak koji su potrebni u python skripti. Sjajan je podatak za daljnje razumijevanje kako je scenarij strukturiran i što svaki objekt radi. Veliko hvala GammaGames -u na pružanju ove dokumentacije. Također bi moglo biti korisno za rješavanje problema u dijelu skripte. Na primjer, prvi prikazani objekt obavlja zadatak skeniranja štapića i vraćanja popisa otkrivenih štapića. Dobra potvrda da vaša postavka za bluetooth puca na sve cilindre. Da biste to učinili, možete kopirati kôd iz test1_BLE_wand_detect.py koji se nalazi u sljedećem repo:
github.com/maspieljr/SmartWand
Korak 4: Postavljanje CLI -ja SmartThings
Dolje se nalazi kopija uputa uključenih u repo smartthings_cli na githubu (https://github.com/rllynch/smartthings_cli).
Ovdje sam uključio male izmjene koje sam morao napraviti na svom postavljanju kako bi sve funkcioniralo. Još jednom hvala rllynchu na pružanju ovoga.
1) Prijavite se i pod My SmartApps, stvorite novu SmartApp s kodom u groovy/app.groovy.
*Napomena: u prvom koraku postoji referenca na web stranicu SmartThings. Obratite posebnu pozornost na to gdje se nalazi vaš račun pametnih stvari. To me je neko vrijeme spotaknulo jer mi je druga web stranica omogućila prijavu, ali nisam mogao pronaći ništa od svojih stvari. Morao sam koristiti sljedeću vezu da bih došao do svog računa SmartThings.https://graph-na04-useast2.api.smartthings.com
(Nema na čemu 2 sata koja sam proveo razvrstavajući:) ovo će biti važno i u kasnijem koraku.)
2) Pritisnite Postavke aplikacije i u odjeljku OAuth kliknite Omogući OAuth u Pametnoj aplikaciji. Zapišite ID klijenta OAuth i tajnu klijenta OAuth. Ažurirajte OAuth klijentski zaslon na SmartThings CLI kontrolu. Kliknite Ažuriraj.
3) Vratite se na Moje SmartApps, a zatim kliknite na SmartThings CLI Control. Pritisnite Objavi => Za mene.
4) Klonirajte spremište smartthings_cli, po želji stvorite virtualenv (ja to nisam učinio), a zatim pokrenite sljedeće naredbe, zamijenivši CLIENTID i CLIENTSECRET ID -om i tajnom iz 2. koraka.
Za kloniranje repoa smartthings možete koristiti sljedeću naredbu. Provjerite je li naredbeni redak linux u direktoriju vašeg projekta koji je stvoren tijekom postavljanja modula štapića.
git klon >
then change directory again down to the smartthings_cli directory that was just created.
cd smartthings_cli
python setup.py install
smartthings_cli --clientid clientid --clientsecret clientsecret
5) smartthings_cli will direct you to a url to authorized access. copy the url from the response in the command window and be sure to update it with the proper path as we had to in step 1. go to that url in a browser and specify which devices the cli should be able to access. click authorize when finished. you should be redirected to a page reporting smartthings_cli.py received auth code.
last few things i needed to do in order to get rid of a warning that kept coming up:
sudo apt-get install libssl-dev
pip install service_identity
pip install attrs pip install pyopenssl pip install pyasn1 pip install pyasn1-modules pip install ipaddress
raspberry pi should now be set-up to issue smart thing commands from the command line interface, try it out with these examples:
smartthings_cli query switch all
smartthings_cli query switch "switch name"
smartthings_cli set switch "switch name" on
step 5: improve response
everything is running at this point but there's a bit of a lag once the wand gesture is captured. in attempt to speed up the response, i've embedded the smarthings logic into the smartwand python script rather than calling it from a command line as it does in smartwand.py. this eliminated the need to repeatedly import the modules required for smartthings communication, which is what was slowing everything down. here's what i had to do to get that working:
python3 -m pip install future
python3 -m pip install twisted
made update to the python script. see smartwand2.py stored in the following repo:
github.com/maspieljr/smartwand
step 6: make smartwand execute on raspberry pi bootup
so you only need to plug in the raspberry pi near your smartthings things and not require a monitor, and keyboard, i followed these instructions to get the script to run on boot or any time a command line terminal is launched. the script seems pretty robust but does get hung up from time to time, requiring a reboot. alternatively you could have a keyboard connected and use alt+f4 to kill a running script and ctrl+alt+t to launch a new terminal without needing a monitor to see anything.
method 2: modify the.bashrc file as described in the link below:
www.dexterindustries.com/howto/run-a-progr…
Preporučeni:
Dizajn igre brzim pokretom u 5 koraka: 5 koraka
Dizajn igre u Flick -u u 5 koraka: Flick je zaista jednostavan način stvaranja igre, osobito nečega poput zagonetke, vizualnog romana ili avanturističke igre
Broj koraka: 17 koraka
الكشف عن عن أنواع المحاليل: محمدآل سعودالكشف عن المحاليل رابط الفديو
Prepoznavanje lica na Raspberry Pi 4B u 3 koraka: 3 koraka
Prepoznavanje lica na Raspberry Pi 4B u 3 koraka: U ovom Instructableu ćemo izvršiti detekciju lica na Raspberry Pi 4 sa Shunya O/S pomoću knjižnice Shunyaface. Shunyaface je biblioteka za prepoznavanje/otkrivanje lica. Cilj projekta je postići najbržu brzinu otkrivanja i prepoznavanja s
Kako napraviti brojač koraka?: 3 koraka (sa slikama)
Kako napraviti brojač koraka?: Nekada sam se dobro snašao u mnogim sportovima: hodanje, trčanje, vožnja bicikla, igranje badmintona itd. Volim jahanje da bih brzo putovao. Pa, pogledaj moj trbušni trbuh … Pa, u svakom slučaju, odlučujem ponovno početi vježbati. Koju opremu trebam pripremiti?
Aduino UNO Broj koraka: 5 koraka
Aduino UNO 를 이용한 도망 치는 &&&& && l g g g g g g g g g g g g g g g 4 g 4 4 4 4 프로젝트 프로젝트 프로젝트 프로젝트 프로젝트 프로젝트 프로젝트 프로젝트 일자 일자 일자: 2017.01.06. ~ 2017.01.11.- 역할 분담 SW 엔지니어: 김 예은, 임동영 HW 엔지니어: 김지훈 디자이너: 이재민 레코더: 홍 다예 ------------------------ --------------------------------------------------