Esta es una biblioteca Arduino de bajo nivel optimizada para leer y escribir registros NRF24L01 (+) utilizando una interfaz SPI. Debe usarse en combinación con una clase derivada que contiene una funcionalidad de lectura, escritura y configuración de nivel superior.
Conecte el NRF24L01 (+) a cualquier placa Arduino que contenga:
Las retransmits o la pérdida de comunicación pueden ocurrir al conectar el NRF24L01 directamente a la 3.3V de una placa Arduino, porque muchos tableros Arduino no pueden entregar suficiente potencia para el chip NRF24L01. Esto se puede resolver con un regulador de voltaje separado o un adaptador de potencia NRF24L01.
Un transceptor inalámbrico NRF24L01 o NRF24L01 (+) de 2.4GHz conectado a una placa Arduino Uno con un regulador de voltaje de 3.3V separado y 100UF ELCO:
Para aumentar la confiabilidad de la comunicación, use un adaptador de potencia NRF24L01 con un regulador de voltaje de 3.3V separado, como:
| NRF24L01+ Alfiler | NRF24L01+ Función | NRF24L01+ adaptador | Arduino Uno/Mini | Mega2560 | ESP8266 Notar |
|---|---|---|---|---|---|
| +3.3V | 3.3V directo | - | 3.3V | 3.3V | 3.3V |
| - | +5V a través del adaptador | +5v | +5v | +5v | - |
| 1 | Gnd | Gnd | Gnd | Gnd | Gnd |
| 3 | Ceñudo | Ceñudo | 7 | 7 | D0 |
| 4 | CSN | CSN | 8 | 8 | D8 |
| 6 | Mosi | mes | 11 | 51 | D7 |
| 7 | Miso | MI | 12 | 50 | D6 |
| 5 | Sck | Sck | 13 | 52 | D5 |
Interfaz NRF24L01 (+) | RegistroCess
El pin CE debe controlarse dentro de la clase derivada.
Se utilizan las siguientes bibliotecas:
# include < nRF24L01Iface.h > class nRF24L01Example : nRF24L01Iface
{
public:
// Constructor, initialize base class with SPI clock and SPI chip-select
nRF24L01Example ( uint32_t spiClock, uint8_t cePin, uint8_t csnPin) :
nRF24L01Iface (spiClock, csnPin),
_cePin (cePin)
{
};
// Read status register
uint8_t readStatus () {
// Read status register
return readRegister (REG_STATUS);
}
// Read from config register
uint8_t readConfig () {
// Read config register
return readRegister (REG_CONFIG);
}
// Write to config register
void writeConfig ( uint8_t val) {
// Write to config register
writeRegister (REG_CONFIG, val);
}
// Write to TX pipe (0) registers
void openWritePipe0 ( const uint8_t *address) {
// Write 5 Bytes transmit pipe
// Now pipe 0 cannot be used for receive
writeRegister (REG_TX_ADDR, address, 5 );
}
// More functions such as read and write
// ...
private:
uint8_t _cePin;
}; // CE pin to enable RX and TX modes
# define CE_PIN 7
// SPI chip select pin
# define CSN_PIN 8
// Create object and initialize with SPI clock, CE pin and SPI chip-select pin
static nRF24L01Example radio (( uint32_t )10000000UL, CE_PIN, CSN_PIN); // Read status register
uint8_t status = radio.readStatus();
// Read from config register
uint8_t config = radio.readConfig();
// Write to config register
radio.writeConfig( 0x08 );
// Define an address pipe for transmit
const uint8_t pipeAddress[ 5 ] = { 0x55 , 0xa5 , 0x5a , 0xaa , 0x99 };
// Configure write pipe0
radio.openWritePipe0(pipeAddress);