Esta é uma biblioteca Arduino de baixo nível otimizada para ler e gravar registros NRF24L01 (+) usando uma interface SPI. Ele deve ser usado em combinação com uma classe derivada que contém a funcionalidade de leitura, gravação e configuração de nível mais alto.
Conecte o NRF24L01 (+) a qualquer placa Arduino que contenha:
Os retransmissão ou a perda de comunicação podem ocorrer ao conectar o NRF24L01 diretamente ao 3,3V de uma placa Arduino, porque muitas placas Arduino não podem fornecer energia suficiente para o chip NRF24L01. Isso pode ser resolvido com um regulador de tensão separado ou adaptador de energia NRF24L01.
Um transceptor sem fio nórdico NRF24L01 ou NRF24L01 (+) de 2,4 GHz conectado a uma placa Arduino UNO com um regulador de tensão de 3,3V separado e 100UF elco:
Para aumentar a confiabilidade da comunicação, use um adaptador de energia NRF24L01 com um regulador de tensão de 3,3V separado, como:
| NRF24L01+ Alfinete | NRF24L01+ Função | NRF24L01+ adaptador | Arduino Uno/Mini | Mega2560 | ESP8266 Nodemcu |
|---|---|---|---|---|---|
| +3,3V | 3.3V direto | - | 3.3V | 3.3V | 3.3V |
| - | +5V via adaptador | +5V | +5V | +5V | - |
| 1 | Gnd | Gnd | Gnd | Gnd | Gnd |
| 3 | CE | CE | 7 | 7 | D0 |
| 4 | CSN | CSN | 8 | 8 | D8 |
| 6 | Mosi | MO | 11 | 51 | D7 |
| 7 | Miso | MI | 12 | 50 | D6 |
| 5 | Sck | Sck | 13 | 52 | D5 |
interface nrf24l01 (+) | RegisterAccess
O pino CE deve ser controlado dentro da classe derivada.
As seguintes bibliotecas são usadas:
# 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);