This shows you the differences between two versions of the page.
pm:prj2023:alexau:smartclock [2023/05/07 22:36] ana_maria.rotari [Hardware Design] |
pm:prj2023:alexau:smartclock [2023/05/30 12:58] (current) ana_maria.rotari [Software Design] |
||
---|---|---|---|
Line 36: | Line 36: | ||
{{:pm:prj2023:alexau:smartalarmclock.jpeg?600|}} | {{:pm:prj2023:alexau:smartalarmclock.jpeg?600|}} | ||
+ | |||
+ | {{:pm:prj2023:alexau:hardclock3.jpeg?nolink&200|}} | ||
+ | {{:pm:prj2023:alexau:hardclock2.jpeg?nolink&200|}} | ||
+ | {{:pm:prj2023:alexau:hardclock.jpeg?nolink&200|}} | ||
===== Software Design ===== | ===== Software Design ===== | ||
Line 41: | Line 45: | ||
<note tip> | <note tip> | ||
- | Descrierea codului aplicaţiei (firmware): | + | |
- | * mediu de dezvoltare (if any) (e.g. AVR Studio, CodeVisionAVR) | + | https://github.com/anamariarotari/smartclock |
- | * librării şi surse 3rd-party (e.g. Procyon AVRlib) | + | |
- | * algoritmi şi structuri pe care plănuiţi să le implementaţi | + | https://www.youtube.com/shorts/OF910UmTgCE |
- | * (etapa 3) surse şi funcţii implementate | + | |
+ | **Am folosit următoarele biblioteci:** | ||
+ | |||
+ | * IRremote.h - Aceasta este biblioteca pentru a recepționa și decoda semnalele de la un receptor IR. | ||
+ | * RTClib.h - Aceasta este biblioteca pentru a crea un port serial software pentru a comunica cu un modul RTC (Real-Time Clock) conectat prin pini digitali. | ||
+ | * LiquidCrystal.h - Aceasta este biblioteca pentru a controla un afișaj LCD cu caractere, cum ar fi un afișaj LCD de 16x2. | ||
</note> | </note> | ||
+ | |||
+ | La inițializare, se setează pinii și se configurează afișajul LCD și receptorul IR. De asemenea, se ajustează ceasul timp real (RTC) la data și ora curentă. | ||
+ | |||
+ | În funcția loop(), se afișează pe LCD timpul curent preluat de la RTC. Apoi, se apelează funcția getAlarm() care verifică dacă este momentul să se declanșeze alarma și dacă utilizatorul trebuie să introducă răspunsul corect la o ecuație pentru a o dezactiva. | ||
+ | |||
+ | Funcția getAlarm() are mai multe etape: | ||
+ | |||
+ | - Verifică dacă este momentul de a seta ora, minutele și secundele pentru alarmă. | ||
+ | - Utilizatorul poate introduce valorile pentru alarmă utilizând telecomanda IR. | ||
+ | - Se afișează pe LCD valoarea introdusă pentru alarmă. | ||
+ | - Se verifică dacă timpul curent este egal cu timpul alarmei. În caz afirmativ, se activează buzzer-ul. | ||
+ | - Se verifică dacă utilizatorul a apăsat butonul de rezolvare a ecuației. În caz afirmativ, se resetează valorile pentru alarmă și se șterge afișajul. | ||
+ | - Dacă alarma este activă (buzzer-ul emite sunet), se afișează o ecuație matematică pe LCD și se așteaptă ca utilizatorul să introducă răspunsul corect prin intermediul telecomenzii IR. Dacă răspunsul este corect, sunetul alarmei este oprit. | ||
+ | |||
+ | Codul utilizează funcții auxiliare cum ar fi translateIR() pentru a traduce codurile IR în comenzi utilizabile și setHour(), setMinute(), setSecond() pentru a gestiona introducerea valorilor pentru alarmă. | ||
+ | |||
+ | |||
===== Rezultate Obţinute ===== | ===== Rezultate Obţinute ===== |