abc

Fork of BLE_API by Bluetooth Low Energy

Committer:
rgrover1
Date:
Tue Dec 09 08:18:11 2014 +0000
Revision:
242:0e9201b67e2f
Parent:
236:a77aefd88e78
Child:
243:98f930d14515
Synchronized with git rev c7eb83db
Author: Rohit Grover
minor white space diffs and fixes for typos.

Who changed what in which revision?

UserRevisionLine numberNew contents of line
Rohit Grover 118:620d28e7a1ba 1 /* mbed Microcontroller Library
Rohit Grover 118:620d28e7a1ba 2 * Copyright (c) 2006-2013 ARM Limited
Rohit Grover 118:620d28e7a1ba 3 *
Rohit Grover 118:620d28e7a1ba 4 * Licensed under the Apache License, Version 2.0 (the "License");
Rohit Grover 118:620d28e7a1ba 5 * you may not use this file except in compliance with the License.
Rohit Grover 118:620d28e7a1ba 6 * You may obtain a copy of the License at
Rohit Grover 118:620d28e7a1ba 7 *
Rohit Grover 118:620d28e7a1ba 8 * http://www.apache.org/licenses/LICENSE-2.0
Rohit Grover 118:620d28e7a1ba 9 *
Rohit Grover 118:620d28e7a1ba 10 * Unless required by applicable law or agreed to in writing, software
Rohit Grover 118:620d28e7a1ba 11 * distributed under the License is distributed on an "AS IS" BASIS,
Rohit Grover 118:620d28e7a1ba 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
Rohit Grover 118:620d28e7a1ba 13 * See the License for the specific language governing permissions and
Rohit Grover 118:620d28e7a1ba 14 * limitations under the License.
Rohit Grover 118:620d28e7a1ba 15 */
Rohit Grover 118:620d28e7a1ba 16
Rohit Grover 118:620d28e7a1ba 17 #ifndef __BLE_HEALTH_THERMOMETER_SERVICE_H__
Rohit Grover 118:620d28e7a1ba 18 #define __BLE_HEALTH_THERMOMETER_SERVICE_H__
Rohit Grover 118:620d28e7a1ba 19
Rohit Grover 118:620d28e7a1ba 20 #include "BLEDevice.h"
Rohit Grover 118:620d28e7a1ba 21
rgrover1 242:0e9201b67e2f 22 /**
mbedAustin 235:448f29f4ae7f 23 * @class HealthThermometerService
rgrover1 242:0e9201b67e2f 24 * @brief BLE Health Thermometer Service. This service provides the location of the thermometer and the temperature. <br>
mbedAustin 235:448f29f4ae7f 25 * Service: https://developer.bluetooth.org/gatt/profiles/Pages/ProfileViewer.aspx?u=org.bluetooth.profile.health_thermometer.xml <br>
mbedAustin 235:448f29f4ae7f 26 * Temperature Measurement: https://developer.bluetooth.org/gatt/characteristics/Pages/CharacteristicViewer.aspx?u=org.bluetooth.characteristic.temperature_measurement.xml <br>
rgrover1 242:0e9201b67e2f 27 * Temperature Type: https://developer.bluetooth.org/gatt/characteristics/Pages/CharacteristicViewer.aspx?u=org.bluetooth.characteristic.temperature_type.xml
mbedAustin 235:448f29f4ae7f 28 */
Rohit Grover 118:620d28e7a1ba 29 class HealthThermometerService {
Rohit Grover 118:620d28e7a1ba 30 public:
mbedAustin 235:448f29f4ae7f 31 /**
mbedAustin 235:448f29f4ae7f 32 * @enum Sensor Location
rgrover1 242:0e9201b67e2f 33 * @brief Location of sensor on the body
mbedAustin 235:448f29f4ae7f 34 */
Rohit Grover 118:620d28e7a1ba 35 enum {
mbedAustin 235:448f29f4ae7f 36 LOCATION_ARMPIT = 1, /*!< armpit */
mbedAustin 235:448f29f4ae7f 37 LOCATION_BODY, /*!< body */
mbedAustin 235:448f29f4ae7f 38 LOCATION_EAR, /*!< ear */
mbedAustin 235:448f29f4ae7f 39 LOCATION_FINGER, /*!< finger */
mbedAustin 235:448f29f4ae7f 40 LOCATION_GI_TRACT, /*!< GI tract */
mbedAustin 235:448f29f4ae7f 41 LOCATION_MOUTH, /*!< mouth */
mbedAustin 235:448f29f4ae7f 42 LOCATION_RECTUM, /*!< rectum */
mbedAustin 235:448f29f4ae7f 43 LOCATION_TOE, /*!< toe */
mbedAustin 235:448f29f4ae7f 44 LOCATION_EAR_DRUM, /*!< ear drum */
Rohit Grover 118:620d28e7a1ba 45 };
Rohit Grover 118:620d28e7a1ba 46
Rohit Grover 118:620d28e7a1ba 47 public:
Rohit Grover 118:620d28e7a1ba 48 /**
rgrover1 242:0e9201b67e2f 49 * @brief Add the Health Thermometer Service to an existing ble object, initialize with temperature and location.
mbedAustin 235:448f29f4ae7f 50 * @param[ref] _ble reference to the BLE device
Rohit Grover 118:620d28e7a1ba 51 * @param[in] initialTemp initial value in celsius
Rohit Grover 118:620d28e7a1ba 52 * @param[in] _location
Rohit Grover 118:620d28e7a1ba 53 */
Rohit Grover 118:620d28e7a1ba 54 HealthThermometerService(BLEDevice &_ble, float initialTemp, uint8_t _location) :
Rohit Grover 118:620d28e7a1ba 55 ble(_ble),
Rohit Grover 118:620d28e7a1ba 56 valueBytes(initialTemp),
Rohit Grover 118:620d28e7a1ba 57 tempMeasurement(GattCharacteristic::UUID_TEMPERATURE_MEASUREMENT_CHAR, valueBytes.getPointer(),
Rohit Grover 118:620d28e7a1ba 58 sizeof(TemperatureValueBytes), sizeof(TemperatureValueBytes),
Rohit Grover 118:620d28e7a1ba 59 GattCharacteristic::BLE_GATT_CHAR_PROPERTIES_READ | GattCharacteristic::BLE_GATT_CHAR_PROPERTIES_NOTIFY),
Rohit Grover 118:620d28e7a1ba 60 tempLocation(GattCharacteristic::UUID_TEMPERATURE_TYPE_CHAR, (uint8_t *)&_location, sizeof(_location), sizeof(_location),
Rohit Grover 118:620d28e7a1ba 61 GattCharacteristic::BLE_GATT_CHAR_PROPERTIES_READ) {
Rohit Grover 118:620d28e7a1ba 62
Rohit Grover 118:620d28e7a1ba 63 GattCharacteristic *hrmChars[] = {&tempMeasurement, &tempLocation, };
Rohit Grover 118:620d28e7a1ba 64 GattService hrmService(GattService::UUID_HEALTH_THERMOMETER_SERVICE, hrmChars, sizeof(hrmChars) / sizeof(GattCharacteristic *));
Rohit Grover 118:620d28e7a1ba 65
Rohit Grover 118:620d28e7a1ba 66 ble.addService(hrmService);
Rohit Grover 118:620d28e7a1ba 67 }
Rohit Grover 118:620d28e7a1ba 68
mbedAustin 235:448f29f4ae7f 69 /**
rgrover1 242:0e9201b67e2f 70 * @brief Update the temperature being broadcast
mbedAustin 235:448f29f4ae7f 71 *
mbedAustin 235:448f29f4ae7f 72 * @param[in] temperature
mbedAustin 235:448f29f4ae7f 73 * Floating point value of the temperature
rgrover1 242:0e9201b67e2f 74 *
mbedAustin 235:448f29f4ae7f 75 */
Rohit Grover 118:620d28e7a1ba 76 void updateTemperature(float temperature) {
Rohit Grover 118:620d28e7a1ba 77 if (ble.getGapState().connected) {
Rohit Grover 118:620d28e7a1ba 78 valueBytes.updateTemperature(temperature);
Rohit Grover 118:620d28e7a1ba 79 ble.updateCharacteristicValue(tempMeasurement.getValueAttribute().getHandle(), valueBytes.getPointer(), sizeof(TemperatureValueBytes));
Rohit Grover 118:620d28e7a1ba 80 }
Rohit Grover 118:620d28e7a1ba 81 }
Rohit Grover 118:620d28e7a1ba 82
Rohit Grover 118:620d28e7a1ba 83 private:
Rohit Grover 118:620d28e7a1ba 84 /* Private internal representation for the bytes used to work with the vaulue of the heart-rate characteristic. */
Rohit Grover 118:620d28e7a1ba 85 struct TemperatureValueBytes {
Rohit Grover 118:620d28e7a1ba 86 static const unsigned OFFSET_OF_FLAGS = 0;
Rohit Grover 118:620d28e7a1ba 87 static const unsigned OFFSET_OF_VALUE = OFFSET_OF_FLAGS + sizeof(uint8_t);
Rohit Grover 118:620d28e7a1ba 88 static const unsigned SIZEOF_VALUE_BYTES = sizeof(uint8_t) + sizeof(float);
Rohit Grover 118:620d28e7a1ba 89
Rohit Grover 118:620d28e7a1ba 90 static const unsigned TEMPERATURE_UNITS_FLAG_POS = 0;
Rohit Grover 118:620d28e7a1ba 91 static const unsigned TIMESTAMP_FLAG_POS = 1;
Rohit Grover 118:620d28e7a1ba 92 static const unsigned TEMPERATURE_TYPE_FLAG_POS = 2;
Rohit Grover 118:620d28e7a1ba 93
rgrover1 242:0e9201b67e2f 94 static const uint8_t TEMPERATURE_UNITS_CELSIUS = 0;
rgrover1 242:0e9201b67e2f 95 static const uint8_t TEMPERATURE_UNITS_FAHRENHEIT = 1;
Rohit Grover 118:620d28e7a1ba 96
Rohit Grover 118:620d28e7a1ba 97 TemperatureValueBytes(float initialTemperature) : bytes() {
Rohit Grover 118:620d28e7a1ba 98 /* assumption: temperature values are expressed in Celsius */
Rohit Grover 118:620d28e7a1ba 99 bytes[OFFSET_OF_FLAGS] = (TEMPERATURE_UNITS_CELSIUS << TEMPERATURE_UNITS_FLAG_POS) |
Rohit Grover 118:620d28e7a1ba 100 (false << TIMESTAMP_FLAG_POS) |
Rohit Grover 118:620d28e7a1ba 101 (false << TEMPERATURE_TYPE_FLAG_POS);
Rohit Grover 118:620d28e7a1ba 102 updateTemperature(initialTemperature);
Rohit Grover 118:620d28e7a1ba 103 }
Rohit Grover 118:620d28e7a1ba 104
Rohit Grover 118:620d28e7a1ba 105 void updateTemperature(float temp) {
Rohit Grover 118:620d28e7a1ba 106 uint32_t temp_ieee11073 = quick_ieee11073_from_float(temp);
Rohit Grover 118:620d28e7a1ba 107 memcpy(&bytes[OFFSET_OF_VALUE], &temp_ieee11073, sizeof(float));
Rohit Grover 118:620d28e7a1ba 108 }
Rohit Grover 118:620d28e7a1ba 109
rgrover1 242:0e9201b67e2f 110 uint8_t *getPointer(void) {
Rohit Grover 118:620d28e7a1ba 111 return bytes;
Rohit Grover 118:620d28e7a1ba 112 }
Rohit Grover 118:620d28e7a1ba 113
Rohit Grover 118:620d28e7a1ba 114 const uint8_t *getPointer(void) const {
Rohit Grover 118:620d28e7a1ba 115 return bytes;
Rohit Grover 118:620d28e7a1ba 116 }
Rohit Grover 118:620d28e7a1ba 117
rgrover1 242:0e9201b67e2f 118 private:
Rohit Grover 118:620d28e7a1ba 119 /**
Rohit Grover 118:620d28e7a1ba 120 * @brief A very quick conversion between a float temperature and 11073-20601 FLOAT-Type.
Rohit Grover 118:620d28e7a1ba 121 * @param temperature The temperature as a float.
Rohit Grover 118:620d28e7a1ba 122 * @return The temperature in 11073-20601 FLOAT-Type format.
Rohit Grover 118:620d28e7a1ba 123 */
Rohit Grover 118:620d28e7a1ba 124 uint32_t quick_ieee11073_from_float(float temperature) {
Rohit Grover 118:620d28e7a1ba 125 uint8_t exponent = 0xFE; //exponent is -2
Rohit Grover 118:620d28e7a1ba 126 uint32_t mantissa = (uint32_t)(temperature * 100);
Rohit Grover 118:620d28e7a1ba 127
Rohit Grover 118:620d28e7a1ba 128 return (((uint32_t)exponent) << 24) | mantissa;
Rohit Grover 118:620d28e7a1ba 129 }
Rohit Grover 118:620d28e7a1ba 130
rgrover1 242:0e9201b67e2f 131 private:
Rohit Grover 118:620d28e7a1ba 132 /* First byte = 8-bit flags, Second field is a float holding the temperature value. */
Rohit Grover 118:620d28e7a1ba 133 /* See --> https://developer.bluetooth.org/gatt/characteristics/Pages/CharacteristicViewer.aspx?u=org.bluetooth.characteristic.temperature_measurement.xml */
Rohit Grover 118:620d28e7a1ba 134 uint8_t bytes[SIZEOF_VALUE_BYTES];
Rohit Grover 118:620d28e7a1ba 135 };
Rohit Grover 118:620d28e7a1ba 136
Rohit Grover 118:620d28e7a1ba 137 private:
Rohit Grover 118:620d28e7a1ba 138 BLEDevice &ble;
Rohit Grover 118:620d28e7a1ba 139 TemperatureValueBytes valueBytes;
Rohit Grover 118:620d28e7a1ba 140 GattCharacteristic tempMeasurement;
Rohit Grover 118:620d28e7a1ba 141 GattCharacteristic tempLocation;
Rohit Grover 118:620d28e7a1ba 142 };
Rohit Grover 118:620d28e7a1ba 143
rgrover1 242:0e9201b67e2f 144 #endif /* #ifndef __BLE_HEALTH_THERMOMETER_SERVICE_H__*/