1. El Octavo Bit
  2. / Arduino
  3. / Proyectos para Arduino
  4. / Control Remoto en Arduino con la librería IRremote

Control Remoto en Arduino con la librería IRremote

| Actualizado:
Comentarios: 0

Control Remoto en Arduino con la librería IRremote
Control Remoto en Arduino con la librería IRremote

¿Qué te parece utilizar un mando para apagar o encender la luz? En este post vamos a utilizar un mando a distancia y un sensor infrarrojo con el que encender o apagar un led. Son elementos que podrás aplicar en futuros proyectos con Arduino.

Los detectores infrarrojos son pequeños microchips con una célula fotoeléctrica que están configurados para recibir la luz infrarroja. Casi siempre se utilizan para la detección del mando a distancia que usa cualquier TV o equipo de sonido.

Encender un led con nuestro control remoto.

En este tutorial trataremos de encender un led presionando un botón y usaremos otro botón para apagarlo. Vamos a trabajar con un emisor, el mando a distancia, y un receptor que reciba la luz infrarroja.

Material necesario:

  • Arduino Uno o similar.
  • Protoboard.
  • Cables.
  • Sensor infrarrojo.
  • Mando a distancia.
  • Led.
  • Resistencia de 220 Ohm.
Sensor infrarrojo VS1838b

Este sensor posee un filtro interno para detectar frecuencias infrarrojas cercanas a 38KHz, lo que lo hace compatible con la mayoría de mandos infrarrojos; posee tres pines de conexión.

Control remoto:

Control infrarrojo remoto e la TV, utilizado para encender y apagar el led

Cada fabricante de mandos desarrolla su propio protocolo de comunicación, por lo que no todos son iguales. Pero sí tienen en común el uso de unas señales que oscilan en unas frecuencias de 36 a 50KHz, siendo la más utilizada la de 38KHz.

Montaje del circuito.

Esquema para encender un led con  nuestro control remoto

Lo primero que debemos saber es el código que envía nuestro control remoto para poder identificar si encendemos o apagamos el led.

Como no conocemos la codificación del mando, primero vamos a identificar el código que regula los botones que vamos a utilizar, usaremos el boton 1 y 2 del mando.

#include "IRremote.h"
int ReceptorIR = 11;
IRrecv irrecv (ReceptorIR);
decode_results Valor;

void setup() {
  Serial.begin(9600);
  irrecv.enableIRIn();  // Inicializa el receptor
}

void loop() {
  if(irrecv.decode(&Valor)){
    // es para averiguar el valor del botón 1 y 2
    Serial.print("0x");
    Serial.println(Valor.value, HEX);  // Mostrar en el monitor
    delay(50);
    irrecv.resume(); // Se prepara para recibir el siguiente dato
  }
}

Expliquemos un poco este código: primero, cargamos la librería IRremote.h que es la encargada de codificar los datos y devolvernos el valor en hexadecimal. Con IRrecv irrecv estamos indicando que el pin (11) será el encargado de recibir los datos. Los datos recibidos, los guardaremos en Valor, con la instrucción decode_results.

En el bloque setup tan solo inicializamos el puerto de serie y el receptor con la instrucción irrecv.enableIRIn().

Y con el bloque loop, en el momento que la placa reciba una señal nos la mostrará en el monitor. Si presionamos un botón, nos debe mostrar en el monitor el código correspondiente para ese botón.

Veremos que cada botón envía un código diferente, guardamos los de los botones 1 y 2. Para ver el código hexadecimal utilizamos el monitor serial.

Monitor serial con el código del botón 1 y 2

Una vez que tenemos identificados los botones podemos pasar a programar para encender o apagar un led, según el botón que presionemos. El código es:

#include "IRremote.h"
int ReceptorIR = 11;
IRrecv irrecv (ReceptorIR);
decode_results Valor;

void setup() {
  Serial.begin(9600);
  pinMode(6, OUTPUT);
  irrecv.enableIRIn();
}

void loop() {
  if(irrecv.decode(&Valor)){
    // es para averiguar el valor del botón 1 y 2
    Serial.print("0x");
    Serial.println(Valor.value, HEX);  // Mostrar en el monitor
    switch(Valor.value){
      case 0xE0E020DF:        // boton 1
      digitalWrite(6, HIGH);  // Encender el led
      break;
      case 0xE0E0A05F:          // boton 2
      digitalWrite(6, LOW);   // Apagar el led
      break;
    }
    delay(50);
    irrecv.resume();
  }
}

Es un programa en el que podemos fácilmente aumentar el número de leds que podemos utilizar.

Artículos que te pueden interesar

Detector de incendios con Arduino
Detector de incendios con Arduino y el sensor KY-026

Detector de incendios con Arduino y el sensor KY-026

| Actualizado:
Comentarios: 0

El módulo KY-026 es un sensor de llama que permite detectar un fuego gracias a un sensor óptico sensible a la radiación emitida por la llama. El sensor puede detectar fuentes de luz en el rango de una longitud de…

Display de 4 dígitos y 7 segmentos
Funcionamiento del display de 4 dígitos y 7 segmentos con Arduino

Funcionamiento del display de 4 dígitos y 7 segmentos con Arduino

| Actualizado:
Comentarios: 0

Para mostrar más información, como la hora o la temperatura, necesitamos un display de más dígitos o conectar varios display de un solo dígito. En este tutorial veremos cómo conectar un display de 4 dígitos a Arduino. Contenido 1 Esquema…

Módulo bluetooth HC-06 con Arduino
Tutorial básico de uso del módulo bluetooth HC-06 en Arduino

Tutorial básico de uso del módulo bluetooth HC-06 en Arduino

| Actualizado:
Comentarios: 0

El objetivo de este tutorial es poder añadir un módulo bluetooth a nuestra placa de Arduino y poder comunicarnos con un teléfono móvil Android a través de una aplicación. Primero veremos cómo conectarlo al móvil y después, cómo configurar el…

Robot controlado por bluetooth con Arduino
¿Cómo hacer un coche controlado por bluetooth con Arduino?

¿Cómo hacer un coche controlado por bluetooth con Arduino?

| Actualizado:
Comentarios: 4

En este tutorial construiremos un robot móvil controlado por Bluetooth desde nuestro móvil a través de una aplicación de Android. El montaje y la puesta en funcionamiento de este pequeño coche es sencillo puesto que es el resultado de la…

Comentarios - 0

Deja un comentario

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *