Это оптимизированная библиотека Arduino Нижнего уровня для чтения и записи регистров NRF24L01 (+) с использованием интерфейса SPI. Его следует использовать в сочетании с производным классом, который содержит функциональность чтения, записи и конфигурации более высокого уровня.
Подключите NRF24L01 (+) к любой плате Arduino, которая содержит:
Ретрансмиты или потеря связи могут возникнуть при подключении NRF24L01 непосредственно к 3,3 В доски Arduino, потому что многие платы Arduino не могут обеспечить достаточную энергию для чипа NRF24L01. Это может быть решено с помощью отдельного регулятора напряжения или адаптера мощности NRF24L01.
Nordic NRF24L01 или NRF24L01 (+) 2,4 ГГц беспроводной приемопередатчик, подключенный к плате Arduino UNO с отдельным регулятором напряжения 3,3 В и 100 UF ELCO:
Чтобы повысить надежность связи, используйте адаптер мощности NRF24L01 с отдельным регулятором напряжения 3,3 В, таким как:
| NRF24L01+ Приколоть | NRF24L01+ Функция | NRF24L01+ адаптер | Arduino uno/mini | Mega2560 | ESP8266 Nodemcu |
|---|---|---|---|---|---|
| +3,3 В. | 3,3 В | - | 3,3 В. | 3,3 В. | 3,3 В. |
| - | +5 В через адаптер | +5 В. | +5 В. | +5 В. | - |
| 1 | Гнездо | Гнездо | Гнездо | Гнездо | Гнездо |
| 3 | CE | CE | 7 | 7 | D0 |
| 4 | CSN | CSN | 8 | 8 | D8 |
| 6 | Моси | МО | 11 | 51 | D7 |
| 7 | Мисо | Мио | 12 | 50 | D6 |
| 5 | SCK | SCK | 13 | 52 | D5 |
NRF24L01 (+) Интерфейс | RegisterAccess
PIN -штифт CE должен управляться внутри производного класса.
Используются следующие библиотеки:
# 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);