Documentos de Académico
Documentos de Profesional
Documentos de Cultura
Arduino Uno
Arduino Uno
Material
-Arduino Uno Rev 3
-Mdulo Bluetooth JY-MCU
-Dispositivo Android con Bluetooth
-Leds rojo, amarillo y verde
-Resistencias 220 ohms x 3, 5K6, 10K
Mdulo Bluetooth
El Bluetooth es un estndar de comunicacin inalmbrica que permite la
transmisin de datos a travs de radiofrecuencia en la banda de 2,4 GHz.
Existen muchos mdulos Bluetooth para usarlos en nuestros proyectos de
electrnica, pero los ms utilizados son los mdulos de JY-MCU, ya que son
muy econmicos y fciles de encontrar en el mercado. Son mdulos
pequeos y con un consumo muy bajo que nos permitirn agregar
Comandos AT
Los comandos AT son un tipo de comandos que sirven para configurar el
mdulo Bluetooth a travs de un microcontrolador, un ordenador o con
cualquier dispositivo que posea una comunicacin serie (Tx/Rx). Son unas
instrucciones que nos permiten cambiar los baudios del mdulo, el PIN, el
nombre, etc. Para usar los comandos AT el mdulo Bluetooth no debe estar
vinculado a ningn dispositivo (led rojo del mdulo parpadeando). Segn las
especificaciones del mdulo, el tiempo que se tiene que respetar entre el
envo de un comando AT y otro tiene que ser de 1 segundo. Si se enva un
comando AT y en menos de un segundo se enva otro, el mdulo no
devuelve respuesta.
Ahora vamos a configurar el mdulo Bluetooth a travs de comandos AT
enviados desde el Monitor Serial del Arduino. El cdigo del Arduino
necesario tanto por el mdulo HC-05 como el HC-06 es el siguiente:
1
2
#include <SoftwareSerial.h> //Librera que permite establecer comunicacin serie en
3
4
//Aqu conectamos los pins RXD,TDX del mdulo Bluetooth.
5
SoftwareSerial BT(10,11); //10 RX, 11 TX.
6
void setup()
7
{
8
BT.begin(9600); //Velocidad del puerto del mdulo Bluetooth
9
Serial.begin(9600); //Abrimos la comunicacin serie con el PC y establecemos velo
10 }
11
12 void loop()
13 {
if(BT.available())
14
{
15
Serial.write(BT.read());
16
}
17
if(Serial.available())
18
{
19
BT.write(Serial.read());
20
}
21 }
22
23
Entre los dos modelos de mdulo Bluetooth existen diferencias a la hora de
enviar los comandos AT:
HC-06
En el HC-06 solo se necesitan cuatro pins: Vcc, GND, TXD y RXD. El pin KEY
no es necesario.
Al enviar un comando AT no se debe enviar ningn carcter de LF (nueva
lnea) ni CR (retorno de carro) al final del comando. En el Monitor Serial del
Arduino tenemos que poner No hay fin de lena.
Los comandos AT que se pueden enviar en este mdulo son los siguientes:
Comando AT
Descripcin
Respuesta
AT
Test de comunicacin.
Responde con
un OK
AT+VERSION
AT+BAUDx
2 = 2400 bps
3 = 4800 bps
OKlinvorV1.8
AT+BAUD4 Configura
la velocidad a 9600
baud rate Responde
con OK9600
AT+NAMEDIYMakers
Configura el nombre
del modulo a
DIYMakers Responde
con OKsetname
AT+PINxxxx
AT+PIN1122
Configura el pin a
1122 Responde
con OKsetPIN
HC-05
El HC-05 es necesario poner el pin KEY del mdulo a nivel alto (5V) para
enviar comandos AT. Adems, al enviar un comando AT hay que enviar un
carcter de LF (nueva lnea) y de CR (retorno de carro) al final del comando.
Por lo tanto, en el Monitor Serial de Arduino pondremos Ambos NL & CR.
Cdigo Arduino
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
/*
www.diymakers.es
by A.Garca
Arduino + Bluetooth
Tutorial en: http://diymakers.es/arduino-bluetooth/
*/
#include <SoftwareSerial.h> //Librera que permite establecer
comunicacin serie en otros pins
//Aqu conectamos los pins RXD,TDX del mdulo Bluetooth.
SoftwareSerial BT(10,11); //10 RX, 11 TX.
int green=4;
int yellow=5;
int red=6;
char cadena[255]; //Creamos un array de caracteres de 256 cposiciones
int i=0; //Tamao actual del array
void setup()
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
BT.begin(9600);
Serial.begin(9600);
pinMode(green,OUTPUT);
pinMode(yellow,OUTPUT);
pinMode(red,OUTPUT);
void loop()
{
//Cuando haya datos disponibles
if(BT.available())
{
char dato=BT.read(); //Guarda los datos carcter a carcter en la
variable "dato"
cadena[i++]=dato; //Vamos colocando cada carcter recibido en el
array "cadena"
//Cuando reciba una nueva lnea (al pulsar enter en la app) entra en
la funcin
if(dato=='\n')
{
Serial.print(cadena); //Visualizamos el comando recibido en el
Monitor Serial
//GREEN LED
if(strstr(cadena,"green on")!=0)
{
digitalWrite(green,HIGH);
}
if(strstr(cadena,"green off")!=0)
{
digitalWrite(green,LOW);
}
//YELLOW LED
if(strstr(cadena,"yellow on")!=0)
{
digitalWrite(yellow,HIGH);
}
if(strstr(cadena,"yellow off")!=0)
{
digitalWrite(yellow,LOW);
}
//RED LED
if(strstr(cadena,"red on")!=0)
{
digitalWrite(red,HIGH);
}
if(strstr(cadena,"red off")!=0)
{
digitalWrite(red,LOW);
}
//ALL ON
if(strstr(cadena,"on all")!=0)
{
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
digitalWrite(green,HIGH);
digitalWrite(yellow,HIGH);
digitalWrite(red,HIGH);
}
//ALL OFF
if(strstr(cadena,"off all")!=0)
{
digitalWrite(green,LOW);
digitalWrite(yellow,LOW);
digitalWrite(red,LOW);
}
BT.write("\r"); //Enviamos un retorno de carro de la app. La app
ya crea una lnea nueva
clean(); //Ejecutamos la funcin clean() para limpiar el array
}
}
}
//Limpia el array
void clean()
{
for (int cl=0; cl<=i; cl++)
{
cadena[cl]=0;
}
i=0;
}
Luego solo hay que poner los comandos para encender y apagar los leds.
Cuando se escribe un comando tenemos que pulsar Enterdel teclado para
enviarlos al Arduino. En el terminal no se pueden borrar caracteres, por lo
que si nos equivocamos pulsamos Enter y lo volvemos a escribir.