UDP.available()
Описание
Функция возвращает количество принятых байт (символов), доступных для считывания из буфера.
Эту функцию можно вызывать только после вызова UDP.parsePacket().
Функция available() является наследником вспомогательного класса Stream.
Синтаксис
UDP.available();
Параметры
нет
Возвращаемые значения
количество байт, доступных для считывания.
Пример
#include <SPI.h>
#include <Ethernet.h>
#include <EthernetUdp.h>
// Ниже укажите MAC-адрес и IP-адрес вашего контроллера.
// IP-адрес будет зависеть от настроек вашей локальной сети:
byte mac[] = {
0xDE, 0xAD, 0xBE, 0xEF, 0xFE, 0xED };
IPAddress ip(192, 168, 1, 177);
unsigned int localPort = 8888; // номер локального порта для прослушивания
// Создание экземпляра класса EthernetUDP для отправки и получения UDP-пакетов
EthernetUDP Udp;
char packetBuffer[UDP_TX_PACKET_MAX_SIZE]; //буфер для хранения входящих пакетов
void setup() {
// запуск Ethernet и UDP:
Ethernet.begin(mac,ip);
Udp.begin(localPort);
}
void loop() {
int packetSize = Udp.parsePacket();
if(Udp.available())
{
Serial.print("Received packet of size ");
Serial.println(packetSize);
Serial.print("From ");
IPAddress remote = Udp.remoteIP();
for (int i =0; i < 4; i++)
{
Serial.print(remote[i], DEC);
if (i < 3)
{
Serial.print(".");
}
}
Serial.print(", port ");
Serial.println(Udp.remotePort());
// считываем пакет в буфер packetBufffer
Udp.read(packetBuffer,UDP_TX_PACKET_MAX_SIZE);
Serial.println("Contents:");
Serial.println(packetBuffer);
}
}

