Mrugająca dioda LED: Różnice pomiędzy wersjami
(dodany link do pełnego opisu pinów) |
(→Włączanie i wyłączanie diody w pythonie) |
||
Linia 82: | Linia 82: | ||
=== Włączanie i wyłączanie diody w pythonie === | === Włączanie i wyłączanie diody w pythonie === | ||
− | |||
− | Poniżej prosty kod przełączający diodę podłączoną do wyjść tak jak na schemacie powyżej. Kod będzie działał tylko na Raspbianie ponieważ | + | Podstawowe informacje o pisaniu programów w '''pythonie''' zawiera [[Wstęp_do_pythona|ta strona]]. Dalej zakładamy, że już coś na ten temat wiesz. |
+ | |||
+ | |||
+ | Poniżej prosty kod przełączający diodę podłączoną do wyjść tak jak na schemacie powyżej. Kod będzie działał tylko na Raspbianie ponieważ w tym systemie dostępny jest moduł '''RPi.GPIO''' przeznaczony do pracy z pinami wejścia/wyjścia maliny (''ang. GPIO'' to skrót ''General Purpose Input/Output'' czyli wejście/wyjście dowolnego przeznaczenia, a ''RPi'' to oczywiście ''raspberry pi''). Próbę importowania modułu '''RPi''' na innym systemie (np. na laptopie) '''python''' skwituje komunikatem o jego braku. | ||
+ | |||
+ | |||
+ | <div class="thumb"><div class="thumbinner"><div class="thumbcaption"><span style="color:#0044bb">'''Uwaga:''' W kodzie poniżej zmieniamy domyślny tryb numeracji wyjść na zgodny z układem pinów na płytce (p. instrukcja <code>gpio.setmode(gpio.BOARD)</code>). Zamiast poprzedniego GPIO 14 zgodnego z numeracją procesora i przyjmowaną domyślnie, będziemy korzystać z numeru 8, czyli po prostu numeru pinu w łączu 40-pinowym (jak na diagramie wyżej). </span></div></div> | ||
− | |||
<source lang="python"> | <source lang="python"> | ||
# coding: utf-8 | # coding: utf-8 | ||
− | # wczytujemy moduł pythona zawierający | + | # wczytujemy moduł pythona zawierający funkcje obsługi czasu, których używamy do mierzenia opóźnień |
import time | import time | ||
− | # | + | # tym module mamy funkcje do obsługi wyjść złącza 40-pinowego |
− | # żeby było prościej | + | # żeby było prościej będziemy go nazywać dalej w programie krótszą nazwą i bez dużych liter (gpio zamiast RPi.GPIO) |
import RPi.GPIO as gpio | import RPi.GPIO as gpio | ||
# moduł RPi.GPIO może używać dwóch różnych sposobów numerowania pinów; nas interesuje w tej chwili wygodniejszy | # moduł RPi.GPIO może używać dwóch różnych sposobów numerowania pinów; nas interesuje w tej chwili wygodniejszy | ||
− | # tryb BOARD (z ang. płytka), w którym | + | # tryb BOARD (z ang. płytka), w którym numery wyjść użyte w kodzie zgadzają się z numerami pinów złącza na płytce Maliny |
gpio.setmode(gpio.BOARD) | gpio.setmode(gpio.BOARD) | ||
− | # będziemy się bawić wyjściem GPIO 14 procesora, które na płytce jest podłączone do | + | # będziemy się bawić wyjściem GPIO 14 procesora, które na płytce jest podłączone do pinu numer 8 |
− | # chcemy używać go | + | # chcemy używać go jako wyjścia sterującego diodą dlatego włączamy tryb OUT |
+ | # (można też odczytywać napięcie na pinie w trybie IN np. jeśli mamy podłączony jakiś czujnik, ale tego tutaj nie potrzebujemy) | ||
gpio.setup(8, gpio.OUT) | gpio.setup(8, gpio.OUT) | ||
− | + | # zmiena, która będzie odliczała kolejne powtórzenia mrugnięcia diodą, zaczynamy od 0 | |
+ | ilePowtorek = 0 | ||
− | while | + | while ilePowtorek < 100: # while powtarza instrukcje tak długo jak długo spełniony jest podany warunek |
− | gpio.output(8, 0) # ustawienie napięcia 0V na styku nr 8, dioda gaśnie | + | gpio.output(8, 0) # ustawienie napięcia 0V na styku nr 8, dioda gaśnie |
− | time.sleep(0.5) | + | time.sleep(0.5) # pół sekundy czekamy |
− | gpio.output(8, 1) # ustawienie napięcia 3.3V styku nr 8, dioda zapala się | + | gpio.output(8, 1) # ustawienie napięcia 3.3V styku nr 8, dioda zapala się |
− | time.sleep(0.5) | + | time.sleep(0.5) # znów chwilę czekamy |
− | # zwiększamy zmienną | + | # skoro wykonaliśmy mrugnięcie zwiększamy zmienną ilePowtorek o jeden |
− | + | # w końcu osiągnie ona wartość 100, warunek while ilePowtorek < 100 przestanie być spełniony i program się skończy | |
+ | ilePowtorek = ilePowtorek + 1 | ||
− | # porządki, czyli przywracamy pierwotne ustawienia wyjść (dobry zwyczaj) | + | # porządki, czyli przywracamy pierwotne ustawienia wyjść zanim skończymy program (dobry zwyczaj!) |
gpio.cleanup() | gpio.cleanup() | ||
</source> | </source> | ||
− | Żeby powyższy kod wykonać na | + | Żeby powyższy kod wykonać na malinie trzeba go zapisać w pliku na jej karcie pamięci, albo będąc zdalnie połączonym (po ssh) wpisać go z klawiatury i zapisać. Można również utworzyć zdalne połączenie z "dyskiem" maliny korzystając z protokołu sftp po lokalnej sieci: wystarczy otworzyć przeglądarkę plików, wybrać "Inne położenia" i tam opcję łączenia ze zdalnym serwerem, gdzie jako adres wpisujemy <code>sftp://192.168.1.177/</code> (oczywiście należy podać aktualny adres IP maliny); po podaniu użytkownika (pi) i hasła (raspberry) będziemy mogli używać "dysku" maliny z laptopa tak, jakby był jakimś katalogiem w laptopie. |
+ | |||
+ | Przy wykonywaniu kodu linijka po linijce w terminalu Maliny, warto pamiętać, że wielolinijkową pętlę '''while''' można zapisać w jednej linii tak jak poniżej. Dla uproszczenia komentarze zostały usunięte, a testowanie wartości zmiennej <code>ilePowtorek < 100</code> zastąpione zostało "zawsze prawdą" (<code>True</code>), a więc pętla będzie się wykonywała w nieskończoność i kiedy już zobaczymy jej działanie i będziemy chcieli ją przerwać musimy to zrobić "ręcznie" wciskając klawisze '''Ctrl-C'''. | ||
− | |||
− | < | + | <code> |
while True: gpio.output(14, 0); time.sleep(0.5); gpio.output(14, 1); time.sleep(0.5); | while True: gpio.output(14, 0); time.sleep(0.5); gpio.output(14, 1); time.sleep(0.5); | ||
− | </ | + | </code> |
[[Category:Projekty_Pi_Zero]] | [[Category:Projekty_Pi_Zero]] |
Wersja z 00:01, 16 sty 2019
Prosty projekt elektroniczno-programowy na start. Przed rozpoczęciem programowania mrugającej diody warto zajrzeć na stronę o podstawach pythona.
Spis treści
Do czego zmierzamy
Chcemy uzyskać taki efekt jak na filmie poniżej, czyli swobodną kontrolę nad jednym z cyfrowych wyjść Maliny. Stan wyjścia będziemy testowali diodą LED.
Dioda do wykrywania stanów logicznych - trochę elektroniki
Żeby przygotować naszą sondę logiczną kładziemy elementy jak na zdjęciu obok. Następnie -- najlepiej dociskając z góry ramionami pęsety każdy z elementów -- dotykamy obu środkowych styków jednocześnie rozgrzanym grotem lutownicy z niewielką ilością cyny, im krócej tym lepiej, sekunda powinna starczyć. Stopiona cyna powinna spłynąć między elementy i stworzyć połączenie (zarówno elektryczne jak i mechaniczne).
Teraz przygotowujemy krótkie odcinki kabelków miedzianych. Najlepiej jeśli jeden z nich, który przylutujemy od strony masy diody LED (od strony zielonych markerów) był czarny bo tego koloru używa się zwykle do oznaczania masy i przyjęcie takiej konwencji ułatwia szybką orientację, który kabel gdzie przytknąć. Kabelki mniej więcej takiej długości jak na filmie. Ściągamy izolację na małym odcinku na końcach (2mm wystarczy) i cynujemy rozgrzaną lutownicą jeszcze przed lutowaniem do pary dioda-opornik. Takie wstępne pocynowanie końcówek ułatwia potem lutowanie do małych elementów SMD, których nie chcemy "usmażyć" zbyt długim podgrzewaniem.
Kable układamy w linii ze zlutowaną wcześniej parą elementów i podobnie jak przed chwilą wkładając rozgrzaną lutownicę w środek z odrobiną cyny łączymy razem.
Na koniec na całość możemy nałożyć przeźroczystą rurkę termokurczliwą i zatopić w niej elementy. Sonda gotowa. Jeśli wszystko zrobiliśmy dobrze podłączona do dwóch baterii "paluszków" powinna się zaświecić. Bateria ma masę na od strony płaskiego końca, a biegun dodatni tam gdzie znajduje się dodatkowa wypustka.
Gdzie tą sondę podłączyć?
Piny złącza 40 pinowego liczy się zaczynając od kwadratowego (numer 1), a dalej "zygzakiem". Poniżej numeracja z zaznaczonym miejscem podłączenia diody tak jak na filmie powyżej.
Na stronie trzykołowca znajduje się pełny opis wszystkich pinów.
Włączanie i wyłączanie diody w pythonie
Podstawowe informacje o pisaniu programów w pythonie zawiera ta strona. Dalej zakładamy, że już coś na ten temat wiesz.
Poniżej prosty kod przełączający diodę podłączoną do wyjść tak jak na schemacie powyżej. Kod będzie działał tylko na Raspbianie ponieważ w tym systemie dostępny jest moduł RPi.GPIO przeznaczony do pracy z pinami wejścia/wyjścia maliny (ang. GPIO to skrót General Purpose Input/Output czyli wejście/wyjście dowolnego przeznaczenia, a RPi to oczywiście raspberry pi). Próbę importowania modułu RPi na innym systemie (np. na laptopie) python skwituje komunikatem o jego braku.
# coding: utf-8
# wczytujemy moduł pythona zawierający funkcje obsługi czasu, których używamy do mierzenia opóźnień
import time
# tym module mamy funkcje do obsługi wyjść złącza 40-pinowego
# żeby było prościej będziemy go nazywać dalej w programie krótszą nazwą i bez dużych liter (gpio zamiast RPi.GPIO)
import RPi.GPIO as gpio
# moduł RPi.GPIO może używać dwóch różnych sposobów numerowania pinów; nas interesuje w tej chwili wygodniejszy
# tryb BOARD (z ang. płytka), w którym numery wyjść użyte w kodzie zgadzają się z numerami pinów złącza na płytce Maliny
gpio.setmode(gpio.BOARD)
# będziemy się bawić wyjściem GPIO 14 procesora, które na płytce jest podłączone do pinu numer 8
# chcemy używać go jako wyjścia sterującego diodą dlatego włączamy tryb OUT
# (można też odczytywać napięcie na pinie w trybie IN np. jeśli mamy podłączony jakiś czujnik, ale tego tutaj nie potrzebujemy)
gpio.setup(8, gpio.OUT)
# zmiena, która będzie odliczała kolejne powtórzenia mrugnięcia diodą, zaczynamy od 0
ilePowtorek = 0
while ilePowtorek < 100: # while powtarza instrukcje tak długo jak długo spełniony jest podany warunek
gpio.output(8, 0) # ustawienie napięcia 0V na styku nr 8, dioda gaśnie
time.sleep(0.5) # pół sekundy czekamy
gpio.output(8, 1) # ustawienie napięcia 3.3V styku nr 8, dioda zapala się
time.sleep(0.5) # znów chwilę czekamy
# skoro wykonaliśmy mrugnięcie zwiększamy zmienną ilePowtorek o jeden
# w końcu osiągnie ona wartość 100, warunek while ilePowtorek < 100 przestanie być spełniony i program się skończy
ilePowtorek = ilePowtorek + 1
# porządki, czyli przywracamy pierwotne ustawienia wyjść zanim skończymy program (dobry zwyczaj!)
gpio.cleanup()
Żeby powyższy kod wykonać na malinie trzeba go zapisać w pliku na jej karcie pamięci, albo będąc zdalnie połączonym (po ssh) wpisać go z klawiatury i zapisać. Można również utworzyć zdalne połączenie z "dyskiem" maliny korzystając z protokołu sftp po lokalnej sieci: wystarczy otworzyć przeglądarkę plików, wybrać "Inne położenia" i tam opcję łączenia ze zdalnym serwerem, gdzie jako adres wpisujemy sftp://192.168.1.177/
(oczywiście należy podać aktualny adres IP maliny); po podaniu użytkownika (pi) i hasła (raspberry) będziemy mogli używać "dysku" maliny z laptopa tak, jakby był jakimś katalogiem w laptopie.
Przy wykonywaniu kodu linijka po linijce w terminalu Maliny, warto pamiętać, że wielolinijkową pętlę while można zapisać w jednej linii tak jak poniżej. Dla uproszczenia komentarze zostały usunięte, a testowanie wartości zmiennej ilePowtorek < 100
zastąpione zostało "zawsze prawdą" (True
), a więc pętla będzie się wykonywała w nieskończoność i kiedy już zobaczymy jej działanie i będziemy chcieli ją przerwać musimy to zrobić "ręcznie" wciskając klawisze Ctrl-C.
while True: gpio.output(14, 0); time.sleep(0.5); gpio.output(14, 1); time.sleep(0.5);