Laser Alarm With RFID Module
by CarlosVoltT in Circuits > Arduino
171 Views, 1 Favorites, 0 Comments
Laser Alarm With RFID Module
In this project, we build a security alarm using a laser detection system, a laser receiver sensor, a buzzer and an RFID-RC522 module.
In this project, we build a security alarm using a laser detection system, a laser receiver sensor, a buzzer and an RFID-RC522 module, all controlled by an Arduino. The goal is to create a system that can detect the interruption of a laser beam and trigger an audible alarm, as well as allowing the arming and disarming of the alarm using a specific RFID card.
Project Operation:
Laser Detection System:
- The system relies on a constant laser beam aimed at a laser receiver sensor. This sensor is configured to detect the presence or absence of the laser beam. Under normal conditions, the laser reaches the sensor and the system recognizes this condition as a “safe” state.
- Laser Detection System:
- The system relies on a constant laser beam aimed at a laser receiver sensor. This sensor is configured to detect the presence or absence of the laser beam. Under normal conditions, the laser reaches the sensor and the system recognizes this condition as a “safe” state.
Alarm Activation:
- When the laser beam is interrupted (for example, by a person passing through the beam), the receiving sensor detects the absence of the laser. This change of state is detected by the Arduino, which in turn activates a buzzer to emit an audible alarm. This mechanism acts as a security barrier, alerting of an intrusion or unauthorized access.
- Alarm Activation:
- When the laser beam is interrupted (for example, by a person passing through the beam), the receiving sensor detects the absence of the laser. This change of state is detected by the Arduino, which in turn activates a buzzer to emit an audible alarm. This mechanism acts as a security barrier, alerting of an intrusion or unauthorized access.
Arming and Disarming Control with RFID:
- The project includes an RFID-RC522 module that allows the alarm to be armed and disarmed using a specific RFID card. By presenting the authorized card, the system switches between armed and disarmed states. This means that, when the alarm is armed, any interruption of the laser beam will activate the buzzer. When disarming the alarm, the system will not react to beam interruptions, avoiding false alarms.
- Arming and Disarming Control with RFID:
- The project includes an RFID-RC522 module that allows the alarm to be armed and disarmed using a specific RFID card. By presenting the authorized card, the system switches between armed and disarmed states. This means that, when the alarm is armed, any interruption of the laser beam will activate the buzzer. When disarming the alarm, the system will not react to beam interruptions, avoiding false alarms.
Alarm Status Indicator:
- In addition to the buzzer, a laser connected to the Arduino indicates the alarm status. This laser turns on when the alarm is armed and turns off when the alarm is disarmed, providing a visual indication of the system status.
- Alarm Status Indicator:
- In addition to the buzzer, a laser connected to the Arduino indicates the alarm status. This laser turns on when the alarm is armed and turns off when the alarm is disarmed, providing a visual indication of the system status.
Reading and Displaying RFID Card UID:
- Each time an RFID card is brought close to the module, the system reads its UID (Unique Identifier) and displays it on the serial monitor. This allows verification of whether the presented card is the one authorized to control the alarm or not. Even if the card is not authorized, the UID is displayed to facilitate access monitoring and control.
- Reading and Displaying RFID Card UID:
- Each time an RFID card is brought close to the module, the system reads its UID (Unique Identifier) and displays it on the serial monitor. This allows verification of whether the presented card is the one authorized to control the alarm or not. Even if the card is not authorized, the UID is displayed to facilitate access monitoring and control.
Applications and Expansion:
This laser alarm system can be used in a variety of security applications, such as protecting entrances, windows, or restricted areas. In addition, the project is easily expandable; multiple laser sensors can be added to cover a larger area, or more functionalities can be incorporated such as SMS alerts, integration with home automation systems, or even remote monitoring via the Internet.
With this project, you not only learn how to work with components like laser sensors, RFID modules, and Arduino, but you also get a hands-on introduction to security and access control systems. It's a great way to explore the intersection between hardware and software, and how the two can be combined to create practical, effective real-world solutions.
Arduino Nano
The Arduino Nano is a small, full-featured, breadboard-compatible board based on the ATmega328 (Arduino Nano 3.x). It has more or less the same functionality as the Arduino Duemilanove, but in a different package. It only lacks a DC power connector and is powered by a Mini-B USB cable instead of a standard one.
A socket for arduino
Female pins
Dupont cables female male
Module Laser ky-008
This module specially designed for Arduino emits easily, quickly and accurately a laser beam produced by this component
It is a Laser Emitting Diode that operates at 5V and emits at a wavelength of 650nm.
Technical characteristics:
Working voltage: 5V
Wavelength: 650nm
Power 5 mW
Color: Red
Material: PCB
Dimensions: 2.3×1.5×0.9cm
Laser Receiver Module
Description
Detecting the light beam of a laser pointer will now be easier with the help of this sensor.
When light is focused on the sensor, it changes the voltage at its output.
It can be used together with the laser module to build counting systems, intrusion detection, remote data transmission.
TECHNICAL SPECIFICATIONS
- Operating voltage: 5V DC
- Salida digital TTL
- Output high level (5V) when receiving laser signal
- Low level output (0V) when no laser signal is received
RC522 RFID Module
Rfid Module Rc522 13.56mhz Card And Keychain Arduino
The module uses 3.3V as a supply voltage and is controlled via the SPI protocol, making it compatible with almost any microcontroller, Arduino or development board.
The RC522 uses an advanced modulation and demodulation system for all types of 13.56Mhz passive devices. The device handles ISO14443A and supports Quick CRYPTO1 and MIFARE encryption algorithms.
The RC522 MF circuit is used for 13.56Mhz wireless communication to write or read data for low power, low cost and small size applications. Ideal for portable devices or cards.
Features Model: MF522-ED
Operating current: 13-26mA at 3.3V
Standby current: 10-13mA at 3.3V
Sleep-mode current: <80µA
Peak current: 30mA
Operating frequency: 13.56Mhz
Reading distance: 0 to 60mm
Communication protocol: SPI
Maximum data rate: 10Mbit/s
Dimensions: 40 x 60 mm
Operating temperature: -20 to 80ºC
Operating humidity: 5%-95%
Maximum SPI speed: 10Mbit/s
Descargar PCB –> pcb ardunano
Circuit
Source Code
#include <SPI.h>
#include <MFRC522.h>
//SDA (SS) a Pin 10 del Arduino
//SCK a Pin 13 del Arduino
//MOSI a Pin 11 del Arduino
//MISO a Pin 12 del Arduino
//IRQ a N/C (no conectado)
//GND a GND del Arduino
//RST a Pin 9 del Arduino
//3.3V a 3.3V del Arduino
const int pinReceptorLaser = 8; // Pin digital donde está conectado el receptor láser
const int pinBuzzer = A4; // Pin digital donde está conectado el buzzer
const int pinRST = 9; // Pin RST del módulo RFID-RC522
const int pinSS = 10; // Pin SDA del módulo RFID-RC522
int estadoReceptorLaser = 0; // Variable para almacenar el estado del receptor láser
bool alarmaArmada = false; // Variable para controlar si la alarma está armada
bool alarmaActiva = false; // Variable para controlar el estado de la alarma
const int pinLED = 2; // Pin digital donde está conectado el LED
MFRC522 lectorRFID(pinSS, pinRST); // Crear instancia del objeto MFRC522
// UID de la tarjeta autorizada
byte UIDAutorizado[] = {0xC5, 0x81, 0xB6, 0x35};
void setup() {
pinMode(pinReceptorLaser, INPUT);
pinMode(pinLED, OUTPUT); // Configurar el pin del emisor Laser como salida
pinMode(pinBuzzer, OUTPUT);
Serial.begin(9600); // Iniciar comunicación serial para debug
SPI.begin(); // Iniciar bus SPI
lectorRFID.PCD_Init(); // Iniciar módulo MFRC522
Serial.println("Coloca la tarjeta RFID...");
}
void loop() {
estadoReceptorLaser = digitalRead(pinReceptorLaser); // Leer el estado del receptor láser
Serial.print("Estado del receptor láser: ");
Serial.println(estadoReceptorLaser);
// Verificar si hay una tarjeta RFID
if (lectorRFID.PICC_IsNewCardPresent() && lectorRFID.PICC_ReadCardSerial()) {
digitalWrite(pinLED, HIGH); // Encender el LED cuando la alarma esté armada
if (esAutorizada(lectorRFID.uid.uidByte, lectorRFID.uid.size)) {
alarmaArmada = !alarmaArmada; // Alternar el estado de armado de la alarma
alarmaActiva = false; // Resetear el estado de la alarma
if (alarmaArmada) {
Serial.println("Tarjeta RFID autorizada detectada, alarma armada.");
} else {
Serial.println("Tarjeta RFID autorizada detectada, alarma desarmada.");
digitalWrite(pinLED, LOW); // Apagar el LED cuando la alarma esté desarmada
}
} else {
Serial.println("Tarjeta RFID no autorizada detectada.");
}
lectorRFID.PICC_HaltA(); // Detener lectura de la tarjeta
}
// Activar la alarma si está armada y el receptor láser está en LOW
if (alarmaArmada) {
alarmaActiva = true;
}
// Controlar el buzzer basado en el estado de la alarma
if (alarmaActiva) {
estadoReceptorLaser = digitalRead(pinReceptorLaser); // Leer el estado del receptor láser
if (estadoReceptorLaser == 0) {
digitalWrite(pinBuzzer, HIGH); // Encender el buzzer si la alarma está activa
}
} else {
digitalWrite(pinBuzzer, LOW); // Apagar el buzzer si la alarma no está activa
}
delay(100); // Pequeña pausa para evitar lecturas erráticas
}
bool esAutorizada(byte *uid, byte tamanoUID) {
// Verificar si el UID leído coincide con el UID autorizado
if (tamanoUID != sizeof(UIDAutorizado)) {
return false;
}
for (byte i = 0; i < tamanoUID; i++) {
if (uid[i] != UIDAutorizado[i]) {
return false;
}
}
return true;
}