RX basestation controller of the NERF demo. Designed for use with the FRDM-K64F and the nRF24L01P module.
Fork of NerfGun_nRF24L01P_RX by
main.cpp
- Committer:
- clarkjarvis
- Date:
- 2014-05-12
- Revision:
- 2:9caef35c5062
- Parent:
- 1:5be2682710c6
- Child:
- 3:fb5f79ff292b
File content as of revision 2:9caef35c5062:
#include "mbed.h" #include "nRF24L01P.h" #define V_SERVO_CENTER 1800 #define V_SERVO_MAX 2200 #define V_SERVO_MIN 800 #define H_SERVO_CENTER 1600 #define H_SERVO_MAX 2200 #define H_SERVO_MIN 800 #define TRANSFER_SIZE 9 Serial pc(USBTX, USBRX); // tx, rx nRF24L01P my_nrf24l01p(PTD6, PTD7, PTD5, PTD4, PTC12, PTC18); // mosi, miso, sck, csn, ce, irq DigitalOut myled1(LED1); DigitalOut myled2(LED2); DigitalOut myled3(LED3); DigitalOut fire(PTB23); PwmOut v_servo(PTC2); PwmOut h_servo(PTA2); int main() { // The nRF24L01+ supports transfers from 1 to 32 bytes, but Sparkfun's // "Nordic Serial Interface Board" (http://www.sparkfun.com/products/9019) // only handles 4 byte transfers in the ATMega code. myled1 = 1; myled2 = 1; myled3 = 0; pc.baud(115200); char rxData[TRANSFER_SIZE]; int rxDataCnt = 0; my_nrf24l01p.setRxAddress(0xDEADBEEF01); my_nrf24l01p.powerUp(); // Display the (default) setup of the nRF24L01+ chip pc.printf( "nRF24L01+ Frequency : %d MHz\r\n", my_nrf24l01p.getRfFrequency() ); pc.printf( "nRF24L01+ Output power : %d dBm\r\n", my_nrf24l01p.getRfOutputPower() ); pc.printf( "nRF24L01+ Data Rate : %d kbps\r\n", my_nrf24l01p.getAirDataRate() ); pc.printf( "nRF24L01+ TX Address : 0x%010llX\r\n", my_nrf24l01p.getTxAddress() ); pc.printf( "nRF24L01+ RX Address : 0x%010llX\r\n", my_nrf24l01p.getRxAddress() ); pc.printf( "This is the Receiver\r\n"); my_nrf24l01p.setTransferSize( TRANSFER_SIZE ); my_nrf24l01p.setReceiveMode(); my_nrf24l01p.enable(); v_servo.period_us(20000); // servo requires a 20ms period v_servo.pulsewidth_us(V_SERVO_CENTER); h_servo.period_us(20000); // servo requires a 20ms period h_servo.pulsewidth_us(H_SERVO_CENTER); fire = 0; int v_pulse = V_SERVO_CENTER; int h_pulse = H_SERVO_CENTER; v_servo.pulsewidth_us(v_pulse); // servo position determined by a pulsewidth between 1-2ms h_servo.pulsewidth_us(h_pulse); // servo position determined by a pulsewidth between 1-2ms wait(0.5); int32_t acc_x, acc_y; char fire_button; while (1) { // If we've received anything in the nRF24L01+... if ( my_nrf24l01p.readable() ) { // ...read the data into the receive buffer rxDataCnt = my_nrf24l01p.read( NRF24L01P_PIPE_P0, rxData, sizeof( rxData ) ); // Display the receive buffer contents via the host serial link acc_x = (int32_t)((rxData[0])|(rxData[1]<<8)|(rxData[2]<<16)|(rxData[3]<<24)); acc_y = (int32_t)((rxData[4])|(rxData[5]<<8)|(rxData[6]<<16)|(rxData[7]<<24)); fire_button = rxData[8]; //pc.printf("%d\t%d\t- %d\n\r",acc_x,acc_y,fire_button); //pc.printf("%01x %01x %01x %01x %01x %01x\n\r",rxData[1],rxData[0],rxData[3],rxData[2],rxData[5],rxData[4]); v_pulse = V_SERVO_CENTER + acc_x; h_pulse = H_SERVO_CENTER + acc_y; if (v_pulse <= V_SERVO_MIN) v_pulse = V_SERVO_MIN; if (v_pulse >= V_SERVO_MAX) v_pulse = V_SERVO_MAX; if (h_pulse <= H_SERVO_MIN) h_pulse = H_SERVO_MIN; if (h_pulse >= H_SERVO_MAX) h_pulse = H_SERVO_MAX; v_servo.pulsewidth_us(v_pulse); // servo position determined by a pulsewidth between 1-2ms h_servo.pulsewidth_us(h_pulse); // servo position determined by a pulsewidth between 1-2ms //pc.printf("%d\t%d\t\n\r",v_pulse,h_pulse); myled1 = fire_button; myled3 = !fire_button; fire = !fire_button; } } }