Solution for Bluetooth SIG hands-on training course

Dependencies:   BLE_API mbed-dev-bin nRF51822-bluetooth-mdw

Dependents:   microbit

Fork of microbit-dal-bluetooth-mdw_starter by Martin Woolley

Revision:
77:9909cbcd0ece
Parent:
74:9771cd712730
Child:
80:74afcabdc9a1
--- a/source/bluetooth/MicroBitAnimationService.cpp	Tue Dec 27 10:59:38 2016 +0000
+++ b/source/bluetooth/MicroBitAnimationService.cpp	Tue Dec 27 11:55:17 2016 +0000
@@ -41,57 +41,35 @@
 MicroBitAnimationService::MicroBitAnimationService(BLEDevice &_ble) :
         ble(_ble)
 {
-    // UUID, valuePTR, length, max length, properties
-    GattCharacteristic  animationTypeCharacteristic(
-        MicroBitAnimationServiceAnimationTypeCharacteristicUUID, 
-        (uint8_t *)animation_type_buffer, 
-        1, 
-        1,
-        GattCharacteristic::BLE_GATT_CHAR_PROPERTIES_READ | GattCharacteristic::BLE_GATT_CHAR_PROPERTIES_WRITE);
-        
-    GattCharacteristic  animationStatusCharacteristic(
-        MicroBitAnimationServiceAnimationStatusCharacteristicUUID, 
-        (uint8_t *)animation_status_buffer, 
-        1, 
-        1,
-        GattCharacteristic::BLE_GATT_CHAR_PROPERTIES_READ | GattCharacteristic::BLE_GATT_CHAR_PROPERTIES_NOTIFY);
+    // TODO: Three GattCharacteristic objects. UUID, valuePTR, length, max length, properties.
+
 
-    GattCharacteristic  animationControlCharacteristic(
-        MicroBitAnimationServiceAnimationControlCharacteristicUUID, 
-        (uint8_t *)animation_control_buffer, 
-        1, 
-        1,
-        GattCharacteristic::BLE_GATT_CHAR_PROPERTIES_WRITE);
+    // TODO: initialise characteristic value buffers
 
-    animation_type_buffer[0]    = 0x00;
-    animation_status_buffer[0]  = 0x00;
-    animation_control_buffer[0] = 0x00;
+
 
     // Set default security requirements - optional
     // animationTypeCharacteristic.requireSecurity(SecurityManager::MICROBIT_BLE_SECURITY_LEVEL);
     // animationStatusCharacteristic.requireSecurity(SecurityManager::MICROBIT_BLE_SECURITY_LEVEL);
     // animationControlCharacteristic.requireSecurity(SecurityManager::MICROBIT_BLE_SECURITY_LEVEL);
 
+    // TODO: create GattService containing the three characteristics
     // create an array of our characteristics so we can pass them to the service when we create it
-    GattCharacteristic *characteristics[] = {&animationTypeCharacteristic, &animationStatusCharacteristic, &animationControlCharacteristic};
 
     // create the animation service and specify its characteristics
-    GattService         service(MicroBitAnimationServiceUUID, characteristics, sizeof(characteristics) / sizeof(GattCharacteristic *));
+
+
 
-    // add the service to the Bluetooth attribute table
-    ble.addService(service);
+    // TODO: add the service to the Bluetooth attribute table
+
 
-    // take a note of the handles of our new characteristics now that they're in the attribute table
-    animationTypeCharacteristicHandle = animationTypeCharacteristic.getValueHandle();
-    animationStatusCharacteristicHandle = animationStatusCharacteristic.getValueHandle();
-    animationControlCharacteristicHandle = animationControlCharacteristic.getValueHandle();
+    // TODO: take a note of the handles of our new characteristics now that they're in the attribute table
+
+
+    // TODO: set the attribute table's characteristic values to the initialised buffer values    
     
-    ble.gattServer().write(animationTypeCharacteristicHandle, (const uint8_t *)&animation_type_buffer, sizeof(animation_type_buffer));
-    ble.gattServer().write(animationStatusCharacteristicHandle, (const uint8_t *)&animation_status_buffer, sizeof(animation_status_buffer));
-    ble.gattServer().write(animationControlCharacteristicHandle, (const uint8_t *)&animation_control_buffer, sizeof(animation_control_buffer));
 
-    // register a callback function for when a characteristic is written to
-    ble.onDataWritten(this, &MicroBitAnimationService::onDataWritten);
+    // TODO: register a callback function for when a characteristic is written to
     
     // subscribe to animation status events so they can be notified to the connected client
     if (EventModel::defaultEventBus)
@@ -105,28 +83,19 @@
 void MicroBitAnimationService::onDataWritten(const GattWriteCallbackParams *params)
 {
    
-    if (params->handle == animationTypeCharacteristicHandle && params->len >= 1) {
-        uint8_t *value = (uint8_t *)params->data;
-        uint16_t event_value = static_cast<uint16_t>(value[0]);
-        MicroBitEvent evt(ANIMATION_TYPE_EVENT, event_value);
-        return;
-    }
+    // TODO: handle write to animation type characteristic
 
-    if (params->handle == animationControlCharacteristicHandle && params->len >= 1) {
-        uint8_t *value = (uint8_t *)params->data;
-        uint16_t event_value = static_cast<uint16_t>(value[0]);
-        MicroBitEvent evt(ANIMATION_CONTROL_EVENT, event_value);
-        return;
-    }
+ 
+    // TODO: handle write to animation control characteristic
+
+
 }
 
 void MicroBitAnimationService::animationStatusUpdate(MicroBitEvent e)
 {
-    if (ble.getGapState().connected)
-    {
-        animation_status_buffer[0] = e.value;
-        ble.gattServer().notify(animationStatusCharacteristicHandle,(uint8_t *)animation_status_buffer, 1);
-    }
+    // TODO: notify connected client of change to the animation status characteristic
+
+
 }
 
 const uint8_t  MicroBitAnimationServiceUUID[] = {