Controle uma lâmpada AC usando qualquer controle remoto infravermelho com um Arduino e relé.
Neste tutorial, aprenderemos a usar um controle remoto infravermelho para operar uma lâmpada AC via um Arduino e um módulo de relé. Este projeto envolve decodificar os sinais do controle remoto e usá-los para controlar o relé, que por sua vez ligará e desligará a lâmpada AC. Ao final deste tutorial, você será capaz de usar qualquer controle remoto infravermelho para controlar sua luminária.
Usaremos um receptor infravermelho para capturar os sinais do controle remoto, e o Arduino interpretará esses sinais para realizar ações específicas. O código fornecido permitirá que você selecione o tipo de controle remoto (preto ou branco) e se está usando uma placa de circuito impresso ou um módulo bare para o receptor. Certifique-se de assistir ao vídeo associado para detalhes e esclarecimentos adicionais (no vídeo em 0:00).
Hardware Explicado
Para este projeto, os principais componentes incluem a placa Arduino, um módulo receptor infravermelho e um módulo relé. O receptor infravermelho é responsável por capturar os sinais do controle remoto e enviá-los para o Arduino. O módulo relé atua como um interruptor para controlar a lâmpada AC, permitindo que ela ligue e desligue com base nos sinais recebidos.
O receptor infravermelho geralmente opera a uma frequência de 38 kHz e pode detectar sinais a uma distância de aproximadamente 10 a 15 metros. Assim que o Arduino recebe o sinal, ele o decodifica e usa o relé para controlar a energia da lâmpada.
Instruções de Fiação

Comece a fiação conectando o módulo receptor infravermelho ao Arduino. O pino VCC do receptor conecta-se ao pino 5V no Arduino, e o pino de terra conecta-se a um pino GND. O pino de sinal do receptor infravermelho deve ser conectado a um pino digital.11no Arduino.
Em seguida, conecte o módulo de relé. O pino de controle do relé deve ser conectado ao pino digital.2no Arduino. Além disso, conecte os pinos VCC e GND do relé aos 5V e GND do Arduino, respectivamente. Por fim, conecte a lâmpada AC ao relé de acordo com as especificações do relé para garantir uma operação segura.
Exemplos de Código e Passo a Passo
Na fase de configuração do programa, inicializamos a comunicação serial e configuramos o pino do relé. O identificadorRECV_PINestá definido para11, que é onde o pino de sinal do receptor infravermelho está conectado. Isso nos permite receber dados do controle remoto.
void setup() {
Serial.begin(9600);
irrecv.enableIRIn(); // Start the receiver
pinMode(RELAY_PIN, OUTPUT); // define a pin for relay as OUTPUT
digitalWrite(RELAY_PIN, HIGH); // set relay to OFF at the beginning
}Na função de loop, verificamos continuamente sinais recebidos do controle remoto. Quando um sinal é detectado, o valor é decodificado e a ação correspondente é tomada com base na tecla pressionada.
void loop() {
if (irrecv.decode(&results)) {
Serial.println(results.value, HEX); // Print the received value
robojaxValidateCode(results.value); // Validate the code
irrecv.resume(); // Receive the next value
}
delay(100);
}OrobojaxValidateCodefunção verifica o código recebido em relação a valores conhecidos para o controle remoto. Dependendo de qual tecla é pressionada, ele executará a ação correspondente usando o relé.
void robojaxValidateCode(int cd) {
if (type == 'W' && !PCB) {
// Check White remote codes
for (int i = 0; i < sizeof(whiteRemote) / sizeof(int); i++) {
if (whiteRemote[i] == cd) {
Serial.print("Key pressed: ");
Serial.println(whiteRemoteKey[i]);
relayAction(whiteRemoteKey[i]); // Take action
}
}
}
}Nesta função, o código verifica se a tecla pressionada corresponde aos valores do array definido. Se uma correspondência for encontrada, chama orelayActionfunção para ligar ou desligar o relé, dependendo da tecla pressionada.
Demonstração / O que Esperar
Após completar a fiação e fazer o upload do código, você pode usar seu controle remoto infravermelho para controlar a lâmpada AC. Pressione as teclas designadas no controle remoto, e o relé deve ativar ou desativar a lâmpada conforme necessário. Certifique-se de testar cada tecla para ver sua resposta (no vídeo às 5:00).
Marcadores de vídeo
- 00:00 Iniciar
- 00:49 Introdução
- 02:00 Fiação e conexão
- 05:27 Código Arduino explicado
- 09:51 Demonstração de controle da lâmpada AC com controle remoto diferente
- 13:13 Usando o controle remoto da TV para controlar a lâmpada do ar-condicionado
/*
* Original library from - http://arcfn.com
*
* This Arduino code decodes any remote code and then you can control an AC load using a relay
* sold on eBay for Arduino.
* You have to select the type of your remote as Black or White in the code below
* and also select your receiver 1838 as either a PCB or bare module. See video for details
*
* You have to watch this video: https://youtu.be/muAkBQb24NI
* before proceeding with this code.
*
* Modified/Written by Ahmad Shamshiri
* on July 31, 2018 at 20:33 in Ajax, Ontario, Canada
* for Robojax.com
* Watch video instructions for this code: https://youtu.be/j5kb0WBpD30
* Get other Arduino codes from Robojax.com
*
*/
#include <IRremote.h>
int RECV_PIN = 11;
const char type ='W';// W for white, B for black. Must keep single quotes like 'B' or 'W'
const boolean PCB = 1;// if receiver is PCB set to 1, if not set to 0. See video for details
boolean displayCode = true;// to display remote code. if not, set to false
//***** Relay settings begins
const int RELAY_PIN = 2;//
const String ON="3";// turn relay ON with + key on remote
const String OFF="1";// turn relay OFF with - key on remote
//**** Relay settings ends
IRrecv irrecv(RECV_PIN);
// this is array holding codes for White Remote when used with PCB version of receiver
unsigned int whiteRemotePCB[] ={
0xE318261B, // CH-
0x511DBB, // CH
0xEE886D7F, // CH+
0x52A3D41F, // |<<
0xD7E84B1B, // >>|
0x20FE4DBB, // >||
0xF076C13B, // -
0xA3C8EDDB, // +
0x12CEA6E6, // EQ
0xC101E57B, // 0
0x97483BFB, // 100+
0xF0C41643, // 200+
0x9716BE3F, // 1
0x3D9AE3F7, // 2
0x6182021B, // 3
0x8C22657B, // 4
0x488F3CBB, // 5
0x449E79F, // 6
0x32C6FDF7, // 7
0x1BC0157B, // 8
0x3EC3FC1B // 9
};
// this is array holding codes for White Remote when used with non-PCB version of receiver
unsigned int whiteRemote[] ={
0xFFA25D, // CH-
0xFF629D, // CH
0xFFE21D, // CH+
0xFF22DD, // |<<
0xFF02FD, // >>|
0xFFC23D, // >||
0xFFE01F, // -
0xFFA857, // +
0xFF906F, // EQ
0xFF6897, // 0
0xFF9867, // 100+
0xFFB04F, // 200+
0xFF30CF, // 1
0xFF18E7, // 2
0xFF7A85, // 3
0xFF10EF, // 4
0xFF38C7, // 5
0xFF5AA5, // 6
0xFF42BD, // 7
0xFF4AB5, // 8
0xFF52AD // 9
};
// key lables of white remote
String whiteRemoteKey[] ={
"CH-",
"CH",
"CH+",
"|<<",
">>|",
">||",
"-",
"+",
"EQ",
"0",
"100+",
"200+",
"1",
"2",
"3",
"4",
"5",
"6",
"7",
"8",
"9"
};
// this is array holding codes for Black Remote when used with non-PCB version of receiver
unsigned int blackRemote[] ={
0xFF629D, // ^
0xFF22DD, // <
0xFF02FD, // OK
0xFFC23D, // >
0xFFA857, // v
0xFF6897, // 1
0xFF9867, // 2
0xF0C41643, // 3
0xFF30CF, // 4
0xFF18E7, // 5
0xFF7A85, // 6
0xFF10EF, // 7
0xFF38C7, // 8
0xFF5AA5, // 9
0xFF42BD, // *
0xFF4AB5, // 0
0xFF52AD // #
};
// this is array holding codes for Black Remote when used with PCB version of receiver
unsigned int blackRemotePCB[] ={
0x511DBB, // ^
0x52A3D41F, // <
0xD7E84B1B, // OK
0x20FE4DBB, // >
0xA3C8EDDB, // v
0xC101E57B, // 1
0x97483BFB, // 2
0xF0C41643, // 3
0x9716BE3F, // 4
0x3D9AE3F7, // 5
0x6182021B, // 6
0x8C22657B, // 7
0x488F3CBB, // 8
0x449E79F, // 9
0x32C6FDF7, // *
0x1BC0157B, // 0
0x3EC3FC1B // #
};
// Black remote key names
String blackRemoteKey[] ={
"^",
"<",
"OK",
">",
"v",
"1",
"2",
"3",
"4",
"5",
"6",
"7",
"8",
"9",
"*",
"0",
"#"
};
decode_results results;
void setup()
{
Serial.begin(9600);
// In case the interrupt driver crashes on setup, give a clue
// to the user what's going on.
Serial.println("Robojax IR Decode");
Serial.println("Control Relay with Remote");
irrecv.enableIRIn(); // Start the receiver
pinMode(RELAY_PIN,OUTPUT);// define a pin for relay as OUTPUT
digitalWrite(RELAY_PIN, HIGH);// set relay to OFF at the begining
}
void loop() {
if (irrecv.decode(&results)) {
if(displayCode)Serial.println(results.value, HEX);
robojaxValidateCode(results.value);// used the "robojaxValidateCode" bellow
irrecv.resume(); // Receive the next value
}
delay(100);
}
/*
* function: robojaxValidateCode
* validates the remote code and prints the correct key name
* cd is code passed from the loop
* Written by A. S. for Robojax
*/
void robojaxValidateCode(int cd)
{
// Robojax IR Remote decoder
int found=0;
if(type =='W' && !PCB)
{
// Robojax IR White Remote decoder
// if type is set to 'W' (white remote) and PCB=0 then check White remote code
for(int i=0; i< sizeof(whiteRemote)/sizeof(int); i++)
{
if(whiteRemote[i] ==cd)
{
Serial.print("Key pressed:");
Serial.println(whiteRemoteKey[i]);
relayAction(whiteRemoteKey[i]);// take action
found=1;
}// if matched
}// for
}else if(type =='W' && PCB){
// Robojax IR White Remote decoder
// if type is set to 'W' (white remote) and PCB=1 then check White remote code
for(int i=0; i< sizeof(whiteRemotePCB)/sizeof(int); i++)
{
if(whiteRemotePCB[i] ==cd)
{
Serial.print("Key pressed:");
Serial.println(whiteRemoteKey[i]);
relayAction(whiteRemoteKey[i]);// take action
found=1;
}// if matched
}// for
}else if(type =='B' && PCB){
// Robojax IR Black Remote decoder
// if type is set to 'B' (black remote) and PCB=1 then check Black remote code
for(int i=0; i< sizeof(blackRemotePCB)/sizeof(int); i++)
{
// Robojax IR black Remote decoder
if(blackRemotePCB[i] ==cd)
{
Serial.print("Key pressed:");
Serial.println(blackRemoteKey[i]);
relayAction(blackRemoteKey[i]);// take action
found=1;
}// if matched
}// for
}else{
// if type is set to 'B' (black remote) and PCB =0 then check Black remote code
for(int i=0; i< sizeof(blackRemote)/sizeof(int); i++)
{
// Robojax IR black Remote decoder
if(blackRemote[i] ==cd)
{
Serial.print("Key pressed:");
Serial.println(blackRemoteKey[i]);
relayAction(blackRemoteKey[i]);// take action
found=1;
}// if matched
}// for
}// else
if(!found){
if(cd !=0xFFFFFFFF)
{
Serial.println("Key unknown");
}
}// found
}// robojaxValidateCode end
/*
*
* relayAction()
* receives string "value" as input and based on the settings,
* turns relay pin HIGH or LOW
*/
void relayAction(String value)
{
// Robojax IR Relay control
if(value == ON)
{
digitalWrite(RELAY_PIN, LOW);// Turn relay ON
Serial.println("Relay Turned ON");
}
if(value == OFF)
{
digitalWrite(RELAY_PIN, HIGH);// Turn relay OFF
Serial.println("Relay Turned OFF");
}
}//relayAction end
Coisas que você pode precisar
-
Amazonas
-
eBay
Recursos e referências
Ainda não há recursos.
Arquivos📁
Nenhum arquivo disponível.