BLE beacon code designed to be remotely compiled by the ble-scanner-station-demo code. https://github.com/BlackstoneEngineering/ble-scanner-station-demo

Dependencies:   BLE_API mbed nRF51822

Fork of BLE_GAP_Example by Bluetooth Low Energy

This code is meant to be used as a target for remote compilation. Users can pass in the NAME variable to change the broadcast name of the beacon being compiled.

This program is meant to be used in conjunction with the NodeJS ble-scanner-station-demo webapp and the remote compile api JS webapp.

The NodeJS ble-scanner-station-demo will display a webpage like the following. The Orange text will be replaced with the name of the beacon. For more details see the repo page

/media/uploads/mbedAustin/screenshot.png

Files at this revision

API Documentation at this revision

Comitter:
mbedAustin
Date:
Tue Mar 17 19:45:19 2015 +0000
Parent:
7:f9a2fa5b1d43
Child:
9:4241e0bac7b3
Commit message:
Added comments and disconnection callback option

Changed in this revision

main.cpp Show annotated file Show diff for this revision Revisions of this file
--- a/main.cpp	Tue Mar 10 22:42:14 2015 +0000
+++ b/main.cpp	Tue Mar 17 19:45:19 2015 +0000
@@ -6,21 +6,28 @@
 // BLE object
 BLEDevice ble;
 
-//const static char     DEVICE_NAME[]        = "ChangeMe!!"; // change this
+// Optional name, add for human read-ability
+//const static char     DEVICE_NAME[]        = "ChangeMe!!"; // Optional: device name
 
 /**
-  You have up to 26 bytes of advertising data to use.
-  Make up your own encoding for these 26bytes, send it across
-  and decode it using the evothings app.
+  * You have up to 26 bytes of advertising data to use.
+  * Make up your own encoding for these 26bytes, send it across
+  * and decode it using the evothings app.
  */
-//const static uint8_t AdvData[] = {"ChangeThisData"};             // example of character data
+//const static uint8_t AdvData[] = {"ChangeThisData"};         // example of character data
 const static uint8_t AdvData[] = {0x01,0x02,0x03,0x04,0x05};   // example of hex data
 
+// Restart advertising when phone app disconnects 
+void disconnectionCallback(Gap::Handle_t handle, Gap::DisconnectionReason_t reason){
+    ble.startAdvertising(); 
+}
+
 // main program
 int main(void)
 {
     // Initialize BLE baselayer, always do this first!
     ble.init();
+    // ble.onDisconnection(disconnectionCallback); // Optional: add callback for disconnection
 
     // Sacrifice 3B of 31B to Advertising Flags
     ble.accumulateAdvertisingPayload(GapAdvertisingData::BREDR_NOT_SUPPORTED | GapAdvertisingData::LE_GENERAL_DISCOVERABLE );
@@ -29,7 +36,7 @@
     // Sacrifice 2B of 31B to AdvType overhead, rest goes to AdvData array you define
     ble.accumulateAdvertisingPayload(GapAdvertisingData::MANUFACTURER_SPECIFIC_DATA, AdvData, sizeof(AdvData));
     
-    // Add name to device 
+    // Optional: Add name to device 
     //ble.accumulateAdvertisingPayload(GapAdvertisingData::COMPLETE_LOCAL_NAME, (uint8_t *)DEVICE_NAME, sizeof(DEVICE_NAME));
 
     // Set advertising interval. Longer interval = longer battery life
@@ -38,6 +45,6 @@
 
     // Infinite loop waiting for BLE events
     for (;;) {
-        ble.waitForEvent(); // this saves battery
+        ble.waitForEvent(); // this saves battery while waiting for callback events
     }
 }