Differences

This shows you the differences between two versions of the page.

Link to this comparison view

pm:prj2025:ccristi:valentin.carauleanu [2025/05/23 16:23]
valentin.carauleanu [Funcții Master Arduino – Organizare pe Secțiuni]
pm:prj2025:ccristi:valentin.carauleanu [2025/05/28 09:45] (current)
valentin.carauleanu [Hardware Design]
Line 70: Line 70:
   * LCD-ul afișează promptul pentru introducerea codului.   * LCD-ul afișează promptul pentru introducerea codului.
   * Utilizatorul introduce codul PIN pe tastatură.   * Utilizatorul introduce codul PIN pe tastatură.
-  * Codul este verificat: dacă este corect: servomotorul deschide dulapul, LED-ul se aprinde, apare mesajul "​Access Granted";​ dacă este greșit: ​buzzer-ul emite un sunet scurt; după 3 încercări greșite, buzzer-ul rămâne pornit. +  * Codul este verificat: dacă este corect: servomotorul deschide dulapul, LED-ul se aprinde, apare mesajul "​Access Granted";​ dacă este greșit: ​apare un mesaj sugestiv; după 3 încercări greșite, buzzer-ul rămâne pornit. 
-  * Se apasă `B` pentru a reloca dulapul.+  * Se apasă `B` pentru a rebloca sieful, `A` pentru a schimba cifrul.
  
 ==== 2. Setarea sau schimbarea codului de securitate ==== ==== 2. Setarea sau schimbarea codului de securitate ====
Line 122: Line 122:
 ===== Hardware Design ===== ===== Hardware Design =====
  
 +Sistemul este alcătuit din două plăci de dezvoltare Arduino Uno, care comunică între ele prin magistrala I2C în configurație Master–Slave. Partea de Master controlează afișajul LCD 1602 cu interfață I2C, un servo-motor SG90 pentru închiderea fizică a seifului, o tastatură matricială 4x4 pentru introducerea codului PIN, un buzzer pentru semnalizare acustică și un LED de stare. Placa Slave este echipată cu senzori de mediu: un DHT11 pentru temperatură și umiditate, un senzor de sunet KY-037 pentru detecția zgomotului ambiental, un modul de timp real RTC DS1302 pentru afișarea orei curente și un senzor de înclinare SW-520D, conectat la o întrerupere externă pentru semnalizarea mișcărilor neautorizate. Întregul ansamblu este alimentat prin USB, fiind gândit să funcționeze într-un sistem închis și compact, ideal pentru securizarea unui obiect fizic.
  
 **Bill of Materials**:​ **Bill of Materials**:​
Line 166: Line 167:
 {{ :​pm:​prj2025:​ccristi:​ez_box_schema.png?​500 |}} {{ :​pm:​prj2025:​ccristi:​ez_box_schema.png?​500 |}}
  
-** Version 1 ** 
  
 {{ :​pm:​prj2025:​ccristi:​img_5139.jpeg?​300 |}} {{ :​pm:​prj2025:​ccristi:​img_5139.jpeg?​300 |}}
  
 {{ :​pm:​prj2025:​ccristi:​img_5144.jpeg?​300 |}} {{ :​pm:​prj2025:​ccristi:​img_5144.jpeg?​300 |}}
 +
 +{{ :​pm:​prj2025:​ccristi:​final.jpg?​300 |}}
 ===== Software Design ===== ===== Software Design =====
  
 Software-ul utilizat: Software-ul utilizat:
- 
-ZIP: 
-{{:​pm:​prj2025:​ccristi:​software_master.zip|}} 
-{{:​pm:​prj2025:​ccristi:​software_slave.zip|}} 
  
 GITHUB: GITHUB:
Line 228: Line 226:
 <​code>​ <​code>​
 // custom structs, enums // custom structs, enums
-enum LockedPhase { +enum LockedPhase { PHASE_IDLE, PHASE_WAIT_INPUT,​ PHASE_VERIFY, ​PHASE_NOTIFICATION }; 
-  ​PHASE_IDLE, +enum UnlockedPhase { PHASE_UNLOCK_IDLEPHASE_UNLOCK_OPTIONS,​ PHASE_NEW_CODE_SETUP }; 
-  ​PHASE_WAIT_INPUT,​ +enum CodeSubPhase { CODE_ENTER, CODE_CONFIRM ​};
-  ​PHASE_VERIFY,​ +
-  ​PHASE_GRANTED+
-  ​PHASE_DENIED +
-};+
  
-enum UnlockedPhase { 
-  PHASE_UNLOCK_IDLE,​ 
-  PHASE_UNLOCK_OPTIONS,​ 
-  PHASE_NEW_CODE_ENTER,​ 
-  PHASE_NEW_CODE_CONFIRM,​ 
-  PHASE_CODE_SUCCESS,​ 
-  PHASE_CODE_FAIL,​ 
-  PHASE_RELOCK 
-}; 
  
 struct SensorPacket { struct SensorPacket {
Line 262: Line 247:
  
  
-===== Rezultate Obţinute ​=====+===== Funcții Master Arduino ​=====
  
-<note tip> +=== Inițializare și configurare ===
-Care au fost rezultatele obţinute în urma realizării proiectului vostru. +
-</​note>​+
  
-===== Concluzii =====+<code cpp> 
 +void setup() 
 +// Inițializează LCD-ul, servo-ul, senzorii, buzzerul, LED-ul, I2C, etc. 
 +// Afișează mesajul „Welcome” și setează sistemul ca fiind blocat sau deblocat în funcție de starea salvată. 
 +</​code>​
  
-===== Download =====+<code cpp> 
 +void resetScreenState() 
 +// Golește ecranul și resetează indicatorii interni și codurile introduse. 
 +// Este apelată după o perioadă lungă de inactivitate. 
 +</​code>​
  
-<note warning>​ +=== Comunicare ​cu Arduino Slave ===
-O arhivă (sau mai multe dacă este cazul) ​cu fişierele obţinute în urma realizării proiectului:​ surse, scheme, etc. Un fişier README, un ChangeLog, un script de compilare şi copiere automată pe uC crează întotdeauna o impresie bună ;-).+
  
-Fişierele se încarcă pe wiki folosind facilitatea **Add Images or other files**Namespace-ul în care se încarcă fişierele ​este de tipul **:​pm:​prj20??:​c?​** sau **:pm:​prj20??:​c?:​nume_student** ​(dacă este cazul). **Exemplu:​** Dumitru Alin331CC -> **:​pm:​prj2009:​cc:​dumitru_alin**. +<code cpp> 
-</​note>​+void requestSensorData() 
 +// Trimite o solicitare I2C către slave (adresă definită) pentru a primi structura SensorPacket. 
 +// Conține ora, temperatura,​ umiditatea, nivelul de sunet și detectarea de mișcare (tilt). 
 +</​code>​ 
 + 
 +=== Control fizic: Blocare și Deblocare === 
 + 
 +<code cpp> 
 +void lock() 
 +// Mută servomotorul în poziția de blocare și oprește LED-ul
 +</​code>​ 
 + 
 +<code cpp> 
 +void unlock() 
 +// Mută servomotorul ​în poziția de deblocare și aprinde LED-ul. 
 +</​code>​ 
 + 
 +<code cpp> 
 +bool isUserClose() 
 +// Măsoară distanța cu senzorul ultrasonic (TRIG/​ECHO). 
 +// Dacă este sub un prag predefinit, consideră că utilizatorul este în apropiere. 
 +</​code>​ 
 + 
 +=== Afișare și notificări === 
 + 
 +<code cpp> 
 +void showNotification(const String& msg, bool isLockedPhase) 
 +// Afișează un mesaj centrat pe LCD și setează automat faza următoare în funcție ​de context (locked/​unlocked). 
 +</​code>​ 
 + 
 +<code cpp> 
 +void displaySensorSummary(bool locked) 
 +// Afișează temperatura,​ umiditatea, sunetul, ora și simbolul de lacăt (închis/​deschis) pe ecran. 
 +</​code>​ 
 + 
 +=== Faze când sistemul este blocat (Locked) === 
 + 
 +<code cpp> 
 +void safeLockedLogicStep() 
 +// Selectează și apelează funcția corespunzătoare fazei curente de blocare. 
 +</​code>​ 
 + 
 +<code cpp> 
 +void handleLockedIdle() 
 +// Solicită date de la slave, verifică tilt, afișează senzorii și pregătește ecranul pentru introducerea codului. 
 +</​code>​ 
 + 
 +<code cpp> 
 +void handleLockedWaitInput() 
 +// Citește codul PIN de la tastatură și afișează ​pentru fiecare cifră. 
 +</​code>​ 
 + 
 +<code cpp> 
 +void handleLockedNotification() 
 +// După succes ​sau eșec, așteaptă 1.5 secunde și revine în faza inițială. 
 +</​code>​ 
 + 
 +=== Faze când sistemul este deblocat (Unlocked) === 
 + 
 +<code cpp> 
 +void safeUnlockedLogicStep() 
 +// Selectează și apelează funcția corespunzătoare fazei curente de deblocare. 
 +</​code>​ 
 + 
 +<code cpp> 
 +void handleUnlockIdle() 
 +// Afișează opțiunile„A” pentru schimbare cod, „B” pentru blocare. 
 +</​code>​ 
 + 
 +<code cpp> 
 +void handleUnlockOptions(
 +// Procesează apăsarea tastelor A sau B pentru a intra în faza de configurare sau de blocare. 
 +</​code>​ 
 + 
 +<code cpp> 
 +void handleNewCodeSetup() 
 +// Permite introducerea unui cod nou și confirmarea acestuia într-o singură funcție. 
 +// Dacă cele două coduri coincid, noul cod este salvat. 
 +</​code>​ 
 + 
 +=== Bucla principală === 
 + 
 +<code cpp> 
 +void loop() 
 +// Verifică la intervale regulate proximitatea utilizatorului. 
 +// Solicită date de la slave și verifică senzorul de înclinare (tilt). 
 +// Apelează logica de blocare sau deblocare doar dacă utilizatorul ​este prezent. 
 +</​code>​ 
 + 
 +===== Functii Arduino Slave ===== 
 + 
 +=== Inițializare și configurare === 
 + 
 +<code cpp> void setup( // Inițializează senzorul DHT11 (temperatură/​umiditate) // Setează ora și data pe modulul RTC // Configurează senzorul de înclinare (tilt) și întreruperea externă // Pornește RTC-ul și inițializează comunicarea I²C ca slave  </​code>​ 
 +=== Funcții de întrerupere și comunicare === 
 + 
 +<code cpp> void onRequest() ​ // Este apelată automat de Arduino Master prin I2C// Trimite structura SensorPacket către Master. // Dacă în acest moment tiltDetected este truese trimite ca atare și apoi se resetează. ​ </​code>​ <code cpp> void onTilt() ​ // Funcție apelată la declanșarea întreruperii externe de la senzorul SW-520. // Setează flag-ul tiltDetected pe true.  </code> 
 +=== Bucla principală (loop) === 
 + 
 +<code cpp> void loop() ​ // Citește data și ora curente de la modulul RTC și actualizează packet // Citește temperatura și umiditatea de la senzorul DHT11 // Citește semnalul analogic de la microfonul KY-037 și îl transformă într-un procent // Copiază flag-ul tilt în packet și apoi îl resetează // Așteaptă 250ms înainte de următoarea lectură (pentru eficiență) ​ </​code>​ 
 + 
 +===== Rezultate Obţinute ===== 
 + 
 +  ​Sistemul de acces a fost implementat cu succes, permițând blocarea/​deblocarea fizică prin introducerea unui cod PIN pe tastatura matricială. 
 +  ​Informațiile despre temperatură,​ umiditate, sunet și înclinare sunt colectate în timp real de Arduino Slave și transmise cu succes către Arduino Master prin I²C. 
 +  ​Ecranul LCD afișează datele ambientale și oferă interfață intuitivă pentru utilizator. 
 +  ​În cazul unei tentative de manipulare a sistemului (detectare de tilt), sistemul reacționează prin activarea buzzerului de alarmă și blochează accesul
 +  * LED-ul montat indică vizual starea de blocare a seifului (ON = deblocat). 
 + 
 +===== Concluzii =====
  
 +  * Comunicarea Master–Slave prin I2C s-a dovedit stabilă și eficientă.
 +  * Utilizarea întreruperilor pentru senzorul de înclinare permite reacții imediate la tentative de manipulare.
 +  * Arhitectura modulară (separare Master–Slave) permite extinderea sistemului cu ușurință ​
 +  * Proiectul oferă un exemplu funcțional de integrare între senzori digitali/​analogici,​ module RTC și controlere multiple într-un sistem embedded.
  
 ===== Bibliografie/​Resurse ===== ===== Bibliografie/​Resurse =====
pm/prj2025/ccristi/valentin.carauleanu.1748006613.txt.gz · Last modified: 2025/05/23 16:23 by valentin.carauleanu
CC Attribution-Share Alike 3.0 Unported
www.chimeric.de Valid CSS Driven by DokuWiki do yourself a favour and use a real browser - get firefox!! Recent changes RSS feed Valid XHTML 1.0