Serial.read()
Contenido
Descripción
Lee o captura un byte (un carácter) desde el puerto serie.
Nota: Lo que lee es un caracter en codigo ASCII.
Sintaxis
char variable = Serial.read();
Parametros
Retorno
El valor recuperado según el número de bits de datos configurado, o -1 si el buffer de entrada está vacío (int).
Advertencia
- Si por error no se verifica de antemano si hay datos disponibles, read() retornará 255 para byte en el caso que el valor real sea -1 (nada).
- El buffer en el caso de UNO y NANO es de 64 kB. Aunque esto se puede cambiar con la libreria HardwareSerial.h.
- El monitor serie nunca añade a la cadena escrita CR (\n) ni LF (\n) si haces un simple Enter. No asi si lo escribes en un block de notas y lo copias en la linea de envio.
Ejemplo 1
En este primer ejemplo usamos una variable tipo char para capturar el caracter.
void setup(){
Serial.begin(9600);
}
void loop(){
if (Serial.available()){ //Espera carácter
char car = Serial.read(); //Lee carácter enviado y lo borra del buffer
Serial.println(car); //Imprime carácter enviado
}
}
Si envias A se imprime A, si envias 1 se imprime 1.
Ejemplo 2
En este segundo ejemplo usamos una variable tipo byte para capturar carácter.
void setup(){
Serial.begin(9600);
}
void loop(){
if (Serial.available()){ //Espera carácter
byte car = Serial.read(); //Lee carácter enviado y lo borra del buffer
Serial.write(car); //Imprime carácter enviado
Serial.print(" = ");
Serial.println(car); //Imprime código ASCII carácter enviado
}
}
Si envias A se imprime 65, si envias 1 se imprime 49.
Tip: Nota que la única diferencia es que en el ejemplo 1 capturamos como char y en el segundo ejemplo como byte.
Ejemplo 3
En este ejemplo capturaremos varios caracteres y los almacenamos uno a uno en una variable tipo String.
String frase = "";
void setup(){
Serial.begin(9600);
}
void loop(){
while (Serial.available()){
char caracter = Serial.read();
frase.concat(caracter);
delay(10);
}
if (frase != ""){
Serial.println(frase);
frase = "";
}
}
Ejemplo 4
Este ejemplo recibe una matriz de ints.
int datos[10];
void setup(){
Serial.begin(9600);
}
void loop(){
if (Serial.available() >= 10 * sizeof(datos[0])){
Serial.readBytes((byte*)datos, 10 * sizeof(datos[0]));
}
}
Ejemplo 5
Mucha gente intenta probar este código enviando datos por el monitor serie y no le funciona, porque el Enter del monitor serie ejecuta la accion de enviar sin introducir los códigos ASCII CR (\r) ni LF (\n).
void setup(){
Serial.begin(9600);
}
void loop(){
if (Serial.available()){
String data = Serial.readStringUntil('\n');
Serial.println(data);
}
}
Nota: Para que te funcione este codigo escribe algo y le das entre en un Notepad++ por ejemplo y luego copia esa cadena completa y la pegas en el monitor serie y envias.
Ejemplo 6
Si leemos el buffer vacio notamos que la respuesta en -1.
void setup(){
Serial.begin(9600);
delay(1000);
Serial.println(Serial.read());
}
void loop(){
//Nada
}
Vea también
Referencias
- Seril.print() - Referencias Arduino
- Comunicacion serie - Enrique Crespo
- Cadena de texto por puerto serie - Luis Llamas
- Matriz por puerto serie - Luis Llamas
- Serial.print() - Manuel Delgado
- Serial print - HetPRO
- Serial.print() - Curso sobre Arduino MEGA
- Difference between Serial.print() and Seria.write() - Stack Exchange