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.h
- Revision:
- 11:07f76589f00a
- Parent:
- 10:8a217441c38e
- Child:
- 13:5cbc726f2bbb
--- a/NRF2401P.h Sat Jul 11 11:18:37 2015 +0000 +++ b/NRF2401P.h Sat Jul 11 14:56:17 2015 +0000 @@ -174,8 +174,25 @@ void start(); char* statusString(); + + /** Print out 1 byte content of register + * + * @param name Name of register to print. + * @param address Register address of interest. + * @param newline By default print a trailing newline, can disable by setting false. + */ + void printReg(char* name, char address, bool newline=true); - /** Print details about the radio setup and configuration + /** Print out 'width' bytes content of register + * + * @param name Name of register to print. + * @param address Register address of interest. + * @param width Number of bytes to print. + * @param newline By default print a trailing newline, can disable by setting false. + */ + void printReg(char* name, char address, char width, bool newline=true); + + /** Print verbose details about the radio setup and configuration * */ void printDetails();