This is a work in progress for an NRF2401P
Dependents: NRF_receiver sender locker4 Weather_Station_Ofiicial ... more
About
This is a simple library to drive the nRF24l01+.
Hardware
This uses the commonly available breakout. The connections are shown below
Software
Use case: For a simple transmitter
tx code snipet
#include "NRF2401P.h" int main() { * * long long addr1=0xAB00CD; // setup address - any 5 byte number - same as RX * int channel =0x12; // [0-126] setup channel, must be same as RX * bool txOK; * char msg[32]; * char ackData[32]; * char len; * * // Setup * NRF2401P nrf1(PTD6,PTD7, PTD5,PTD4, PTC12); //mosi, miso, sclk, csn, ce) * nrf1.quickTxSetup(channel, addr1); // sets nrf24l01+ as transmitter * * // transmit * strcpy (msg, "Hello"); * txOK= nrf1.transmitData(msg,strlen(msg)); * * // read ack data if available * if (nrf1.isAckData()) { * len= nrf1.getRxData(ackData); // len is number of bytes in ackData * } *}
Use case: For a simple receiver
rx code snipet
#include "NRF2401P.h" *int main(){ * * long long addr1=0xAB00CD; // setup address - any 5 byte number - same as TX * int channel =0x12; // [0-126] setup channel, must be same as TX * bool txOK; * char msg[32]; * char ackData[32]; * char len; * * // Setup * NRF2401P nrf1(PTD6,PTD7, PTD5,PTD4, PTC12); //mosi, miso, sclk, csn, ce) * nrf1.quickRxSetup(channel, addr1); // sets nrf24l01+ as receiver, using pipe 1 * * // set ack data * sprintf(ackData,"Ack data"); * nrf1.acknowledgeData(ackData, strlen(ackData),1); // ack for pipe 1 * * // receive * while (! nrf1.isRxData()); // note this blocks until RX data * len= nrf1.getRxData(msg); // gets the message, len is length of msg * *}
Diff: NRF2401P.cpp
- Revision:
- 7:621a5b0cf1aa
- Parent:
- 6:77ead8abdd1c
- Child:
- 8:3e027705ce23
diff -r 77ead8abdd1c -r 621a5b0cf1aa NRF2401P.cpp --- a/NRF2401P.cpp Sun Jul 05 21:45:51 2015 +0000 +++ b/NRF2401P.cpp Sun Jul 05 22:20:40 2015 +0000 @@ -173,19 +173,6 @@ } } -/** -*Speed : -‘0x00’ – 1Mbps -‘0x01’ – 2Mbps -‘0x02’ – 250kbps -‘0x03’ – Reserved -Power: -'0x00' – -18dBm -'0x01' – -12dBm -'0x02' – -6dBm -'0x03' – 0dBm -* Return: 0 for success, non-zero for fail -*/ char NRF2401P::setRadio(char speed, char power) { char val=0, chk=0;