Example program for BLE devices using updated Puck library.

Dependencies:   Puck mbed

Fork of location-puck by Nordic Pucks

Revision:
8:54535e2f4098
Parent:
6:306e898c274f
Child:
9:28eb877be5f8
--- a/main.cpp	Thu Jul 03 10:48:53 2014 +0000
+++ b/main.cpp	Thu Jul 03 12:51:28 2014 +0000
@@ -1,7 +1,7 @@
 #include <mbed.h>
-#include "nRF51822n.h"
+#include "BLEDevice.h"
 
-#define DEBUG 1
+#define DEBUG 0
 #ifdef DEBUG
     Serial pc(USBTX, USBRX);
     #define LOG(args...)    pc.printf(args)
@@ -13,7 +13,7 @@
  * The Beacon payload (encapsulated within the MSD advertising data structure)
  * has the following composition:
  * 128-Bit UUID = E2 0A 39 F4 73 F5 4B C4 A1 2F 17 D1 AD 07 A9 61
- * Major/Minor  = 0000 / 0000
+ * Major/Minor  = 1337 / XXXX
  * Tx Power     = C8
  */
 const static uint8_t beaconPayload[] = {
@@ -22,35 +22,28 @@
     0x15,       // length of the remaining payload
     0xE2, 0x0A, 0x39, 0xF4, 0x73, 0xF5, 0x4B, 0xC4, // UUID
     0xA1, 0x2F, 0x17, 0xD1, 0xAD, 0x07, 0xA9, 0x61,
-    0x13, 0x37, // the major value to differenciate a location
-    0x13, 0x38, // the minor value to differenciate a location
+    0x13, 0x37, // the major value to differenciate a location (Our app requires 1337 as major number)
+    0x13, 0x38, // the minor value to differenciate a location (Change this to differentiate location pucks)
     0xC8        // 2's complement of the Tx power (-56dB)
 };
 
-nRF51822n nrf;
+BLEDevice ble;
 DigitalOut led1(LED1);
 
-GapAdvertisingData advData;
-GapAdvertisingData scanResponse;
-GapAdvertisingParams advParams(GapAdvertisingParams::ADV_NON_CONNECTABLE_UNDIRECTED);
-
 int main(void) {
     led1 = 1;
 
-    LOG("Starting init\n");
-    nrf.init();
-    nrf.reset();
-    LOG("Init and reset nrf done\n");
+    LOG("Initializing ble beacon\n");
+    ble.init();
 
-    advData.addFlags(GapAdvertisingData::BREDR_NOT_SUPPORTED);
-    advData.addData(GapAdvertisingData::MANUFACTURER_SPECIFIC_DATA,
+    ble.accumulateAdvertisingPayload(GapAdvertisingData::BREDR_NOT_SUPPORTED);
+    ble.accumulateAdvertisingPayload(GapAdvertisingData::MANUFACTURER_SPECIFIC_DATA,
                     beaconPayload, sizeof(beaconPayload));
-    advData.addAppearance(GapAdvertisingData::UNKNOWN);
+    
+    ble.setAdvertisingType(GapAdvertisingParams::ADV_NON_CONNECTABLE_UNDIRECTED);
+    ble.setAdvertisingInterval(160); /* 100ms; in multiples of 0.625ms. */
 
-    nrf.getGap().setAdvertisingData(advData, scanResponse);
-    LOG("Set advertising data done!\n");
-
-    nrf.getGap().startAdvertising(advParams);
+    ble.startAdvertising();
     LOG("Starting advertising!\n");
 
     for(;;) {